SHOW:
|
|
- or go back to the newest paste.
| 1 | #define UART_BASE 0x90000000 | |
| 2 | ||
| 3 | #define UART_TX_REG 0x0 | |
| 4 | #define UART_RX_REG 0x0 | |
| 5 | #define UART_INT_ENABLE_REG 0x1 | |
| 6 | #define UART_INT_ID_REG 0x2 | |
| 7 | #define UART_FIFO_CTRL_REG 0x2 | |
| 8 | #define UART_LINE_CTRL_REG 0x3 | |
| 9 | #define UART_MODEM_CTRL_REG 0x4 | |
| 10 | #define UART_LINE_STATUS_REG 0x5 | |
| 11 | ||
| 12 | #define UART_DIV_LSB_REG 0x0 | |
| 13 | #define UART_DIV_MSB_REG 0x1 | |
| 14 | ||
| 15 | #define UART_LSR_THRE 0x20 | |
| 16 | ||
| 17 | boot_init: | |
| 18 | l.movhi r0, 0 | |
| 19 | l.movhi r1, hi(UART_BASE) | |
| 20 | l.ori r2, r0, 0x80 | |
| 21 | l.sb UART_LINE_CTRL_REG(r1), r2 | |
| 22 | l.sb UART_DIV_MSB_REG(r1), r0 | |
| 23 | l.ori r2, r0, 0x1B | |
| 24 | l.sb UART_DIV_LSB_REG(r1), r2 | |
| 25 | l.ori r2, r0, 0x83 | |
| 26 | - | l.sb UART_TX_REG(r1), r3 |
| 26 | + | |
| 27 | l.jal uart_putc | |
| 28 | l.ori r3, r0, '>' | |
| 29 | l.jal uart_putc | |
| 30 | l.ori r3, r0, 'H' | |
| 31 | l.jal uart_putc | |
| 32 | l.ori r3, r0, 'e' | |
| 33 | l.jal uart_putc | |
| 34 | l.ori r3, r0, 'l' | |
| 35 | l.jal uart_putc | |
| 36 | l.ori r3, r0, 'l' | |
| 37 | l.jal uart_putc | |
| 38 | l.ori r3, r0, 'o' | |
| 39 | l.jal uart_putc | |
| 40 | l.ori r3, r0, '!' | |
| 41 | l.j . | |
| 42 | l.nop | |
| 43 | ||
| 44 | uart_putc: | |
| 45 | l.lbz r4, UART_LINE_STATUS_REG(r1) | |
| 46 | l.andi r4, r4, UART_LSR_THRE | |
| 47 | l.sfnei r4, UART_LSR_THRE | |
| 48 | l.bf uart_putc | |
| 49 | l.nop | |
| 50 | l.jr r9 | |
| 51 | l.sb UART_TX_REG(r1), r3 |