The unified diff between revisions [0b05faeb..] and [0b1d8473..] is displayed below. It can also be downloaded as a raw diff.
# # old_revision [0b05faeb3c5c6294511a5c77018c9c2a6f644535] # new_revision [0b1d8473609f29aa4a19839761537a746e7d641d] # # patch "main.c" # from [0320b79369f77b68526dd563a325920b95e16d18] # to [fb017164ff6afc1976107459118fb6bca950ac3f] # ============================================================ --- main.c 0320b79369f77b68526dd563a325920b95e16d18 +++ main.c fb017164ff6afc1976107459118fb6bca950ac3f @@ -1,11 +1,43 @@ -#define U0THR (*((volatile unsigned char *) 0xE000C000)) /* UART0 transmitter holding register */ -#define U0LSR (*((volatile unsigned char *) 0xE000C014)) /* UART0 line status register */ -#define U0THRE ((U0LSR & (1<<5))) /* UART0 transmitter holding register is empty */ +#define UARTBASE 0xE000C000 +#define RBR 0x00 +#define THR 0x00 +#define DLL 0x00 +#define DLM 0x04 +#define IER 0x04 +#define IIR 0x08 +#define FCR 0x08 + +#define LCR 0x0c +#define LSR 0x14 +#define SCR 0x1c +#define ACR 0x20 +#define FDR 0x28 +#define TER 0x30 + +#define REG(x) (((volatile unsigned char *)UARTBASE)[x]) + +#define U0THRE ((REG(LSR) & (1<<5))) /* UART0 transmitter holding register is empty */ + +#define PINSEL0 (*((volatile unsigned char *) 0xE002C000)) + +void init_uart(void) +{ + REG(FDR) = 0x10; /* DivAddVal = 0, MulVal = 1 */ + + REG(LCR) = 0x80; + REG(DLM) = 0x00; + REG(DLL) = 0x08; /* 14745600 / (16*115200) */ + REG(LCR) = 0x13; + REG(FCR) = 0x07; + + PINSEL0 = 0x00000005; /* P0.0 and P0.1 assigned to UART */ +} + void putch(char c) { while (!U0THRE); - U0THR = c; + REG(THR) = c; } void putstr(char *s) { @@ -13,6 +45,7 @@ int main(void) { } int main(void) { + init_uart(); putstr("Your entire life has been a mathematical error... a mathematical error I'm about to correct!\n"); return 0; }