34 lines
		
	
	
	
		
			748 B
			
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
		
		
			
		
	
	
			34 lines
		
	
	
	
		
			748 B
			
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * Broadcom BCM63xx low-level UART debug
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Copyright (C) 2014 Broadcom Corporation
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * This program is free software; you can redistribute it and/or modify
							 | 
						||
| 
								 | 
							
								 * it under the terms of the GNU General Public License version 2 as
							 | 
						||
| 
								 | 
							
								 * published by the Free Software Foundation.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <linux/serial_bcm63xx.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									.macro	addruart, rp, rv, tmp
							 | 
						||
| 
								 | 
							
									ldr	\rp, =CONFIG_DEBUG_UART_PHYS
							 | 
						||
| 
								 | 
							
									ldr	\rv, =CONFIG_DEBUG_UART_VIRT
							 | 
						||
| 
								 | 
							
									.endm
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									.macro	senduart, rd, rx
							 | 
						||
| 
								 | 
							
									/* word access do not work */
							 | 
						||
| 
								 | 
							
									strb	\rd, [\rx, #UART_FIFO_REG]
							 | 
						||
| 
								 | 
							
									.endm
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									.macro	waituart, rd, rx
							 | 
						||
| 
								 | 
							
								1001:	ldr	\rd, [\rx, #UART_IR_REG]
							 | 
						||
| 
								 | 
							
									tst	\rd, #(1 << UART_IR_TXEMPTY)
							 | 
						||
| 
								 | 
							
									beq	1001b
							 | 
						||
| 
								 | 
							
									.endm
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
									.macro	busyuart, rd, rx
							 | 
						||
| 
								 | 
							
								1002:	ldr	\rd, [\rx, #UART_IR_REG]
							 | 
						||
| 
								 | 
							
									tst	\rd, #(1 << UART_IR_TXTRESH)
							 | 
						||
| 
								 | 
							
									beq	1002b
							 | 
						||
| 
								 | 
							
									.endm
							 |