From: "Daniel P. Berrangé" <berrange@redhat.com>
To: Richard Henderson <richard.henderson@linaro.org>
Cc: qemu-devel@nongnu.org
Subject: Re: [PATCH v4 09/23] util: introduce some API docs for logging APIs
Date: Fri, 26 Sep 2025 15:31:37 +0100 [thread overview]
Message-ID: <aNajyYZ0A33OgjFD@redhat.com> (raw)
In-Reply-To: <a27a8ca5-ad86-44a5-8849-e28e1e3271c0@linaro.org>
On Thu, Sep 25, 2025 at 05:02:37PM -0700, Richard Henderson wrote:
> On 9/25/25 02:44, Daniel P. Berrangé wrote:
> > This addresses two key gotchas with the logging APIs:
> >
> > * Safely outputting a single line of text using
> > multiple qemu_log() calls requires use of the
> > qemu_log_trylock/unlock functions to avoid
> > interleaving between threads
> >
> > * Directly outputting to the FILE object returned
> > by qemu_log_trylock() must be discouraged because
> > it prevents the inclusion of configured log message
> > prefixes.
>
> I disagree with this point.
>
> >
> > Reported-by: Markus Armbruster <armbru@redhat.com>
> > Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
> > ---
> > include/qemu/log-for-trace.h | 35 ++++++++++++++++++++++++++++++++++-
> > include/qemu/log.h | 26 ++++++++++++++++++++++++++
> > rust/util/src/log.rs | 7 +++++++
> > 3 files changed, 67 insertions(+), 1 deletion(-)
> >
> > diff --git a/include/qemu/log-for-trace.h b/include/qemu/log-for-trace.h
> > index d47c9cd446..4e05b2e26f 100644
> > --- a/include/qemu/log-for-trace.h
> > +++ b/include/qemu/log-for-trace.h
> > @@ -29,7 +29,40 @@ static inline bool qemu_loglevel_mask(int mask)
> > return (qemu_loglevel & mask) != 0;
> > }
> > -/* main logging function */
> > +/**
> > + * qemu_log: report a log message
> > + * @fmt: the format string for the message
> > + * @...: the format string arguments
> > + *
> > + * This will emit a log message to the current output stream.
> > + *
> > + * The @fmt string should normally represent a complete line
> > + * of text, ending with a newline character.
> > + *
> > + * If intending to call this function multiple times to
> > + * incrementally construct a line of text, locking must
> > + * be used to ensure that output from different threads
> > + * is not interleaved.
> > + *
> > + * This is achieved by calling qemu_log_trylock() before
> > + * starting the log line; calling qemu_log() multiple
> > + * times with the last call having a newline at the end
> > + * of @fmt; finishing with a call to qemu_log_unlock().
> > + *
> > + * The FILE object returned by qemu_log_trylock() does
> > + * not need to be used for outputting text directly,
> > + * it is merely used to associate the lock.
> > + *
> > + * FILE *f = qemu_log_trylock()
> > + *
> > + * qemu_log("Something");
> > + * qemu_log("Something");
> > + * qemu_log("Something");
> > + * qemu_log("The end\n");
> > + *
> > + * qemu_log_unlock(f);
> > + *
>
> And I really don't like documenting this as the "right way".
>
> I believe that qemu_log *should* be used only for single-line output, all in
> one piece. Larger blocks *should* always use qemu_log_trylock and fprintf.
> The compiler has optimizations transforming fprintf to fputs and fputc as
> appropriate.
Ok, bearing in mind your suggestion below, I'll flip this around.
The above doc would instruct people to NOT use qemu_log for
incomplete lines (though it would still be accepted), and then
qemu_log_trylock() docs can recommend the best practice for
incremental line output.
> If we can manage to transform all existing usage of multiple qemu_log, then
> we can remove the '\n' detection added in patch 8.
The challenge with that is that we have no easy way to identify all
such usage other than incredibly tedious auditing of every single
file with more than one qemu_log call. And then we also can't easil
prevent it being re-introduced as a problem.
>
> As far as adding the new prefixes... perhaps we should have something like
>
> FILE *qemu_log_trylock_and_context(bool suppress_context)
> {
> FILE *f = qemu_log_trylock();
> if (f && !suppress_context) {
> qmessage_context_print(f);
> }
> return f;
> }
>
> where qemu_log would do
>
> f = qemu_log_trylock_and_context(incomplete);
That's a nice idea, as it brings the prefixes into the codepaths which
avoid qemu_log(). I'll try that out.
With regards,
Daniel
--
|: https://berrange.com -o- https://www.flickr.com/photos/dberrange :|
|: https://libvirt.org -o- https://fstop138.berrange.com :|
|: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|
next prev parent reply other threads:[~2025-09-26 14:33 UTC|newest]
Thread overview: 47+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-25 9:44 [PATCH v4 00/23] util: sync error_report & qemu_log output more closely Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 01/23] include: define constant for early constructor priority Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 02/23] monitor: initialize global data from a constructor Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 03/23] system: unconditionally enable thread naming Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 04/23] util: expose qemu_thread_set_name Daniel P. Berrangé
2025-09-25 9:52 ` Philippe Mathieu-Daudé
2025-09-25 9:44 ` [PATCH v4 05/23] audio: make jackaudio use qemu_thread_set_name Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 06/23] util: set the name for the 'main' thread Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 07/23] util: add API to fetch the current thread name Daniel P. Berrangé
2025-09-25 21:13 ` Eric Blake
2025-09-25 9:44 ` [PATCH v4 08/23] log: avoid repeated prefix on incremental qemu_log calls Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 09/23] util: introduce some API docs for logging APIs Daniel P. Berrangé
2025-09-25 21:18 ` Eric Blake
2025-09-26 0:02 ` Richard Henderson
2025-09-26 14:31 ` Daniel P. Berrangé [this message]
2025-09-25 9:44 ` [PATCH v4 10/23] ui/vnc: remove use of error_printf_unless_qmp() Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 11/23] monitor: remove redundant error_[v]printf_unless_qmp Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 12/23] monitor: refactor error_vprintf() Daniel P. Berrangé
2025-09-25 19:37 ` Richard Henderson
2025-09-25 9:44 ` [PATCH v4 13/23] monitor: move error_vprintf back to error-report.c Daniel P. Berrangé
2025-09-25 19:40 ` Richard Henderson
2025-09-25 21:20 ` Eric Blake
2025-09-25 9:44 ` [PATCH v4 14/23] monitor: introduce monitor_cur_is_hmp() helper Daniel P. Berrangé
2025-09-25 19:41 ` Richard Henderson
2025-09-25 9:44 ` [PATCH v4 15/23] util: don't skip error prefixes when QMP is active Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 16/23] util: fix interleaving of error & trace output Daniel P. Berrangé
2025-09-25 19:54 ` Richard Henderson
2025-09-26 14:27 ` Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 17/23] util: fix interleaving of error prefixes Daniel P. Berrangé
2025-09-25 9:56 ` Philippe Mathieu-Daudé
2025-09-25 19:56 ` Richard Henderson
2025-09-25 9:44 ` [PATCH v4 18/23] util: introduce common helper for error-report & log code Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 19/23] util: convert error-report & log to message API for timestamp Daniel P. Berrangé
2025-09-25 9:44 ` [PATCH v4 20/23] util: add support for formatting a workload name in messages Daniel P. Berrangé
2025-09-25 9:59 ` Philippe Mathieu-Daudé
2025-09-25 11:25 ` Philippe Mathieu-Daudé
2025-09-25 9:44 ` [PATCH v4 21/23] util: add support for formatting a program " Daniel P. Berrangé
2025-09-25 9:59 ` Philippe Mathieu-Daudé
2025-09-25 11:23 ` Philippe Mathieu-Daudé
2025-09-25 9:44 ` [PATCH v4 22/23] util: add support for formatting thread info " Daniel P. Berrangé
2025-09-25 10:00 ` Philippe Mathieu-Daudé
2025-09-25 9:44 ` [PATCH v4 23/23] util: add brackets around guest name in message context Daniel P. Berrangé
2025-09-25 10:01 ` Philippe Mathieu-Daudé
2025-09-25 11:25 ` Philippe Mathieu-Daudé
2025-09-25 10:22 ` [PATCH v4 00/23] util: sync error_report & qemu_log output more closely Philippe Mathieu-Daudé
2025-09-25 10:31 ` Daniel P. Berrangé
2025-09-25 11:21 ` Philippe Mathieu-Daudé
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aNajyYZ0A33OgjFD@redhat.com \
--to=berrange@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=richard.henderson@linaro.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.