diff options
| author | David Vernet <[email protected]> | 2023-10-09 11:14:13 -0500 | 
|---|---|---|
| committer | Daniel Borkmann <[email protected]> | 2023-10-09 23:10:58 +0200 | 
| commit | 829955981c557c7fc7416581c4cd68a8a0c28620 (patch) | |
| tree | 80b95778675492d06e075316b2aa066b61cb184c /tools/perf/scripts/python/check-perf-trace.py | |
| parent | a12bbb3cccf03b12847de0f7a6772127f90936ac (diff) | |
bpf: Fix verifier log for async callback return values
The verifier, as part of check_return_code(), verifies that async
callbacks such as from e.g. timers, will return 0. It does this by
correctly checking that R0->var_off is in tnum_const(0), which
effectively checks that it's in a range of 0. If this condition fails,
however, it prints an error message which says that the value should
have been in (0x0; 0x1). This results in possibly confusing output such
as the following in which an async callback returns 1:
  At async callback the register R0 has value (0x1; 0x0) should have been in (0x0; 0x1)
The fix is easy -- we should just pass the tnum_const(0) as the correct
range to verbose_invalid_scalar(), which will then print the following:
  At async callback the register R0 has value (0x1; 0x0) should have been in (0x0; 0x0)
Fixes: bfc6bb74e4f1 ("bpf: Implement verifier support for validation of async callbacks.")
Signed-off-by: David Vernet <[email protected]>
Signed-off-by: Daniel Borkmann <[email protected]>
Link: https://lore.kernel.org/bpf/[email protected]
Diffstat (limited to 'tools/perf/scripts/python/check-perf-trace.py')
0 files changed, 0 insertions, 0 deletions