Thread (23 messages) 23 messages, 6 authors, 2025-09-11

Re: [PATCH 2/7] tracing: Have syscall trace events show "0x" for values greater than 10

From: Steven Rostedt <rostedt@kernel.org>
Date: 2025-08-06 12:39:48
Also in: lkml

On Wed, 6 Aug 2025 11:24:33 +0100
Douglas Raillard [off-list ref] wrote:
On 05-08-2025 20:26, Steven Rostedt wrote:
quoted
From: Steven Rostedt <rostedt@goodmis.org>

Currently the syscall trace events show each value as hexadecimal, but
without adding "0x" it can be confusing:

    sys_write(fd: 4, buf: 0x55c4a1fa9270, count: 44)

Looks like the above write wrote 44 bytes, when in reality it wrote 68
bytes.

Add a "0x" for all values greater or equal to 10 to remove the ambiguity.
For values less than 10, leave off the "0x" as that just adds noise to the
output.  
I'm on the fence for the value-dependent format. This looks like
it could easily make life harder for quick&dirty scripts, but then both
awk's strtonum() and Python's int(x, base=16) seem to handle
the presence/absence of the 0x prefix so maybe it's a non-issue.
Yes, but the trace file is more for humans than scripts, and the 0x1 is
just noise.
OTH, a hand-crafted regex designed after a small set of input may start
to randomly fail if one field unexpectedly goes beyond 10 ...
If you are doing hand crafted scripts, I'd suggest to use tracing
filters or other tooling that can handle this easily ;-)
Just using explicit hex may be the best here, as the actual proper fix
(type-level display hints) is harder. It could probably be implemented
using btf_decl_tag() and __builtin_btf_type_id() to retrieve the BTF info.
That would add a dependency on BTF, which I would like to avoid.

Thanks!

-- Steve
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help