When syslog message has addition characters after last new-line. With buffering those now get lost as vsyslog does not flush output after lib_sprintf. Additional trailing characters could be ANSI escape sequence to reset state that message setups. For example, macro here uses colors and resets state after actual message (including '\n'):

With flushing added to vsyslog, then there is problem that next syslog line might come from other task before reset sequence, causing wrong line getting color. This could be avoided by not flushing on '\n' but only if IOB is full and/or at end of vsyslog. Would this make sense?
This commit is contained in:
Jussi Kivilinna 2017-05-11 07:11:35 -06:00 committed by Gregory Nutt
parent 3091050963
commit ba933efd9e
2 changed files with 6 additions and 2 deletions

View File

@ -82,9 +82,9 @@ static void syslogstream_putc(FAR struct lib_outstream_s *this, int ch)
iob->io_len++; iob->io_len++;
this->nput++; this->nput++;
/* Is the buffer full? Did we encounter a new line? */ /* Is the buffer full? */
if (iob->io_len >= CONFIG_IOB_BUFSIZE || ch == '\n') if (iob->io_len >= CONFIG_IOB_BUFSIZE)
{ {
/* Yes.. then flush the buffer */ /* Yes.. then flush the buffer */

View File

@ -130,6 +130,10 @@ int _vsyslog(int priority, FAR const IPTR char *fmt, FAR va_list *ap)
ret = lib_vsprintf(&stream.public, fmt, *ap); ret = lib_vsprintf(&stream.public, fmt, *ap);
/* Flush the output */
stream.public.flush(&stream.public);
#ifdef CONFIG_SYSLOG_BUFFER #ifdef CONFIG_SYSLOG_BUFFER
/* Destroy the syslog stream buffer */ /* Destroy the syslog stream buffer */