Home
last modified time | relevance | path

Searched refs:BPF_FETCH (Results 1 – 24 of 24) sorted by relevance

/openbmc/linux/tools/testing/selftests/bpf/verifier/
H A Datomic_fetch.c10 BPF_ATOMIC_OP(BPF_DW, BPF_AND | BPF_FETCH, BPF_REG_2, BPF_REG_1, 0),
34 BPF_ATOMIC_OP(BPF_DW, BPF_AND | BPF_FETCH, BPF_REG_2, BPF_REG_1, 0),
58 BPF_ATOMIC_OP(BPF_W, BPF_AND | BPF_FETCH, BPF_REG_2, BPF_REG_1, 0),
81 BPF_ATOMIC_OP(BPF_W, BPF_AND | BPF_FETCH, BPF_REG_2, BPF_REG_1, 0),
121 __ATOMIC_FETCH_OP_TEST(BPF_REG_1, BPF_REG_2, 1, BPF_ADD | BPF_FETCH, 2, 3),
122 __ATOMIC_FETCH_OP_TEST(BPF_REG_0, BPF_REG_1, 1, BPF_ADD | BPF_FETCH, 2, 3),
123 __ATOMIC_FETCH_OP_TEST(BPF_REG_1, BPF_REG_0, 1, BPF_ADD | BPF_FETCH, 2, 3),
124 __ATOMIC_FETCH_OP_TEST(BPF_REG_2, BPF_REG_3, 1, BPF_ADD | BPF_FETCH, 2, 3),
125 __ATOMIC_FETCH_OP_TEST(BPF_REG_4, BPF_REG_5, 1, BPF_ADD | BPF_FETCH, 2, 3),
126 __ATOMIC_FETCH_OP_TEST(BPF_REG_9, BPF_REG_8, 1, BPF_ADD | BPF_FETCH, 2, 3),
[all …]
H A Datomic_invalid.c15 __INVALID_ATOMIC_ACCESS_TEST(BPF_ADD | BPF_FETCH),
17 __INVALID_ATOMIC_ACCESS_TEST(BPF_ADD | BPF_FETCH),
19 __INVALID_ATOMIC_ACCESS_TEST(BPF_AND | BPF_FETCH),
21 __INVALID_ATOMIC_ACCESS_TEST(BPF_OR | BPF_FETCH),
23 __INVALID_ATOMIC_ACCESS_TEST(BPF_XOR | BPF_FETCH),
H A Datomic_fetch_add.c9 BPF_ATOMIC_OP(BPF_DW, BPF_ADD | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
31 BPF_ATOMIC_OP(BPF_W, BPF_ADD | BPF_FETCH, BPF_REG_10, BPF_REG_1, -4),
50 BPF_ATOMIC_OP(BPF_DW, BPF_ADD | BPF_FETCH, BPF_REG_10, BPF_REG_10, -8),
62 BPF_ATOMIC_OP(BPF_DW, BPF_ADD | BPF_FETCH, BPF_REG_10, BPF_REG_2, -8),
75 BPF_ATOMIC_OP(BPF_DW, BPF_ADD | BPF_FETCH, BPF_REG_2, BPF_REG_0, -8),
96 BPF_ATOMIC_OP(BPF_DW, BPF_ADD | BPF_FETCH, BPF_REG_2, BPF_REG_3, 0),
H A Datomic_or.c30 BPF_ATOMIC_OP(BPF_DW, BPF_OR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
60 BPF_ATOMIC_OP(BPF_W, BPF_OR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -4),
88 BPF_ATOMIC_OP(BPF_W, BPF_OR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
H A Datomic_and.c30 BPF_ATOMIC_OP(BPF_DW, BPF_AND | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
60 BPF_ATOMIC_OP(BPF_W, BPF_AND | BPF_FETCH, BPF_REG_10, BPF_REG_1, -4),
85 BPF_ATOMIC_OP(BPF_DW, BPF_AND | BPF_FETCH, BPF_REG_10, BPF_REG_0, -8),
H A Datomic_xor.c30 BPF_ATOMIC_OP(BPF_DW, BPF_XOR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
60 BPF_ATOMIC_OP(BPF_W, BPF_XOR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -4),
H A Datomic_bounds.c18 BPF_ATOMIC_OP(BPF_DW, BPF_ADD | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
/openbmc/linux/arch/mips/net/
H A Dbpf_jit_comp32.c741 case BPF_ADD | BPF_FETCH: in emit_atomic_r32()
747 case BPF_SUB | BPF_FETCH: in emit_atomic_r32()
753 case BPF_OR | BPF_FETCH: in emit_atomic_r32()
759 case BPF_AND | BPF_FETCH: in emit_atomic_r32()
765 case BPF_XOR | BPF_FETCH: in emit_atomic_r32()
777 if (code & BPF_FETCH) { in emit_atomic_r32()
822 case BPF_ADD | BPF_FETCH: in emit_atomic_r64()
828 case BPF_SUB | BPF_FETCH: in emit_atomic_r64()
834 case BPF_OR | BPF_FETCH: in emit_atomic_r64()
858 if (code & BPF_FETCH) { in emit_atomic_r64()
[all …]
H A Dbpf_jit_comp64.c391 case BPF_ADD | BPF_FETCH: in emit_atomic_r64()
395 case BPF_AND | BPF_FETCH: in emit_atomic_r64()
399 case BPF_OR | BPF_FETCH: in emit_atomic_r64()
403 case BPF_XOR | BPF_FETCH: in emit_atomic_r64()
414 if (code & BPF_FETCH) { in emit_atomic_r64()
853 case BPF_ADD | BPF_FETCH: in build_insn()
855 case BPF_AND | BPF_FETCH: in build_insn()
857 case BPF_OR | BPF_FETCH: in build_insn()
859 case BPF_XOR | BPF_FETCH: in build_insn()
863 } else if (imm & BPF_FETCH) { in build_insn()
H A Dbpf_jit_comp.c415 case BPF_ADD | BPF_FETCH: in emit_atomic_r()
419 case BPF_AND | BPF_FETCH: in emit_atomic_r()
423 case BPF_OR | BPF_FETCH: in emit_atomic_r()
427 case BPF_XOR | BPF_FETCH: in emit_atomic_r()
438 if (code & BPF_FETCH) { in emit_atomic_r()
/openbmc/linux/tools/testing/selftests/bpf/
H A Ddisasm.c221 (insn->imm == (BPF_ADD | BPF_FETCH) || in print_bpf_insn()
222 insn->imm == (BPF_AND | BPF_FETCH) || in print_bpf_insn()
223 insn->imm == (BPF_OR | BPF_FETCH) || in print_bpf_insn()
224 insn->imm == (BPF_XOR | BPF_FETCH))) { in print_bpf_insn()
/openbmc/linux/kernel/bpf/
H A Ddisasm.c221 (insn->imm == (BPF_ADD | BPF_FETCH) || in print_bpf_insn()
222 insn->imm == (BPF_AND | BPF_FETCH) || in print_bpf_insn()
223 insn->imm == (BPF_OR | BPF_FETCH) || in print_bpf_insn()
224 insn->imm == (BPF_XOR | BPF_FETCH))) { in print_bpf_insn()
/openbmc/linux/arch/arm64/net/
H A Dbpf_jit_comp.c481 case BPF_ADD | BPF_FETCH: in emit_lse_atomic()
484 case BPF_AND | BPF_FETCH: in emit_lse_atomic()
488 case BPF_OR | BPF_FETCH: in emit_lse_atomic()
491 case BPF_XOR | BPF_FETCH: in emit_lse_atomic()
556 imm == (BPF_AND | BPF_FETCH) || in emit_ll_sc_atomic()
557 imm == (BPF_OR | BPF_FETCH) || in emit_ll_sc_atomic()
558 imm == (BPF_XOR | BPF_FETCH)) { in emit_ll_sc_atomic()
564 if (imm == (BPF_ADD | BPF_FETCH)) in emit_ll_sc_atomic()
566 else if (imm == (BPF_AND | BPF_FETCH)) in emit_ll_sc_atomic()
568 else if (imm == (BPF_OR | BPF_FETCH)) in emit_ll_sc_atomic()
[all …]
/openbmc/linux/arch/powerpc/net/
H A Dbpf_jit_comp64.c813 if ((imm & BPF_FETCH) && IS_ENABLED(CONFIG_SMP)) in bpf_jit_build_body()
823 if (imm & BPF_FETCH) in bpf_jit_build_body()
828 case BPF_ADD | BPF_FETCH: in bpf_jit_build_body()
832 case BPF_AND | BPF_FETCH: in bpf_jit_build_body()
836 case BPF_OR | BPF_FETCH: in bpf_jit_build_body()
840 case BPF_XOR | BPF_FETCH: in bpf_jit_build_body()
876 if (imm & BPF_FETCH) { in bpf_jit_build_body()
H A Dbpf_jit_comp32.c861 if ((imm & BPF_FETCH) && IS_ENABLED(CONFIG_SMP)) in bpf_jit_build_body()
868 if (imm & BPF_FETCH) in bpf_jit_build_body()
873 case BPF_ADD | BPF_FETCH: in bpf_jit_build_body()
877 case BPF_AND | BPF_FETCH: in bpf_jit_build_body()
881 case BPF_OR | BPF_FETCH: in bpf_jit_build_body()
885 case BPF_XOR | BPF_FETCH: in bpf_jit_build_body()
915 if (imm & BPF_FETCH) { in bpf_jit_build_body()
/openbmc/linux/lib/
H A Dtest_bpf.c1613 if (op & BPF_FETCH) in __bpf_emit_atomic64()
1660 if (op & BPF_FETCH) in __bpf_emit_atomic32()
1808 return __bpf_fill_atomic64(self, BPF_ADD | BPF_FETCH); in bpf_fill_atomic64_add_fetch()
1818 return __bpf_fill_atomic64(self, BPF_OR | BPF_FETCH); in bpf_fill_atomic64_or_fetch()
1870 return __bpf_fill_atomic32(self, BPF_OR | BPF_FETCH); in bpf_fill_atomic32_or_fetch()
1967 !(op & BPF_FETCH))) in __bpf_fill_atomic_reg_pairs()
1971 else if (op & BPF_FETCH) in __bpf_fill_atomic_reg_pairs()
1989 !(rd == rs && (op & BPF_FETCH))) { in __bpf_fill_atomic_reg_pairs()
8676 { { 0, (op) & BPF_FETCH ? old : update } }, \
11701 (op) & BPF_FETCH ? 1 : 0), \
[all …]
/openbmc/linux/Documentation/bpf/
H A Dclang-notes.rst34 Clang can generate is ``BPF_ADD`` *without* ``BPF_FETCH``. If you need to enable
/openbmc/linux/arch/s390/net/
H A Dbpf_jit_comp.c1312 (insn->imm & BPF_FETCH) ? src_reg : REG_W0, \ in bpf_jit_insn()
1314 if (insn->imm & BPF_FETCH) { \ in bpf_jit_insn()
1322 case BPF_ADD | BPF_FETCH: in bpf_jit_insn()
1327 case BPF_AND | BPF_FETCH: in bpf_jit_insn()
1332 case BPF_OR | BPF_FETCH: in bpf_jit_insn()
1337 case BPF_XOR | BPF_FETCH: in bpf_jit_insn()
/openbmc/linux/Documentation/bpf/standardization/
H A Dinstruction-set.rst526 BPF_FETCH 0x01 modifier: return old value
527 BPF_XCHG 0xe0 | BPF_FETCH atomic exchange
528 BPF_CMPXCHG 0xf0 | BPF_FETCH atomic compare and exchange
531 The ``BPF_FETCH`` modifier is optional for simple atomic operations, and
532 always set for the complex atomic operations. If the ``BPF_FETCH`` flag
/openbmc/linux/arch/loongarch/net/
H A Dbpf_jit.c320 case BPF_ADD | BPF_FETCH: in emit_atomic()
328 case BPF_AND | BPF_FETCH: in emit_atomic()
336 case BPF_OR | BPF_FETCH: in emit_atomic()
344 case BPF_XOR | BPF_FETCH: in emit_atomic()
/openbmc/linux/tools/include/uapi/linux/
H A Dbpf.h49 #define BPF_FETCH 0x01 /* not an opcode on its own, used to build others */ macro
50 #define BPF_XCHG (0xe0 | BPF_FETCH) /* atomic exchange */
51 #define BPF_CMPXCHG (0xf0 | BPF_FETCH) /* atomic compare-and-write */
/openbmc/linux/include/uapi/linux/
H A Dbpf.h49 #define BPF_FETCH 0x01 /* not an opcode on its own, used to build others */ macro
50 #define BPF_XCHG (0xe0 | BPF_FETCH) /* atomic exchange */
51 #define BPF_CMPXCHG (0xf0 | BPF_FETCH) /* atomic compare-and-write */
/openbmc/linux/arch/riscv/net/
H A Dbpf_jit_comp64.c518 case BPF_ADD | BPF_FETCH: in emit_atomic()
524 case BPF_AND | BPF_FETCH: in emit_atomic()
530 case BPF_OR | BPF_FETCH: in emit_atomic()
536 case BPF_XOR | BPF_FETCH: in emit_atomic()
/openbmc/linux/arch/x86/net/
H A Dbpf_jit_comp.c889 case BPF_ADD | BPF_FETCH: in emit_atomic()
1560 if (insn->imm == (BPF_AND | BPF_FETCH) || in do_jit()
1561 insn->imm == (BPF_OR | BPF_FETCH) || in do_jit()
1562 insn->imm == (BPF_XOR | BPF_FETCH)) { in do_jit()