]> git.proxmox.com Git - mirror_ubuntu-hirsute-kernel.git/commit
bpf: Fix masking negation logic upon negative dst register
authorDaniel Borkmann <daniel@iogearbox.net>
Fri, 30 Apr 2021 14:21:46 +0000 (16:21 +0200)
committerStefan Bader <stefan.bader@canonical.com>
Wed, 19 May 2021 08:03:33 +0000 (10:03 +0200)
commit714bbfae4e05a4fef0fe5354d501f6779a4b36e1
treeca3ee05366f979b7501bf44e2a90f6670f6d07b3
parent26e95a0cc641b21219879b5c311a0b377e7a6c58
bpf: Fix masking negation logic upon negative dst register

BugLink: https://bugs.launchpad.net/bugs/1928850
commit b9b34ddbe2076ade359cd5ce7537d5ed019e9807 upstream.

The negation logic for the case where the off_reg is sitting in the
dst register is not correct given then we cannot just invert the add
to a sub or vice versa. As a fix, perform the final bitwise and-op
unconditionally into AX from the off_reg, then move the pointer from
the src to dst and finally use AX as the source for the original
pointer arithmetic operation such that the inversion yields a correct
result. The single non-AX mov in between is possible given constant
blinding is retaining it as it's not an immediate based operation.

Fixes: 979d63d50c0c ("bpf: prevent out of bounds speculation on pointer arithmetic")
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Tested-by: Piotr Krysiuk <piotras@gmail.com>
Reviewed-by: Piotr Krysiuk <piotras@gmail.com>
Reviewed-by: John Fastabend <john.fastabend@gmail.com>
Acked-by: Alexei Starovoitov <ast@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
kernel/bpf/verifier.c