diff options
| author | Steven Rostedt <[email protected]> | 2024-12-31 05:06:46 +0000 |
|---|---|---|
| committer | Steven Rostedt (Google) <[email protected]> | 2024-12-31 05:10:32 +0000 |
| commit | afc6717628f959941d7b33728570568b4af1c4b8 (patch) | |
| tree | 11f1ea12328aa2ccf155ae82e5c7238b8b21f474 /drivers/fpga/zynqmp-fpga.c | |
| parent | Linux 6.13-rc5 (diff) | |
| download | kernel-afc6717628f959941d7b33728570568b4af1c4b8.tar.gz kernel-afc6717628f959941d7b33728570568b4af1c4b8.zip | |
tracing: Have process_string() also allow arrays
In order to catch a common bug where a TRACE_EVENT() TP_fast_assign()
assigns an address of an allocated string to the ring buffer and then
references it in TP_printk(), which can be executed hours later when the
string is free, the function test_event_printk() runs on all events as
they are registered to make sure there's no unwanted dereferencing.
It calls process_string() to handle cases in TP_printk() format that has
"%s". It returns whether or not the string is safe. But it can have some
false positives.
For instance, xe_bo_move() has:
TP_printk("move_lacks_source:%s, migrate object %p [size %zu] from %s to %s device_id:%s",
__entry->move_lacks_source ? "yes" : "no", __entry->bo, __entry->size,
xe_mem_type_to_name[__entry->old_placement],
xe_mem_type_to_name[__entry->new_placement], __get_str(device_id))
Where the "%s" references into xe_mem_type_to_name[]. This is an array of
pointers that should be safe for the event to access. Instead of flagging
this as a bad reference, if a reference points to an array, where the
record field is the index, consider it safe.
Link: https://lore.kernel.org/all/[email protected]/
Cc: [email protected]
Cc: Masami Hiramatsu <[email protected]>
Cc: Mathieu Desnoyers <[email protected]>
Link: https://lore.kernel.org/[email protected]
Fixes: 65a25d9f7ac02 ("tracing: Add "%s" check in test_event_printk()")
Reported-by: Genes Lists <[email protected]>
Tested-by: Gene C <[email protected]>
Signed-off-by: Steven Rostedt (Google) <[email protected]>
Diffstat (limited to 'drivers/fpga/zynqmp-fpga.c')
0 files changed, 0 insertions, 0 deletions
