bpf: fix state equivalence
Commmits57a09bf0a4
("bpf: Detect identical PTR_TO_MAP_VALUE_OR_NULL registers") and484611357c
("bpf: allow access into map value arrays") by themselves are correct, but in combination they make state equivalence ignore 'id' field of the register state which can lead to accepting invalid program. Fixes:57a09bf0a4
("bpf: Detect identical PTR_TO_MAP_VALUE_OR_NULL registers") Fixes:484611357c
("bpf: allow access into map value arrays") Signed-off-by: Alexei Starovoitov <ast@kernel.org> Acked-by: Daniel Borkmann <daniel@iogearbox.net> Acked-by: Thomas Graf <tgraf@suug.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
3665f3817c
commit
d2a4dd37f6
@@ -2528,7 +2528,7 @@ static bool states_equal(struct bpf_verifier_env *env,
|
||||
* we didn't do a variable access into a map then we are a-ok.
|
||||
*/
|
||||
if (!varlen_map_access &&
|
||||
rold->type == rcur->type && rold->imm == rcur->imm)
|
||||
memcmp(rold, rcur, offsetofend(struct bpf_reg_state, id)) == 0)
|
||||
continue;
|
||||
|
||||
/* If we didn't map access then again we don't care about the
|
||||
|
Reference in New Issue
Block a user