74 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __ROMIMAGE_MACRO_H
 | |
| #define __ROMIMAGE_MACRO_H
 | |
| 
 | |
| /* The LIST command is used to include comments in the script */
 | |
| .macro	LIST comment
 | |
| .endm
 | |
| 
 | |
| /* The ED command is used to write a 32-bit word */
 | |
| .macro  ED, addr, data
 | |
| 	mov.l 1f, r1
 | |
| 	mov.l 2f, r0
 | |
| 	mov.l r0, @r1
 | |
| 	bra 3f
 | |
| 	 nop
 | |
| 	.align 2
 | |
| 1 :	.long \addr
 | |
| 2 :	.long \data
 | |
| 3 :
 | |
| .endm
 | |
| 
 | |
| /* The EW command is used to write a 16-bit word */
 | |
| .macro  EW, addr, data
 | |
| 	mov.l 1f, r1
 | |
| 	mov.l 2f, r0
 | |
| 	mov.w r0, @r1
 | |
| 	bra 3f
 | |
| 	 nop
 | |
| 	.align 2
 | |
| 1 :	.long \addr
 | |
| 2 :	.long \data
 | |
| 3 :
 | |
| .endm
 | |
| 
 | |
| /* The EB command is used to write an 8-bit word */
 | |
| .macro  EB, addr, data
 | |
| 	mov.l 1f, r1
 | |
| 	mov.l 2f, r0
 | |
| 	mov.b r0, @r1
 | |
| 	bra 3f
 | |
| 	 nop
 | |
| 	.align 2
 | |
| 1 :	.long \addr
 | |
| 2 :	.long \data
 | |
| 3 :
 | |
| .endm
 | |
| 
 | |
| /* The WAIT command is used to delay the execution */
 | |
| .macro  WAIT, time
 | |
| 	mov.l  2f, r3
 | |
| 1 :
 | |
| 	nop
 | |
| 	tst     r3, r3
 | |
| 	bf/s    1b
 | |
| 	dt      r3
 | |
| 	bra	3f
 | |
| 	 nop
 | |
| 	.align 2
 | |
| 2 :	.long \time * 100
 | |
| 3 :
 | |
| .endm
 | |
| 
 | |
| /* The DD command is used to read a 32-bit word */
 | |
| .macro  DD, addr, addr2, nr
 | |
| 	mov.l 1f, r1
 | |
| 	mov.l @r1, r0
 | |
| 	bra 2f
 | |
| 	 nop
 | |
| 	.align 2
 | |
| 1 :	.long \addr
 | |
| 2 :
 | |
| .endm
 | |
| 
 | |
| #endif /* __ROMIMAGE_MACRO_H */
 |