On Sun, Mar 10, 2013 at 2:16 PM, Jean-Christophe PLAGNIOL-VILLARD <plagnioj@xxxxxxxxxxxx> wrote: > On 00:19 Sun 10 Mar , Vicente Bergas wrote: >> some sort of UART setup has to be done in order to use PUTC_LL >> >> Signed-off-by: Vicente Bergas <vicencb@xxxxxxxxx> >> --- >> arch/arm/mach-omap/include/mach/debug_ll.h | 21 +++++++++++++++++++++ >> 1 file changed, 21 insertions(+) >> >> diff --git a/arch/arm/mach-omap/include/mach/debug_ll.h b/arch/arm/mach-omap/include/mach/debug_ll.h >> index eea6eb3..9740848 100644 >> --- a/arch/arm/mach-omap/include/mach/debug_ll.h >> +++ b/arch/arm/mach-omap/include/mach/debug_ll.h >> @@ -45,9 +45,30 @@ >> #endif >> >> #define LSR_THRE 0x20 /* Xmit holding register empty */ >> +#define LCR_BKSE 0x80 /* Bank select enable */ >> #define LSR (5 << 2) >> #define THR (0 << 2) >> +#define DLL (0 << 2) >> +#define IER (1 << 2) >> +#define DLM (1 << 2) >> +#define FCR (2 << 2) >> +#define LCR (3 << 2) >> +#define MCR (4 << 2) >> +#define MDR (8 << 2) >> >> +static inline void INIT_LL(void) > where this come from? This comes from drivers/serial/serial_ns16550.c: ns16550_serial_init_port ns16550_serial_init_port call other functions and has local variables, so a stack is required INIT_LL instead is an extremly simple inline function without local variables, so it can be called at the very beginning from include/debug_ll.h: "Note that several SoCs expect the UART to be initialized by a debugger or a first stage bootloader." INIT_LL implements the second option. I have a question regarding code executed at the very beginning, that is, when the stack may not be available or the binary is not at it's link address What are the things that can't be done in such scenario? For example, from include/debug_ll.h: "Be careful with PUTS_LL, it only works if the binary is running at the link address which often is not the case during early startup." static __inline__ void PUTS_LL(const char * str) { while (*str) { if (*str == '\n') { PUTC_LL('\r'); } PUTC_LL(*str); str++; } } What does PUTS_LL do that can't be done? >> +{ >> + writeb(0x00, UART_BASE + LCR); >> + writeb(0x00, UART_BASE + IER); >> + writeb(0x07, UART_BASE + MDR); >> + writeb(LCR_BKSE, UART_BASE + LCR); >> + writeb(26, UART_BASE + DLL); /* 115200 */ >> + writeb(0, UART_BASE + DLM); >> + writeb(0x03, UART_BASE + LCR); >> + writeb(0x03, UART_BASE + MCR); >> + writeb(0x07, UART_BASE + FCR); >> + writeb(0x00, UART_BASE + MDR); >> +} >> static inline void PUTC_LL(char c) >> { >> /* Wait until there is space in the FIFO */ >> -- >> 1.8.1.5 >> >> >> _______________________________________________ >> barebox mailing list >> barebox@xxxxxxxxxxxxxxxxxxx >> http://lists.infradead.org/mailman/listinfo/barebox _______________________________________________ barebox mailing list barebox@xxxxxxxxxxxxxxxxxxx http://lists.infradead.org/mailman/listinfo/barebox