121 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			121 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /* op50n-io.S -- low-level I/O routines for the Oki OP50N eval board.
 | |
|  *
 | |
|  * Copyright (c) 1995 Cygnus Support
 | |
|  *
 | |
|  * The authors hereby grant permission to use, copy, modify, distribute,
 | |
|  * and license this software and its documentation for any purpose, provided
 | |
|  * that existing copyright notices are retained in all copies and that this
 | |
|  * notice is included verbatim in any distributions. No written agreement,
 | |
|  * license, or royalty fee is required for any of the authorized uses.
 | |
|  * Modifications to this software may be copyrighted by their authors
 | |
|  * and need not follow the licensing terms described here, provided that
 | |
|  * the new terms are clearly indicated on the first page of each file where
 | |
|  * they apply.
 | |
|  */
 | |
| 
 | |
| mon_start       .EQU    0xd0000000
 | |
| where_dp        .EQU    mon_start+4*4
 | |
| where_ci        .EQU    mon_start+14*4
 | |
| where_co        .EQU    mon_start+15*4
 | |
| where_read	.EQU	mon_start+22*4
 | |
| where_write	.EQU	mon_start+23*4
 | |
| 
 | |
| /* 
 | |
|  *int c = inbyte(wait);
 | |
|  */
 | |
| 	.space $TEXT$
 | |
| 	.align 4
 | |
|         .EXPORT inbyte,CODE,ARGW0=GR,RTNVAL=GR
 | |
| inbyte
 | |
| 	.PROC
 | |
| 	.CALLINFO CALLER,FRAME=64,SAVE_RP
 | |
| 	.ENTRY
 | |
|         stw     %r2,-20(0,%r30)
 | |
|         ldo     64(%r30),%r30
 | |
|         stw     %r27,-56(0,%r30) 	; save my dp
 | |
|  	ldil    l%where_dp,%r27    	; load monitors dp
 | |
| 	ldw	r%where_dp(0,%r27),%r27
 | |
| 	ldil	l%where_ci,%r1
 | |
| 	ldw	r%where_ci(0,%r1),%r1
 | |
|         ble     0(0,%r1)
 | |
|         copy    %r31,%r2
 | |
|         ldw     -56(0,%r30),%r27 	; load my dp
 | |
|         ldw     -84(0,%r30),%r2
 | |
|         ldo     -64(%r30),%r30
 | |
|         bv      %r0(%r2)
 | |
| 	nop
 | |
|         .EXIT
 | |
|         .PROCEND
 | |
|  
 | |
| /* int c = outbyte(c);
 | |
| */
 | |
|         .EXPORT outbyte,CODE,ARGW0=GR,RTNVAL=GR
 | |
| outbyte
 | |
|         .PROC
 | |
|         .CALLINFO CALLER,FRAME=64,SAVE_RP
 | |
|         .ENTRY
 | |
|         stw     %r2,-20(0,%r30)
 | |
|         ldo     64(%r30),%r30
 | |
|         stw     %r27,-56(0,%r30) 	; save my dp
 | |
|  	ldil    l%where_dp,%r27    	; load monitors dp
 | |
| 	ldw	r%where_dp(0,%r27),%r27
 | |
| 	ldil	l%where_co,%r1
 | |
| 	ldw	r%where_co(0,%r1),%r1
 | |
|         ble     0(0,%r1)
 | |
|         copy    %r31,%r2
 | |
|         ldw     -56(0,%r30),%r27 	; load my dp
 | |
|         ldw     -84(0,%r30),%r2
 | |
|         ldo     -64(%r30),%r30
 | |
|         bv      %r0(%r2)
 | |
| 	nop
 | |
|         .EXIT
 | |
|         .PROCEND
 | |
| 
 | |
| #if 0
 | |
| /* cnt = read(fd, bufp, cnt);
 | |
| */
 | |
| 	.EXPORT	read,CODE,ARGW0=NO,ARGW1=NO,ARGW2=NO,ARGW3=NO,RTNVAL=NO
 | |
| read
 | |
| 	.PROC
 | |
| 	.CALLINFO FRAME=64,CALLS,SAVE_RP
 | |
| 	.ENTRY
 | |
| 	stw	%r2,-20(0,%r30)
 | |
| 	ldo	64(%r30),%r30
 | |
| 	stw	%dp,-56(0,%r30)	; save my dp
 | |
| 	ldil	l%where_dp,%dp	; load monitors dp
 | |
| 	ldw	r%where_dp(0,%dp), %dp
 | |
| 	ldil	l%where_read,%r1
 | |
| 	ldw	r%where_read(0,%r1), %r1
 | |
| 	ble	0(0,%r1)
 | |
| 	copy	%r31,%r2
 | |
| 	ldw	-56(0,%r30),%dp	; load my dp
 | |
| 	ldw	-84(0,%r30),%r2
 | |
| 	bv	%r0(%r2)
 | |
| 	ldo	-64(%r30),%r30
 | |
| 	.EXIT
 | |
| 	.PROCEND
 | |
| 
 | |
| /* cnt = write(fd, bufp, cnt);
 | |
| */
 | |
| 	.EXPORT	write,CODE,ARGW0=NO,ARGW1=NO,ARGW2=NO,ARGW3=NO,RTNVAL=NO
 | |
| write
 | |
| 	.PROC
 | |
| 	.CALLINFO FRAME=64,CALLS,SAVE_RP
 | |
| 	.ENTRY
 | |
| 	stw	%r2,-20(0,%r30)
 | |
| 	ldo	64(%r30),%r30
 | |
| 	stw	%dp,-56(0,%r30)	; save my dp
 | |
| 	ldil	l%where_dp,%dp	; load monitors dp
 | |
| 	ldw	r%where_dp(0,%dp), %dp
 | |
| 	ldil	l%where_write,%r1
 | |
| 	ldw	r%where_write(0,%r1), %r1
 | |
| 	ble	0(0,%r1)
 | |
| 	copy	%r31,%r2
 | |
| 	ldw	-56(0,%r30),%dp	; load my dp
 | |
| 	ldw	-84(0,%r30),%r2
 | |
| 	bv	%r0(%r2)
 | |
| 	ldo	-64(%r30),%r30
 | |
| 	.EXIT
 | |
| 	.PROCEND
 | |
| #endif
 |