Blackfin: add os log functions
Part of the mini Blackfin ABI with operating systems is that they can use 0x4f0-0x4f8 to pass log buffers to/from bootloaders. So add support to U-Boot for reading the log buffer. Signed-off-by: Mike Frysinger <vapier@gentoo.org>
This commit is contained in:
parent
d39041fcad
commit
909878fd3f
@ -17,7 +17,7 @@ EXTRA :=
|
||||
CEXTRA := initcode.o
|
||||
SEXTRA := start.o
|
||||
SOBJS := interrupt.o cache.o
|
||||
COBJS-y := cpu.o traps.o interrupts.o reset.o serial.o watchdog.o
|
||||
COBJS-y := cpu.o traps.o interrupts.o os_log.o reset.o serial.o watchdog.o
|
||||
COBJS-$(CONFIG_JTAG_CONSOLE) += jtag-console.o
|
||||
|
||||
ifeq ($(CONFIG_BFIN_BOOT_MODE),BFIN_BOOT_BYPASS)
|
||||
|
30
cpu/blackfin/os_log.c
Normal file
30
cpu/blackfin/os_log.c
Normal file
@ -0,0 +1,30 @@
|
||||
/*
|
||||
* functions for handling OS log buffer
|
||||
*
|
||||
* Copyright (c) 2009 Analog Devices Inc.
|
||||
*
|
||||
* Licensed under the 2-clause BSD.
|
||||
*/
|
||||
|
||||
#include <common.h>
|
||||
|
||||
#define OS_LOG_MAGIC 0xDEADBEEF
|
||||
#define OS_LOG_MAGIC_ADDR ((unsigned long *)0x4f0)
|
||||
#define OS_LOG_PTR_ADDR ((char **)0x4f4)
|
||||
|
||||
bool bfin_os_log_check(void)
|
||||
{
|
||||
if (*OS_LOG_MAGIC_ADDR != OS_LOG_MAGIC)
|
||||
return false;
|
||||
*OS_LOG_MAGIC_ADDR = 0;
|
||||
return true;
|
||||
}
|
||||
|
||||
void bfin_os_log_dump(void)
|
||||
{
|
||||
char *log = *OS_LOG_PTR_ADDR;
|
||||
while (*log) {
|
||||
puts(log);
|
||||
log += strlen(log) + 1;
|
||||
}
|
||||
}
|
@ -61,6 +61,9 @@ extern u_long get_sclk(void);
|
||||
|
||||
# define bfin_revid() (*pCHIPID >> 28)
|
||||
|
||||
extern bool bfin_os_log_check(void);
|
||||
extern void bfin_os_log_dump(void);
|
||||
|
||||
extern void blackfin_icache_flush_range(const void *, const void *);
|
||||
extern void blackfin_dcache_flush_range(const void *, const void *);
|
||||
extern void blackfin_icache_dcache_flush_range(const void *, const void *);
|
||||
|
@ -384,6 +384,12 @@ void board_init_r(gd_t * id, ulong dest_addr)
|
||||
post_run(NULL, POST_RAM | post_bootmode_get(0));
|
||||
#endif
|
||||
|
||||
if (bfin_os_log_check()) {
|
||||
puts("\nLog buffer from operating system:\n");
|
||||
bfin_os_log_dump();
|
||||
puts("\n");
|
||||
}
|
||||
|
||||
/* main_loop() can return to retry autoboot, if so just run it again. */
|
||||
for (;;)
|
||||
main_loop();
|
||||
|
Loading…
Reference in New Issue
Block a user