Linux Audio

Check our new training course

Loading...
Note: File does not exist in v3.1.
  1/* SPDX-License-Identifier: GPL-2.0-or-later */
  2/*
  3 * Macro used to simplify coding multi-line assembler.
  4 * Some of the bit test macro can simplify down to one line
  5 * depending on the mask value.
  6 *
  7 * Copyright (C) 2004 Microtronix Datacom Ltd.
  8 *
  9 * All rights reserved.
 10 */
 11#ifndef _ASM_NIOS2_ASMMACROS_H
 12#define _ASM_NIOS2_ASMMACROS_H
 13/*
 14 * ANDs reg2 with mask and places the result in reg1.
 15 *
 16 * You cannnot use the same register for reg1 & reg2.
 17 */
 18
 19.macro ANDI32	reg1, reg2, mask
 20.if \mask & 0xffff
 21	.if \mask & 0xffff0000
 22		movhi	\reg1, %hi(\mask)
 23		movui	\reg1, %lo(\mask)
 24		and	\reg1, \reg1, \reg2
 25	.else
 26		andi	\reg1, \reg2, %lo(\mask)
 27	.endif
 28.else
 29	andhi	\reg1, \reg2, %hi(\mask)
 30.endif
 31.endm
 32
 33/*
 34 * ORs reg2 with mask and places the result in reg1.
 35 *
 36 * It is safe to use the same register for reg1 & reg2.
 37 */
 38
 39.macro ORI32	reg1, reg2, mask
 40.if \mask & 0xffff
 41	.if \mask & 0xffff0000
 42		orhi	\reg1, \reg2, %hi(\mask)
 43		ori	\reg1, \reg2, %lo(\mask)
 44	.else
 45		ori	\reg1, \reg2, %lo(\mask)
 46	.endif
 47.else
 48	orhi	\reg1, \reg2, %hi(\mask)
 49.endif
 50.endm
 51
 52/*
 53 * XORs reg2 with mask and places the result in reg1.
 54 *
 55 * It is safe to use the same register for reg1 & reg2.
 56 */
 57
 58.macro XORI32	reg1, reg2, mask
 59.if \mask & 0xffff
 60	.if \mask & 0xffff0000
 61		xorhi	\reg1, \reg2, %hi(\mask)
 62		xori	\reg1, \reg1, %lo(\mask)
 63	.else
 64		xori	\reg1, \reg2, %lo(\mask)
 65	.endif
 66.else
 67	xorhi	\reg1, \reg2, %hi(\mask)
 68.endif
 69.endm
 70
 71/*
 72 * This is a support macro for BTBZ & BTBNZ.  It checks
 73 * the bit to make sure it is valid 32 value.
 74 *
 75 * It is safe to use the same register for reg1 & reg2.
 76 */
 77
 78.macro BT	reg1, reg2, bit
 79.if \bit > 31
 80	.err
 81.else
 82	.if \bit < 16
 83		andi	\reg1, \reg2, (1 << \bit)
 84	.else
 85		andhi	\reg1, \reg2, (1 << (\bit - 16))
 86	.endif
 87.endif
 88.endm
 89
 90/*
 91 * Tests the bit in reg2 and branches to label if the
 92 * bit is zero.  The result of the bit test is stored in reg1.
 93 *
 94 * It is safe to use the same register for reg1 & reg2.
 95 */
 96
 97.macro BTBZ	reg1, reg2, bit, label
 98	BT	\reg1, \reg2, \bit
 99	beq	\reg1, r0, \label
100.endm
101
102/*
103 * Tests the bit in reg2 and branches to label if the
104 * bit is non-zero.  The result of the bit test is stored in reg1.
105 *
106 * It is safe to use the same register for reg1 & reg2.
107 */
108
109.macro BTBNZ	reg1, reg2, bit, label
110	BT	\reg1, \reg2, \bit
111	bne	\reg1, r0, \label
112.endm
113
114/*
115 * Tests the bit in reg2 and then compliments the bit in reg2.
116 * The result of the bit test is stored in reg1.
117 *
118 * It is NOT safe to use the same register for reg1 & reg2.
119 */
120
121.macro BTC	reg1, reg2, bit
122.if \bit > 31
123	.err
124.else
125	.if \bit < 16
126		andi	\reg1, \reg2, (1 << \bit)
127		xori	\reg2, \reg2, (1 << \bit)
128	.else
129		andhi	\reg1, \reg2, (1 << (\bit - 16))
130		xorhi	\reg2, \reg2, (1 << (\bit - 16))
131	.endif
132.endif
133.endm
134
135/*
136 * Tests the bit in reg2 and then sets the bit in reg2.
137 * The result of the bit test is stored in reg1.
138 *
139 * It is NOT safe to use the same register for reg1 & reg2.
140 */
141
142.macro BTS	reg1, reg2, bit
143.if \bit > 31
144	.err
145.else
146	.if \bit < 16
147		andi	\reg1, \reg2, (1 << \bit)
148		ori	\reg2, \reg2, (1 << \bit)
149	.else
150		andhi	\reg1, \reg2, (1 << (\bit - 16))
151		orhi	\reg2, \reg2, (1 << (\bit - 16))
152	.endif
153.endif
154.endm
155
156/*
157 * Tests the bit in reg2 and then resets the bit in reg2.
158 * The result of the bit test is stored in reg1.
159 *
160 * It is NOT safe to use the same register for reg1 & reg2.
161 */
162
163.macro BTR	reg1, reg2, bit
164.if \bit > 31
165	.err
166.else
167	.if \bit < 16
168		andi	\reg1, \reg2, (1 << \bit)
169		andi	\reg2, \reg2, %lo(~(1 << \bit))
170	.else
171		andhi	\reg1, \reg2, (1 << (\bit - 16))
172		andhi	\reg2, \reg2, %lo(~(1 << (\bit - 16)))
173	.endif
174.endif
175.endm
176
177/*
178 * Tests the bit in reg2 and then compliments the bit in reg2.
179 * The result of the bit test is stored in reg1.  If the
180 * original bit was zero it branches to label.
181 *
182 * It is NOT safe to use the same register for reg1 & reg2.
183 */
184
185.macro BTCBZ	reg1, reg2, bit, label
186	BTC	\reg1, \reg2, \bit
187	beq	\reg1, r0, \label
188.endm
189
190/*
191 * Tests the bit in reg2 and then compliments the bit in reg2.
192 * The result of the bit test is stored in reg1.  If the
193 * original bit was non-zero it branches to label.
194 *
195 * It is NOT safe to use the same register for reg1 & reg2.
196 */
197
198.macro BTCBNZ	reg1, reg2, bit, label
199	BTC	\reg1, \reg2, \bit
200	bne	\reg1, r0, \label
201.endm
202
203/*
204 * Tests the bit in reg2 and then sets the bit in reg2.
205 * The result of the bit test is stored in reg1.  If the
206 * original bit was zero it branches to label.
207 *
208 * It is NOT safe to use the same register for reg1 & reg2.
209 */
210
211.macro BTSBZ	reg1, reg2, bit, label
212	BTS	\reg1, \reg2, \bit
213	beq	\reg1, r0, \label
214.endm
215
216/*
217 * Tests the bit in reg2 and then sets the bit in reg2.
218 * The result of the bit test is stored in reg1.  If the
219 * original bit was non-zero it branches to label.
220 *
221 * It is NOT safe to use the same register for reg1 & reg2.
222 */
223
224.macro BTSBNZ	reg1, reg2, bit, label
225	BTS	\reg1, \reg2, \bit
226	bne	\reg1, r0, \label
227.endm
228
229/*
230 * Tests the bit in reg2 and then resets the bit in reg2.
231 * The result of the bit test is stored in reg1.  If the
232 * original bit was zero it branches to label.
233 *
234 * It is NOT safe to use the same register for reg1 & reg2.
235 */
236
237.macro BTRBZ	reg1, reg2, bit, label
238	BTR	\reg1, \reg2, \bit
239	bne	\reg1, r0, \label
240.endm
241
242/*
243 * Tests the bit in reg2 and then resets the bit in reg2.
244 * The result of the bit test is stored in reg1.  If the
245 * original bit was non-zero it branches to label.
246 *
247 * It is NOT safe to use the same register for reg1 & reg2.
248 */
249
250.macro BTRBNZ	reg1, reg2, bit, label
251	BTR	\reg1, \reg2, \bit
252	bne	\reg1, r0, \label
253.endm
254
255/*
256 * Tests the bits in mask against reg2 stores the result in reg1.
257 * If the all the bits in the mask are zero it branches to label.
258 *
259 * It is safe to use the same register for reg1 & reg2.
260 */
261
262.macro TSTBZ	reg1, reg2, mask, label
263	ANDI32	\reg1, \reg2, \mask
264	beq	\reg1, r0, \label
265.endm
266
267/*
268 * Tests the bits in mask against reg2 stores the result in reg1.
269 * If the any of the bits in the mask are 1 it branches to label.
270 *
271 * It is safe to use the same register for reg1 & reg2.
272 */
273
274.macro TSTBNZ	reg1, reg2, mask, label
275	ANDI32	\reg1, \reg2, \mask
276	bne	\reg1, r0, \label
277.endm
278
279/*
280 * Pushes reg onto the stack.
281 */
282
283.macro PUSH	reg
284	addi	sp, sp, -4
285	stw	\reg, 0(sp)
286.endm
287
288/*
289 * Pops the top of the stack into reg.
290 */
291
292.macro POP	reg
293	ldw	\reg, 0(sp)
294	addi	sp, sp, 4
295.endm
296
297
298#endif /* _ASM_NIOS2_ASMMACROS_H */