File: movi.s

package info (click to toggle)
binutils-avr 2.26.20160125%2BAtmel3.6.2-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 365,552 kB
  • sloc: ansic: 2,480,046; asm: 892,807; exp: 188,218; cpp: 133,829; makefile: 63,886; sh: 32,212; yacc: 26,783; lisp: 16,709; xml: 7,490; perl: 6,449; python: 4,555; ada: 4,318; pascal: 3,174; lex: 2,250; cs: 879; sed: 334; f90: 298; awk: 168; objc: 134; java: 73; fortran: 43
file content (120 lines) | stat: -rw-r--r-- 3,073 bytes parent folder | download | duplicates (29)
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
112
113
114
115
116
117
118
119
120
// movi.s Test file for AArch64 AdvSIMD modified immediate instruction MOVI

	.text

	.macro all_64bit_mask_movi	dst
	.irp	b7, 0, 0xff00000000000000
	.irp	b6, 0, 0xff000000000000
	.irp	b5, 0, 0xff0000000000
	.irp	b4, 0, 0xff00000000
	.irp	b3, 0, 0xff000000
	.irp	b2, 0, 0xff0000
	.irp	b1, 0, 0xff00
	.irp	b0, 0, 0xff
	movi	\dst, \b7 + \b6 + \b5 + \b4 + \b3 + \b2 + \b1 + \b0
	.endr
	.endr
	.endr
	.endr
	.endr
	.endr
	.endr
	.endr
	.endm

	// MOVI <Dd>, #<imm>
	// MOVI <Vd>.2D, #<imm>
	all_64bit_mask_movi d31
	all_64bit_mask_movi v15.2d


	.macro	all_8bit_imm_movi dst, from=0, to=255
	movi	\dst, \from
	.if	\to-\from
	all_8bit_imm_movi \dst, "(\from+1)", \to
	.endif
	.endm

	// Per byte
	// MOVI <Vd>.<T>, #<imm8>
	.irp	T, 8b, 16b
	all_8bit_imm_movi v15.\T, 0, 63
	all_8bit_imm_movi v15.\T, 64, 127
	all_8bit_imm_movi v15.\T, 128, 191
	all_8bit_imm_movi v15.\T, 192, 255
	.endr


	.macro	all_8bit_imm_movi_sft dst, from=0, to=255, shift_op, amount
	movi	\dst, \from, \shift_op \amount
	.if	\to-\from
	all_8bit_imm_movi_sft \dst, "(\from+1)", \to, \shift_op, \amount
	.endif
	.endm

	// Shift ones, per word
	// MOVI <Vd>.<T>, #<imm8>, MSL #<amount>
	.irp	T, 2s, 4s
	.irp	amount, 8, 16
	// Have to break into four chunks to avoid "Fatal error: macros nested
	// too deeply".
	all_8bit_imm_movi_sft v7.\T, 0, 63, MSL, \amount
	all_8bit_imm_movi_sft v7.\T, 64, 127, MSL, \amount
	all_8bit_imm_movi_sft v7.\T, 128, 191, MSL, \amount
	all_8bit_imm_movi_sft v7.\T, 192, 255, MSL, \amount
	.endr
	.endr


	// Shift zeros, per halfword
	// MOVI <Vd>.<T>, #<imm8> {, LSL #<amount>}
	.irp	T, 4h, 8h
	.irp	amount, 0, 8
	all_8bit_imm_movi_sft v7.\T, 0, 63, LSL, \amount
	all_8bit_imm_movi_sft v7.\T, 64, 127, LSL, \amount
	all_8bit_imm_movi_sft v7.\T, 128, 191, LSL, \amount
	all_8bit_imm_movi_sft v7.\T, 192, 255, LSL, \amount
	all_8bit_imm_movi v15.\T, 0, 63
	all_8bit_imm_movi v15.\T, 64, 127
	all_8bit_imm_movi v15.\T, 128, 191
	all_8bit_imm_movi v15.\T, 192, 255
	.endr
	.endr


	// Shift zeros, per word
	// MOVI <Vd>.<T>, #<imm8> {, LSL #<amount>}
	.irp	T, 2s, 4s
	.irp	amount, 0, 8, 16, 24
	all_8bit_imm_movi_sft v7.\T, 0, 63, LSL, \amount
	all_8bit_imm_movi_sft v7.\T, 64, 127, LSL, \amount
	all_8bit_imm_movi_sft v7.\T, 128, 191, LSL, \amount
	all_8bit_imm_movi_sft v7.\T, 192, 255, LSL, \amount
	all_8bit_imm_movi v15.\T, 0, 63
	all_8bit_imm_movi v15.\T, 64, 127
	all_8bit_imm_movi v15.\T, 128, 191
	all_8bit_imm_movi v15.\T, 192, 255
	.endr
	.endr

	// Shift zeros, per byte
	// MOVI <Vd>.<T>, #<imm8>, LSL #0
	// This used to be a programmer-friendly feature (allowing LSL #0),
	// but it is now part of the architecture specification.
	.irp	T, 8b, 16b
	all_8bit_imm_movi_sft v7.\T, 0, 63, LSL, 0
	all_8bit_imm_movi_sft v7.\T, 64, 127, LSL, 0
	all_8bit_imm_movi_sft v7.\T, 128, 191, LSL, 0
	all_8bit_imm_movi_sft v7.\T, 192, 255, LSL, 0
	.endr

	movi	v0.2d, 18446744073709551615
	movi	v0.2d, -1
	movi	v0.2d, bignum
	movi	d31, 18446744073709551615
.set    bignum, 0xffffffffffffffff

	// Allow -128 to 255 in #<imm8>
	movi	v3.8b, -128
	movi	v3.8b, -127
	movi	v3.8b, -1