/* * 16550 compatible uart based serial debug support for zboot */ #include #include #include #include #if defined(CONFIG_MACH_LOONGSON) || defined(CONFIG_MIPS_MALTA) #define UART_BASE 0x1fd003f8 #define PORT(offset) (CKSEG1ADDR(UART_BASE) + (offset)) #endif #ifdef CONFIG_AR7 #include #define PORT(offset) (CKSEG1ADDR(AR7_REGS_UART0) + (4 * offset)) #endif #ifndef PORT #error please define the serial port address for your own machine #endif static inline unsigned int serial_in(int offset) { return *((char *)PORT(offset)); } static inline void serial_out(int offset, int value) { *((char *)PORT(offset)) = value; } void putc(char c) { #if 0 int timeout = 1024; while (((serial_in(UART_LSR) & UART_LSR_THRE) == 0) && (timeout-- > 0)) ; serial_out(UART_TX, c); #else unsigned int timeout = 1000; unsigned char *lsr = (unsigned char *)(0xbf004080 + 0x5); unsigned char status; char *sdata = (unsigned char *)0xbf004080; while (timeout--) { status = *lsr; if (status & 0x20) break; }; if (timeout) //successful *sdata = c; #endif }