[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-block] [Qemu-devel] [PATCH for-2.9] mirror: Fix backwards mirr
From: |
Eric Blake |
Subject: |
Re: [Qemu-block] [Qemu-devel] [PATCH for-2.9] mirror: Fix backwards mirror_yield parameters |
Date: |
Fri, 10 Mar 2017 14:49:22 -0600 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.7.0 |
On 03/09/2017 09:25 PM, Eric Blake wrote:
> [adding Stefan in cc, as trace maintainer]
>
> On 03/09/2017 09:15 PM, Eric Blake wrote:
>
> Perhaps I should update the subject to mention trace?
>
>> trace-events lists the parameters for mirror_yield consistently
>> with other events (cnt just after s, like in mirror_before_sleep;
>> in_flight last, like in mirror_yield_in_flight). But the callers
>> were passing parameters in the wrong order, leading to poor trace
>> messages, including type truncation when there are more than 4G
>> dirty sectors involved.
I traced it back to commit bd48bde. And I started auditing for more,
finding at least a bad caller to trace_megasas_iovec_underflow since
commit e8f943ce, so I'll be submitting a v2 that turns this into a
full-blown series.
My v2 will turn on -Wformat checking to catch any more instances of type
mismatch between callers and trace-events (I'm turning up LOTS of places
where the caller and trace-events disagree on types, leading to silent
truncation such as a caller's uint64_t passed to the trace's uint32_t),
so it's turning into rather a large series. The obvious wrong
parameters and probably even the type mismatch cleanups are probably 2.9
material (although many of the things I'm fixing have been wrong in 2.8
or earlier, and are not necessarily 2.9 regressions), but the code to
actually enable -Wformat flagging may best be left for 2.10 material,
since there may be latent type mismatches in files that I'm not
compiling due to my configure/installed-library settings, but which
would break builds for others (we'll see what the buildbots say, at any
rate). Stay tuned for v2...
Oh, how am I enabling -Wformat checking, you ask? Our existing code
generates:
static inline void trace_foo(int param)
{
if (cond) {
do stuff, including with the log tracer...
qemu_log_mask(LOG_TRACE, "address@hidden:mirror_start " "bs %p s
%p opaque %p" "\n", ..., param);
}
}
and qemu-log_mask() already does -Wformat checking - but ONLY for the
types declared as the parameters to trace_foo. It is NOT detecting type
mismatches at the caller, such as if I call trace_foo(my_long).
So my trick: I taught the generator to output the inline trace_foo() as
before, but now follow it up with:
#define trace_foo(...) \
do { \
if (0) { \
printf(<format> "\n", ## __VA_ARGS__); \
} \
trace_foo(__VA_ARGS__); \
} while (0)
which creates a dead-code printf for the desired compile-time type
validations, using the format from the trace-events file.
And here's where I'm stuck: the makefiles are broken. Touching
scripts/tracetool/format/h.py does NOT cause tracetool to be re-run by a
mere 'make'; I've had to resort to 'make -B block/trace.h-timestamp' to
get things to rebuild. And this is in spite of the fact that h.py
_should_ be getting listed in $(tracetool-y) by trace/Makefile.objs, and
$(tracetool-y) is listed as a dependency of %/trace.h-timestamp in the
top-level Makefile. I would appreciate anyone with advice or an idea on
how to patch Makefile to get the dependency working without me having to
manually kick it.
--
Eric Blake eblake redhat com +1-919-301-3266
Libvirt virtualization library http://libvirt.org
signature.asc
Description: OpenPGP digital signature