diff options
author | Luke Nelson <[email protected]> | 2019-05-30 15:29:22 -0700 |
---|---|---|
committer | Alexei Starovoitov <[email protected]> | 2019-05-31 17:08:53 -0700 |
commit | 1e692f09e091bf5c8b38384f297d6dae5dbf0f12 (patch) | |
tree | bd39ab619e1c156b8a8b6701527ba6b472dc3748 /tools/perf/scripts/python/Perf-Trace-Util/lib/Perf | |
parent | cfd4921049269ee6765b4a1cb820b95d0df5dda5 (diff) |
bpf, riscv: clear high 32 bits for ALU32 add/sub/neg/lsh/rsh/arsh
In BPF, 32-bit ALU operations should zero-extend their results into
the 64-bit registers.
The current BPF JIT on RISC-V emits incorrect instructions that perform
sign extension only (e.g., addw, subw) on 32-bit add, sub, lsh, rsh,
arsh, and neg. This behavior diverges from the interpreter and JITs
for other architectures.
This patch fixes the bugs by performing zero extension on the destination
register of 32-bit ALU operations.
Fixes: 2353ecc6f91f ("bpf, riscv: add BPF JIT for RV64G")
Cc: Xi Wang <[email protected]>
Signed-off-by: Luke Nelson <[email protected]>
Acked-by: Song Liu <[email protected]>
Acked-by: Björn Töpel <[email protected]>
Reviewed-by: Palmer Dabbelt <[email protected]>
Signed-off-by: Alexei Starovoitov <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/Perf-Trace-Util/lib/Perf')
0 files changed, 0 insertions, 0 deletions