.result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "invalid 8-byte read from bpf_sk_lookup remote_ip4 field",
        .result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "invalid 8-byte read from bpf_sk_lookup remote_port field",
        .result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "invalid 8-byte read from bpf_sk_lookup local_ip4 field",
        .result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "invalid 8-byte read from bpf_sk_lookup local_port field",
        .result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 /* invalid 1,2,4-byte reads from 8-byte fields in bpf_sk_lookup */
 {
        .result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "invalid 4-byte unaligned read from bpf_sk_lookup at even offset",
        .result = REJECT,
        .prog_type = BPF_PROG_TYPE_SK_LOOKUP,
        .expected_attach_type = BPF_SK_LOOKUP,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 /* in-bound and out-of-bound writes to bpf_sk_lookup */
 {
 
        .fixup_map_array_48b = { 1 },
        .result = REJECT,
        .errstr = "R1 min value is outside of the allowed memory range",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "direct map access, write test 7",
        .fixup_map_array_48b = { 1, 3 },
        .result = REJECT,
        .errstr = "invalid access to map value, value_size=48 off=47 size=2",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "direct map access, write test 17",
        .fixup_map_array_48b = { 1, 3 },
        .result = REJECT,
        .errstr = "invalid access to map value, value_size=48 off=47 size=2",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "direct map access, write test 18",
 
        .errstr_unpriv = "bpf_array access is allowed only to CAP_PERFMON and CAP_SYS_ADMIN",
        .result = REJECT,
        .errstr = "cannot access ptr member ops with moff 0 in struct bpf_map with off 1 size 4",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "bpf_map_ptr: read ops field accepted",
 
        .fixup_map_hash_8b = { 1, },
        .prog_type = BPF_PROG_TYPE_RAW_TRACEPOINT_WRITABLE,
        .errstr = "R6 invalid variable buffer offset: off=0, var_off=(0x0; 0xffffffff)",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
        .errstr = "invalid mem access",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "reference tracking: use ptr from bpf_sk_fullsock() after release",
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
        .errstr = "invalid mem access",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "reference tracking: use ptr from bpf_sk_fullsock(tp) after release",
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
        .errstr = "invalid mem access",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "reference tracking: use sk after bpf_sk_release(tp)",
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
        .errstr = "invalid mem access",
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "reference tracking: use ptr from bpf_get_listener_sock() after bpf_sk_release(sk)",
 
        .fixup_map_hash_48b = { 4 },
        .result = ACCEPT,
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc negative",
        .fixup_map_hash_48b = { 4 },
        .result = ACCEPT,
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc src_reg negative",
        .result = REJECT,
        .errstr = "invalid access to map value, value_size=48 off=44 size=8",
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc and spill",
        .fixup_map_hash_48b = { 4 },
        .result = ACCEPT,
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc and spill negative",
        .result = REJECT,
        .errstr = "invalid access to map value, value_size=48 off=48 size=8",
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc three regs",
        .fixup_map_hash_48b = { 4 },
        .result = ACCEPT,
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc after call",
        .fixup_map_hash_48b = { 4 },
        .result = ACCEPT,
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc in callee",
        .fixup_map_hash_48b = { 4 },
        .result = ACCEPT,
        .prog_type = BPF_PROG_TYPE_TRACEPOINT,
+       .flags = F_NEEDS_EFFICIENT_UNALIGNED_ACCESS,
 },
 {
        "regalloc, spill, JEQ",
 
-#define BPF_SOCK_ADDR_STORE(field, off, res, err) \
+#define BPF_SOCK_ADDR_STORE(field, off, res, err, flgs)        \
 { \
        "wide store to bpf_sock_addr." #field "[" #off "]", \
        .insns = { \
        .prog_type = BPF_PROG_TYPE_CGROUP_SOCK_ADDR, \
        .expected_attach_type = BPF_CGROUP_UDP6_SENDMSG, \
        .errstr = err, \
+       .flags = flgs, \
 }
 
 /* user_ip6[0] is u64 aligned */
 BPF_SOCK_ADDR_STORE(user_ip6, 0, ACCEPT,
-                   NULL),
+                   NULL, 0),
 BPF_SOCK_ADDR_STORE(user_ip6, 1, REJECT,
-                   "invalid bpf_context access off=12 size=8"),
+                   "invalid bpf_context access off=12 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 BPF_SOCK_ADDR_STORE(user_ip6, 2, ACCEPT,
-                   NULL),
+                   NULL, 0),
 BPF_SOCK_ADDR_STORE(user_ip6, 3, REJECT,
-                   "invalid bpf_context access off=20 size=8"),
+                   "invalid bpf_context access off=20 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 
 /* msg_src_ip6[0] is _not_ u64 aligned */
 BPF_SOCK_ADDR_STORE(msg_src_ip6, 0, REJECT,
-                   "invalid bpf_context access off=44 size=8"),
+                   "invalid bpf_context access off=44 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 BPF_SOCK_ADDR_STORE(msg_src_ip6, 1, ACCEPT,
-                   NULL),
+                   NULL, 0),
 BPF_SOCK_ADDR_STORE(msg_src_ip6, 2, REJECT,
-                   "invalid bpf_context access off=52 size=8"),
+                   "invalid bpf_context access off=52 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 BPF_SOCK_ADDR_STORE(msg_src_ip6, 3, REJECT,
-                   "invalid bpf_context access off=56 size=8"),
+                   "invalid bpf_context access off=56 size=8", 0),
 
 #undef BPF_SOCK_ADDR_STORE
 
-#define BPF_SOCK_ADDR_LOAD(field, off, res, err) \
+#define BPF_SOCK_ADDR_LOAD(field, off, res, err, flgs) \
 { \
        "wide load from bpf_sock_addr." #field "[" #off "]", \
        .insns = { \
        .prog_type = BPF_PROG_TYPE_CGROUP_SOCK_ADDR, \
        .expected_attach_type = BPF_CGROUP_UDP6_SENDMSG, \
        .errstr = err, \
+       .flags = flgs, \
 }
 
 /* user_ip6[0] is u64 aligned */
 BPF_SOCK_ADDR_LOAD(user_ip6, 0, ACCEPT,
-                  NULL),
+                  NULL, 0),
 BPF_SOCK_ADDR_LOAD(user_ip6, 1, REJECT,
-                  "invalid bpf_context access off=12 size=8"),
+                  "invalid bpf_context access off=12 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 BPF_SOCK_ADDR_LOAD(user_ip6, 2, ACCEPT,
-                  NULL),
+                  NULL, 0),
 BPF_SOCK_ADDR_LOAD(user_ip6, 3, REJECT,
-                  "invalid bpf_context access off=20 size=8"),
+                  "invalid bpf_context access off=20 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 
 /* msg_src_ip6[0] is _not_ u64 aligned */
 BPF_SOCK_ADDR_LOAD(msg_src_ip6, 0, REJECT,
-                  "invalid bpf_context access off=44 size=8"),
+                  "invalid bpf_context access off=44 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 BPF_SOCK_ADDR_LOAD(msg_src_ip6, 1, ACCEPT,
-                  NULL),
+                  NULL, 0),
 BPF_SOCK_ADDR_LOAD(msg_src_ip6, 2, REJECT,
-                  "invalid bpf_context access off=52 size=8"),
+                  "invalid bpf_context access off=52 size=8",
+                   F_NEEDS_EFFICIENT_UNALIGNED_ACCESS),
 BPF_SOCK_ADDR_LOAD(msg_src_ip6, 3, REJECT,
-                  "invalid bpf_context access off=56 size=8"),
+                  "invalid bpf_context access off=56 size=8", 0),
 
 #undef BPF_SOCK_ADDR_LOAD