forked from Minki/linux
45 lines
982 B
C
45 lines
982 B
C
|
/*
|
||
|
* linux/include/asm-arm/arch-l7200/uncompress.h
|
||
|
*
|
||
|
* Copyright (C) 2000 Steve Hill (sjhill@cotw.com)
|
||
|
*
|
||
|
* Changelog:
|
||
|
* 05-01-2000 SJH Created
|
||
|
* 05-13-2000 SJH Filled in function bodies
|
||
|
* 07-26-2000 SJH Removed hard coded buad rate
|
||
|
*/
|
||
|
|
||
|
#include <asm/hardware.h>
|
||
|
|
||
|
#define IO_UART IO_START + 0x00044000
|
||
|
|
||
|
#define __raw_writeb(v,p) (*(volatile unsigned char *)(p) = (v))
|
||
|
#define __raw_readb(p) (*(volatile unsigned char *)(p))
|
||
|
|
||
|
static __inline__ void putc(char c)
|
||
|
{
|
||
|
while(__raw_readb(IO_UART + 0x18) & 0x20 ||
|
||
|
__raw_readb(IO_UART + 0x18) & 0x08);
|
||
|
__raw_writeb(c, IO_UART + 0x00);
|
||
|
}
|
||
|
|
||
|
static void putstr(const char *s)
|
||
|
{
|
||
|
while (*s) {
|
||
|
if (*s == 10) { /* If a LF, add CR */
|
||
|
putc(10);
|
||
|
putc(13);
|
||
|
}
|
||
|
putc(*(s++));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
static __inline__ void arch_decomp_setup(void)
|
||
|
{
|
||
|
__raw_writeb(0x00, IO_UART + 0x08); /* Set HSB */
|
||
|
__raw_writeb(0x00, IO_UART + 0x20); /* Disable IRQs */
|
||
|
__raw_writeb(0x01, IO_UART + 0x14); /* Enable UART */
|
||
|
}
|
||
|
|
||
|
#define arch_decomp_wdog()
|