xref: /rk3399_rockchip-uboot/arch/sh/include/asm/macro.h (revision 326ea986ac150acdc7656d57fca647db80b50158)
1819833afSPeter Tyser /*
2819833afSPeter Tyser  * Copyright (C) 2008 Yoshihiro Shimoda <shimoda.yoshihiro@renesas.com>
3819833afSPeter Tyser  *
4*1a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
5819833afSPeter Tyser  */
6819833afSPeter Tyser 
7819833afSPeter Tyser #ifndef __MACRO_H__
8819833afSPeter Tyser #define __MACRO_H__
9819833afSPeter Tyser #ifdef __ASSEMBLY__
10819833afSPeter Tyser 
11819833afSPeter Tyser .macro	write32, addr, data
12819833afSPeter Tyser 	mov.l \addr ,r1
13819833afSPeter Tyser 	mov.l \data ,r0
14819833afSPeter Tyser 	mov.l r0, @r1
15819833afSPeter Tyser .endm
16819833afSPeter Tyser 
17819833afSPeter Tyser .macro	write16, addr, data
18819833afSPeter Tyser 	mov.l \addr ,r1
19819833afSPeter Tyser 	mov.w \data ,r0
20819833afSPeter Tyser 	mov.w r0, @r1
21819833afSPeter Tyser .endm
22819833afSPeter Tyser 
23819833afSPeter Tyser .macro	write8, addr, data
24819833afSPeter Tyser 	mov.l \addr ,r1
25819833afSPeter Tyser 	mov.l \data ,r0
26819833afSPeter Tyser 	mov.b r0, @r1
27819833afSPeter Tyser .endm
28819833afSPeter Tyser 
29819833afSPeter Tyser .macro	wait_timer, time
30819833afSPeter Tyser 	mov.l	\time ,r3
31819833afSPeter Tyser 1:
32819833afSPeter Tyser 	nop
33819833afSPeter Tyser 	tst	r3, r3
34819833afSPeter Tyser 	bf/s	1b
35819833afSPeter Tyser 	dt	r3
36819833afSPeter Tyser .endm
37819833afSPeter Tyser 
38819833afSPeter Tyser #endif /* __ASSEMBLY__ */
39819833afSPeter Tyser #endif /* __MACRO_H__ */
40