| |
| |
| #define READ_UINT8( _register_, _value_ ) \ |
| ((_value_) = *((volatile unsigned char *)(_register_))) |
| |
| #define WRITE_UINT8( _register_, _value_ ) \ |
| (*((volatile unsigned char *)(_register_)) = (_value_)) |
| |
| /* - Board specific addresses for serial chip */ |
| #define DIAG_BASE 0xfffff300 |
| #define DIAG_SLCR (DIAG_BASE+0x00) |
| #define DIAG_SLSR (DIAG_BASE+0x04) |
| #define DIAG_SLDICR (DIAG_BASE+0x08) |
| #define DIAG_SLDISR (DIAG_BASE+0x0C) |
| #define DIAG_SFCR (DIAG_BASE+0x10) |
| #define DIAG_SBRG (DIAG_BASE+0x14) |
| #define DIAG_TFIFO (DIAG_BASE+0x20) |
| #define DIAG_RFIFO (DIAG_BASE+0x30) |
| |
| #define BRG_T0 0x0000 |
| #define BRG_T2 0x0100 |
| #define BRG_T4 0x0200 |
| #define BRG_T5 0x0300 |
| |
| |
| #define READ_UINT16( _register_, _value_ ) \ |
| ((_value_) = *((volatile unsigned short *)(_register_))) |
| |
| #define WRITE_UINT16( _register_, _value_ ) \ |
| (*((volatile unsigned short *)(_register_)) = (_value_)) |
| |
| unsigned char |
| inbyte (void) |
| { |
| unsigned char c; |
| unsigned short disr; |
| |
| for (;;) |
| { |
| READ_UINT16 (DIAG_SLDISR, disr); |
| if (disr & 0x0001) |
| break; |
| } |
| disr = disr & ~0x0001; |
| READ_UINT8 (DIAG_RFIFO, c); |
| WRITE_UINT16 (DIAG_SLDISR, disr); |
| return c; |
| } |
| |
| void |
| outbyte (unsigned char c) |
| { |
| unsigned short disr; |
| |
| for (;;) |
| { |
| READ_UINT16 (DIAG_SLDISR, disr); |
| if (disr & 0x0002) |
| break; |
| } |
| disr = disr & ~0x0002; |
| WRITE_UINT8 (DIAG_TFIFO, c); |
| WRITE_UINT16 (DIAG_SLDISR, disr); |
| } |
| |
| /* Stuff required to setup IO on this board */ |
| void board_serial_init (void) |
| { |
| WRITE_UINT16 (DIAG_SLCR, 0x0020); |
| WRITE_UINT16 (DIAG_SLDICR, 0x0000); |
| WRITE_UINT16 (DIAG_SFCR, 0x0000); |
| WRITE_UINT16 (DIAG_SBRG, BRG_T2 | 5); |
| } |
| |
| /* If you want this to be initialized as part of the stuff which gets called |
| by crt0, it should be named 'hardware_init_hook'. |
| Local implementations may want to move or add to this function OR |
| do the initializations after main() is entered. |
| */ |
| void hardware_init_hook(void) |
| { |
| board_serial_init() ; |
| } |
| |
| /* Structure filled in by get_mem_info. Only the size field is |
| actually used (by sbrk), so the others aren't even filled in. */ |
| |
| struct s_mem |
| { |
| unsigned int size; |
| unsigned int icsize; |
| unsigned int dcsize; |
| }; |
| |
| /* mem_size is provided in the linker script so that we don't have to |
| define it here. */ |
| extern char _mem_size[]; |
| |
| void |
| get_mem_info (mem) |
| struct s_mem *mem; |
| { |
| mem->size = (unsigned int)_mem_size; |
| } |