Commit b375688
bpf: Correctly reject negative offsets for ALU ops
When verifying BPF programs, the check_alu_op() function validates
instructions with ALU operations. The 'offset' field in these
instructions is a signed 16-bit integer.
The existing check 'insn->off > 1' was intended to ensure the offset is
either 0, or 1 for BPF_MOD/BPF_DIV. However, because 'insn->off' is
signed, this check incorrectly accepts all negative values (e.g., -1).
This commit tightens the validation by changing the condition to
'(insn->off != 0 && insn->off != 1)'. This ensures that any value
other than the explicitly permitted 0 and 1 is rejected, hardening the
verifier against malformed BPF programs.
Co-developed-by: Shenghao Yuan <[email protected]>
Signed-off-by: Shenghao Yuan <[email protected]>
Co-developed-by: Tianci Cao <[email protected]>
Signed-off-by: Tianci Cao <[email protected]>
Signed-off-by: Yazhou Tang <[email protected]>1 parent f992e01 commit b375688
1 file changed
+2
-2
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
15803 | 15803 | | |
15804 | 15804 | | |
15805 | 15805 | | |
15806 | | - | |
| 15806 | + | |
15807 | 15807 | | |
15808 | 15808 | | |
15809 | 15809 | | |
| |||
15813 | 15813 | | |
15814 | 15814 | | |
15815 | 15815 | | |
15816 | | - | |
| 15816 | + | |
15817 | 15817 | | |
15818 | 15818 | | |
15819 | 15819 | | |
| |||
0 commit comments