18c2ecf20Sopenharmony_ci{ 28c2ecf20Sopenharmony_ci "direct packet read test#1 for CGROUP_SKB", 38c2ecf20Sopenharmony_ci .insns = { 48c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_2, BPF_REG_1, 58c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, data)), 68c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_3, BPF_REG_1, 78c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, data_end)), 88c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_4, BPF_REG_1, 98c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, len)), 108c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 118c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, pkt_type)), 128c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 138c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, mark)), 148c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_6, 158c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, mark)), 168c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_7, BPF_REG_1, 178c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, queue_mapping)), 188c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_8, BPF_REG_1, 198c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, protocol)), 208c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_9, BPF_REG_1, 218c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, vlan_present)), 228c2ecf20Sopenharmony_ci BPF_MOV64_REG(BPF_REG_0, BPF_REG_2), 238c2ecf20Sopenharmony_ci BPF_ALU64_IMM(BPF_ADD, BPF_REG_0, 8), 248c2ecf20Sopenharmony_ci BPF_JMP_REG(BPF_JGT, BPF_REG_0, BPF_REG_3, 1), 258c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_B, BPF_REG_0, BPF_REG_2, 0), 268c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 278c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 288c2ecf20Sopenharmony_ci }, 298c2ecf20Sopenharmony_ci .result = ACCEPT, 308c2ecf20Sopenharmony_ci .result_unpriv = REJECT, 318c2ecf20Sopenharmony_ci .errstr_unpriv = "invalid bpf_context access off=76 size=4", 328c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 338c2ecf20Sopenharmony_ci}, 348c2ecf20Sopenharmony_ci{ 358c2ecf20Sopenharmony_ci "direct packet read test#2 for CGROUP_SKB", 368c2ecf20Sopenharmony_ci .insns = { 378c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_4, BPF_REG_1, 388c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, vlan_tci)), 398c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 408c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, vlan_proto)), 418c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 428c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, priority)), 438c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_6, 448c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, priority)), 458c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_7, BPF_REG_1, 468c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, ingress_ifindex)), 478c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_8, BPF_REG_1, 488c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, tc_index)), 498c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_9, BPF_REG_1, 508c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, hash)), 518c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 528c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 538c2ecf20Sopenharmony_ci }, 548c2ecf20Sopenharmony_ci .result = ACCEPT, 558c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 568c2ecf20Sopenharmony_ci}, 578c2ecf20Sopenharmony_ci{ 588c2ecf20Sopenharmony_ci "direct packet read test#3 for CGROUP_SKB", 598c2ecf20Sopenharmony_ci .insns = { 608c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_4, BPF_REG_1, 618c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[0])), 628c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 638c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[1])), 648c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 658c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[2])), 668c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_7, BPF_REG_1, 678c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[3])), 688c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_8, BPF_REG_1, 698c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[4])), 708c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_9, BPF_REG_1, 718c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, napi_id)), 728c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_4, 738c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[0])), 748c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_5, 758c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[1])), 768c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_6, 778c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[2])), 788c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_7, 798c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[3])), 808c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_8, 818c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, cb[4])), 828c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 838c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 848c2ecf20Sopenharmony_ci }, 858c2ecf20Sopenharmony_ci .result = ACCEPT, 868c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 878c2ecf20Sopenharmony_ci}, 888c2ecf20Sopenharmony_ci{ 898c2ecf20Sopenharmony_ci "direct packet read test#4 for CGROUP_SKB", 908c2ecf20Sopenharmony_ci .insns = { 918c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_2, BPF_REG_1, 928c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, family)), 938c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_3, BPF_REG_1, 948c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, remote_ip4)), 958c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_4, BPF_REG_1, 968c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, local_ip4)), 978c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 988c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, remote_ip6[0])), 998c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 1008c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, remote_ip6[1])), 1018c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 1028c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, remote_ip6[2])), 1038c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_5, BPF_REG_1, 1048c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, remote_ip6[3])), 1058c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 1068c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, local_ip6[0])), 1078c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 1088c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, local_ip6[1])), 1098c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 1108c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, local_ip6[2])), 1118c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_6, BPF_REG_1, 1128c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, local_ip6[3])), 1138c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_7, BPF_REG_1, 1148c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, remote_port)), 1158c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_8, BPF_REG_1, 1168c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, local_port)), 1178c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1188c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1198c2ecf20Sopenharmony_ci }, 1208c2ecf20Sopenharmony_ci .result = ACCEPT, 1218c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1228c2ecf20Sopenharmony_ci}, 1238c2ecf20Sopenharmony_ci{ 1248c2ecf20Sopenharmony_ci "invalid access of tc_classid for CGROUP_SKB", 1258c2ecf20Sopenharmony_ci .insns = { 1268c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_0, BPF_REG_1, 1278c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, tc_classid)), 1288c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1298c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1308c2ecf20Sopenharmony_ci }, 1318c2ecf20Sopenharmony_ci .result = REJECT, 1328c2ecf20Sopenharmony_ci .errstr = "invalid bpf_context access", 1338c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1348c2ecf20Sopenharmony_ci}, 1358c2ecf20Sopenharmony_ci{ 1368c2ecf20Sopenharmony_ci "invalid access of data_meta for CGROUP_SKB", 1378c2ecf20Sopenharmony_ci .insns = { 1388c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_0, BPF_REG_1, 1398c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, data_meta)), 1408c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1418c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1428c2ecf20Sopenharmony_ci }, 1438c2ecf20Sopenharmony_ci .result = REJECT, 1448c2ecf20Sopenharmony_ci .errstr = "invalid bpf_context access", 1458c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1468c2ecf20Sopenharmony_ci}, 1478c2ecf20Sopenharmony_ci{ 1488c2ecf20Sopenharmony_ci "invalid access of flow_keys for CGROUP_SKB", 1498c2ecf20Sopenharmony_ci .insns = { 1508c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_0, BPF_REG_1, 1518c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, flow_keys)), 1528c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1538c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1548c2ecf20Sopenharmony_ci }, 1558c2ecf20Sopenharmony_ci .result = REJECT, 1568c2ecf20Sopenharmony_ci .errstr = "invalid bpf_context access", 1578c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1588c2ecf20Sopenharmony_ci}, 1598c2ecf20Sopenharmony_ci{ 1608c2ecf20Sopenharmony_ci "invalid write access to napi_id for CGROUP_SKB", 1618c2ecf20Sopenharmony_ci .insns = { 1628c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_W, BPF_REG_9, BPF_REG_1, 1638c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, napi_id)), 1648c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_W, BPF_REG_1, BPF_REG_9, 1658c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, napi_id)), 1668c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1678c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1688c2ecf20Sopenharmony_ci }, 1698c2ecf20Sopenharmony_ci .result = REJECT, 1708c2ecf20Sopenharmony_ci .errstr = "invalid bpf_context access", 1718c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1728c2ecf20Sopenharmony_ci}, 1738c2ecf20Sopenharmony_ci{ 1748c2ecf20Sopenharmony_ci "write tstamp from CGROUP_SKB", 1758c2ecf20Sopenharmony_ci .insns = { 1768c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1778c2ecf20Sopenharmony_ci BPF_STX_MEM(BPF_DW, BPF_REG_1, BPF_REG_0, 1788c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, tstamp)), 1798c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1808c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1818c2ecf20Sopenharmony_ci }, 1828c2ecf20Sopenharmony_ci .result = ACCEPT, 1838c2ecf20Sopenharmony_ci .result_unpriv = REJECT, 1848c2ecf20Sopenharmony_ci .errstr_unpriv = "invalid bpf_context access off=152 size=8", 1858c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1868c2ecf20Sopenharmony_ci}, 1878c2ecf20Sopenharmony_ci{ 1888c2ecf20Sopenharmony_ci "read tstamp from CGROUP_SKB", 1898c2ecf20Sopenharmony_ci .insns = { 1908c2ecf20Sopenharmony_ci BPF_LDX_MEM(BPF_DW, BPF_REG_0, BPF_REG_1, 1918c2ecf20Sopenharmony_ci offsetof(struct __sk_buff, tstamp)), 1928c2ecf20Sopenharmony_ci BPF_MOV64_IMM(BPF_REG_0, 0), 1938c2ecf20Sopenharmony_ci BPF_EXIT_INSN(), 1948c2ecf20Sopenharmony_ci }, 1958c2ecf20Sopenharmony_ci .result = ACCEPT, 1968c2ecf20Sopenharmony_ci .prog_type = BPF_PROG_TYPE_CGROUP_SKB, 1978c2ecf20Sopenharmony_ci}, 198