File: ldst-reg-pair.s

package info (click to toggle)
binutils 2.31.1-11
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 307,644 kB
  • sloc: ansic: 1,161,122; asm: 638,494; cpp: 128,815; exp: 68,557; makefile: 55,816; sh: 22,360; yacc: 14,238; lisp: 13,272; perl: 2,111; ada: 1,681; lex: 1,652; pascal: 1,446; cs: 879; sed: 195; python: 154; xml: 95; awk: 25
file content (111 lines) | stat: -rw-r--r-- 2,579 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/* ldst-reg-pair.s Test file for AArch64 load-store reg.pair instructions.

   Copyright (C) 2011-2018 Free Software Foundation, Inc.
   Contributed by ARM Ltd.

   This file is part of GAS.

   GAS is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 3 of the license, or
   (at your option) any later version.

   GAS is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; see the file COPYING3. If not,
   see <http://www.gnu.org/licenses/>.  */

/* Includes:
 *   Load-store reg.pair (offset)
 *   Load-store reg.pair (post-ind.)
 *   Load-store reg.pair (pre-ind.)
 *   Load-store na.pair (pre-ind.)
 */

	// offset format
	.macro	op3_offset op, reg, imm
	\op	\reg\()7, \reg\()15, [sp, #\imm]
	.endm

	// post-ind. format
	.macro	op3_post_ind op, reg, imm
	\op	\reg\()7, \reg\()15, [sp], #\imm
	.endm

	// pre-ind. format
	.macro	op3_pre_ind op, reg, imm
	\op	\reg\()7, \reg\()15, [sp, #\imm]!
	.endm

	.macro	op3 op, reg, size, type
	// a variety of values for the imm7 field
	.irp	imm7, -64, -31, -1, 0, 15, 63
		// offset format
		.ifc \type, 1
		op3_offset	\op, \reg, "(\imm7*\size)"
		.endif
		// post-ind. format
		.ifc \type, 2
		op3_post_ind	\op, \reg, "(\imm7*\size)"
		.endif
		// pre-ind. format
		.ifc \type, 3
		op3_pre_ind	\op, \reg, "(\imm7*\size)"
		.endif
	.endr
	.endm

	.macro ldst_reg_pair type
	//     	op, reg, size(in byte) of one of the pair, type
	op3	stp, w, 4, \type
	op3	ldp, w, 4, \type

	op3	ldpsw, x, 4, \type

	op3	stp, x, 8, \type
	op3	ldp, x, 8, \type

	op3	stp, s, 4, \type
	op3	ldp, s, 4, \type

	op3	stp, d, 8, \type
	op3	ldp, d, 8, \type

	op3	stp, q, 16, \type
	op3	ldp, q, 16, \type
	.endm

	.macro ldst_reg_na_pair type
	//     	op, reg, size(in byte) of one of the pair, type
	op3	stnp, w, 4, \type
	op3	ldnp, w, 4, \type

	op3	stnp, x, 8, \type
	op3	ldnp, x, 8, \type

	op3	stnp, s, 4, \type
	op3	ldnp, s, 4, \type

	op3	stnp, d, 8, \type
	op3	ldnp, d, 8, \type

	op3	stnp, q, 16, \type
	op3	ldnp, q, 16, \type
	.endm

func:
	// Load-store reg.pair (offset)
	ldst_reg_pair	1

	// Load-store reg.pair (post-ind.)
	ldst_reg_pair	2

	// Load-store reg.pair (pre-ind.)
	ldst_reg_pair	3

	// Load-store na.pair (offset)
	ldst_reg_na_pair	1