Back to home page

OSCL-LXR

 
 

    


0001 {
0002     "BPF_ATOMIC OR without fetch",
0003     .insns = {
0004         /* val = 0x110; */
0005         BPF_ST_MEM(BPF_DW, BPF_REG_10, -8, 0x110),
0006         /* atomic_or(&val, 0x011); */
0007         BPF_MOV64_IMM(BPF_REG_1, 0x011),
0008         BPF_ATOMIC_OP(BPF_DW, BPF_OR, BPF_REG_10, BPF_REG_1, -8),
0009         /* if (val != 0x111) exit(2); */
0010         BPF_LDX_MEM(BPF_DW, BPF_REG_0, BPF_REG_10, -8),
0011         BPF_JMP_IMM(BPF_JEQ, BPF_REG_0, 0x111, 2),
0012         BPF_MOV64_IMM(BPF_REG_0, 2),
0013         BPF_EXIT_INSN(),
0014         /* r1 should not be clobbered, no BPF_FETCH flag */
0015         BPF_MOV64_IMM(BPF_REG_0, 0),
0016         BPF_JMP_IMM(BPF_JEQ, BPF_REG_1, 0x011, 1),
0017         BPF_MOV64_IMM(BPF_REG_0, 1),
0018         BPF_EXIT_INSN(),
0019     },
0020     .result = ACCEPT,
0021 },
0022 {
0023     "BPF_ATOMIC OR with fetch",
0024     .insns = {
0025         BPF_MOV64_IMM(BPF_REG_0, 123),
0026         /* val = 0x110; */
0027         BPF_ST_MEM(BPF_DW, BPF_REG_10, -8, 0x110),
0028         /* old = atomic_fetch_or(&val, 0x011); */
0029         BPF_MOV64_IMM(BPF_REG_1, 0x011),
0030         BPF_ATOMIC_OP(BPF_DW, BPF_OR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
0031         /* if (old != 0x110) exit(3); */
0032         BPF_JMP_IMM(BPF_JEQ, BPF_REG_1, 0x110, 2),
0033         BPF_MOV64_IMM(BPF_REG_0, 3),
0034         BPF_EXIT_INSN(),
0035         /* if (val != 0x111) exit(2); */
0036         BPF_LDX_MEM(BPF_DW, BPF_REG_1, BPF_REG_10, -8),
0037         BPF_JMP_IMM(BPF_JEQ, BPF_REG_1, 0x111, 2),
0038         BPF_MOV64_IMM(BPF_REG_1, 2),
0039         BPF_EXIT_INSN(),
0040         /* Check R0 wasn't clobbered (for fear of x86 JIT bug) */
0041         BPF_JMP_IMM(BPF_JEQ, BPF_REG_0, 123, 2),
0042         BPF_MOV64_IMM(BPF_REG_0, 1),
0043         BPF_EXIT_INSN(),
0044         /* exit(0); */
0045         BPF_MOV64_IMM(BPF_REG_0, 0),
0046         BPF_EXIT_INSN(),
0047     },
0048     .result = ACCEPT,
0049 },
0050 {
0051     "BPF_ATOMIC OR with fetch 32bit",
0052     .insns = {
0053         /* r0 = (s64) -1 */
0054         BPF_MOV64_IMM(BPF_REG_0, 0),
0055         BPF_ALU64_IMM(BPF_SUB, BPF_REG_0, 1),
0056         /* val = 0x110; */
0057         BPF_ST_MEM(BPF_W, BPF_REG_10, -4, 0x110),
0058         /* old = atomic_fetch_or(&val, 0x011); */
0059         BPF_MOV32_IMM(BPF_REG_1, 0x011),
0060         BPF_ATOMIC_OP(BPF_W, BPF_OR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -4),
0061         /* if (old != 0x110) exit(3); */
0062         BPF_JMP32_IMM(BPF_JEQ, BPF_REG_1, 0x110, 2),
0063         BPF_MOV32_IMM(BPF_REG_0, 3),
0064         BPF_EXIT_INSN(),
0065         /* if (val != 0x111) exit(2); */
0066         BPF_LDX_MEM(BPF_W, BPF_REG_1, BPF_REG_10, -4),
0067         BPF_JMP32_IMM(BPF_JEQ, BPF_REG_1, 0x111, 2),
0068         BPF_MOV32_IMM(BPF_REG_1, 2),
0069         BPF_EXIT_INSN(),
0070         /* Check R0 wasn't clobbered (for fear of x86 JIT bug)
0071          * It should be -1 so add 1 to get exit code.
0072          */
0073         BPF_ALU64_IMM(BPF_ADD, BPF_REG_0, 1),
0074         BPF_EXIT_INSN(),
0075     },
0076     .result = ACCEPT,
0077 },
0078 {
0079     "BPF_W atomic_fetch_or should zero top 32 bits",
0080     .insns = {
0081         /* r1 = U64_MAX; */
0082         BPF_MOV64_IMM(BPF_REG_1, 0),
0083         BPF_ALU64_IMM(BPF_SUB, BPF_REG_1, 1),
0084         /* u64 val = r1; */
0085         BPF_STX_MEM(BPF_DW, BPF_REG_10, BPF_REG_1, -8),
0086         /* r1 = (u32)atomic_fetch_or((u32 *)&val, 2); */
0087         BPF_MOV32_IMM(BPF_REG_1, 2),
0088         BPF_ATOMIC_OP(BPF_W, BPF_OR | BPF_FETCH, BPF_REG_10, BPF_REG_1, -8),
0089         /* r2 = 0x00000000FFFFFFFF; */
0090         BPF_MOV64_IMM(BPF_REG_2, 1),
0091         BPF_ALU64_IMM(BPF_LSH, BPF_REG_2, 32),
0092         BPF_ALU64_IMM(BPF_SUB, BPF_REG_2, 1),
0093         /* if (r2 != r1) exit(1); */
0094         BPF_JMP_REG(BPF_JEQ, BPF_REG_2, BPF_REG_1, 2),
0095         BPF_MOV64_REG(BPF_REG_0, BPF_REG_1),
0096         BPF_EXIT_INSN(),
0097         /* exit(0); */
0098         BPF_MOV32_IMM(BPF_REG_0, 0),
0099         BPF_EXIT_INSN(),
0100     },
0101     .result = ACCEPT,
0102 },