bpf, x86: Remove unnecessary handling of BPF_SUB atomic op
authorHou Tao <houtao1@huawei.com>
Thu, 27 Jan 2022 08:32:40 +0000 (16:32 +0800)
committerDaniel Borkmann <daniel@iogearbox.net>
Thu, 27 Jan 2022 21:47:05 +0000 (22:47 +0100)
According to the LLVM commit (https://reviews.llvm.org/D72184),
sync_fetch_and_sub() is implemented as a negation followed by
sync_fetch_and_add(), so there will be no BPF_SUB op, thus just
remove it. BPF_SUB is also rejected by the verifier anyway.

Signed-off-by: Hou Tao <houtao1@huawei.com>
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Acked-by: Brendan Jackman <jackmanb@google.com>
Link: https://lore.kernel.org/bpf/20220127083240.1425481-1-houtao1@huawei.com
arch/x86/net/bpf_jit_comp.c

index 2b1e266ff95c3db3bbfb4b142e2f770487f43cad..36f6fc3e6e690ce382aa05293ebb8c45001d2664 100644 (file)
@@ -787,7 +787,6 @@ static int emit_atomic(u8 **pprog, u8 atomic_op,
        /* emit opcode */
        switch (atomic_op) {
        case BPF_ADD:
-       case BPF_SUB:
        case BPF_AND:
        case BPF_OR:
        case BPF_XOR: