[U-Boot] Endless loop in cmd_log.c?
Peter Tyser
ptyser at xes-inc.com
Fri May 7 01:27:27 CEST 2010
Hi Dennis,
On Wed, 2010-05-05 at 12:22 -0700, Dennis Ruffer wrote:
> I am trying to implement CONFIG_LOGBUFFER and CONFIG_CMD_LOG on our ARM
> systems and I seem to have run into an endless loop. With loglevel=5 so we
> still see our console output, the printf at the end of logbuff_printk
> appears to create an endless loop.
>
> I had to replace that line with serial_puts(msg);
>
> Have I missed some other solution or do the systems that use this never set
> logbuffer higher than default_message_loglevel?
I see the same issue you describe when enabling CONFIG_LOGBUFFER. It
looks like only a few boards have CONFIG_LOGBUFFER enabled, and many of
them also have CONFIG_SYS_CONSOLE_IS_IN_ENV defined. When
CONFIG_SYS_CONSOLE_IS_IN_ENV is defined I believe the behavior is
changed so that the the stdout/stderr/stdin values are read from the
environment, with a default fallback of 'serial'.
My guess is most of the boards with CONFIG_LOGBUFFER defined have their
'stdout' value set to 'serial', so they don't actually utilize the
logbuffer, and thus don't run into the issue you found.
In any case, I think its a bug and your suggested workaround sounds good
to me. Have any interest in submitting a patch to fix it?
Best,
Peter
More information about the U-Boot
mailing list