]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
bpf: Prepare verifier logs for upcoming kfunc stack arguments
authorYonghong Song <yonghong.song@linux.dev>
Thu, 23 Apr 2026 03:35:01 +0000 (20:35 -0700)
committerAlexei Starovoitov <ast@kernel.org>
Thu, 23 Apr 2026 14:54:50 +0000 (07:54 -0700)
This change prepares verifier log reporting for upcoming kfunc stack
argument support.

Currently verifier log code mostly assumes that an argument can be
described directly by a register number. That works for arguments
passed in `R1` to `R5`, but it does not work once kfunc arguments
can also be passed on the stack.

Introduce an opaque `argno_t` type that encodes both register-based
and arg-based references. Four helpers form the interface:

  - argno_from_reg(regno): create from a register number
  - argno_from_arg(arg):   create from a 1-based arg number
  - reg_from_argno(a):     extract register number, or -1
  - arg_from_argno(a):     extract arg number, or -1

reg_arg_name() converts an argno_t to a human-readable string for
verifier logs: "R%d" for register arguments, or "*(R11-off)" for
stack arguments beyond R5.

Update selftests accordingly.

Signed-off-by: Yonghong Song <yonghong.song@linux.dev>
Link: https://lore.kernel.org/r/20260423033501.2539667-1-yonghong.song@linux.dev
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
30 files changed:
include/linux/bpf_verifier.h
kernel/bpf/verifier.c
tools/testing/selftests/bpf/prog_tests/bpf_nf.c
tools/testing/selftests/bpf/prog_tests/cb_refs.c
tools/testing/selftests/bpf/prog_tests/kfunc_call.c
tools/testing/selftests/bpf/prog_tests/linked_list.c
tools/testing/selftests/bpf/progs/cgrp_kfunc_failure.c
tools/testing/selftests/bpf/progs/cpumask_failure.c
tools/testing/selftests/bpf/progs/dynptr_fail.c
tools/testing/selftests/bpf/progs/file_reader_fail.c
tools/testing/selftests/bpf/progs/irq.c
tools/testing/selftests/bpf/progs/iters.c
tools/testing/selftests/bpf/progs/iters_state_safety.c
tools/testing/selftests/bpf/progs/iters_testmod.c
tools/testing/selftests/bpf/progs/iters_testmod_seq.c
tools/testing/selftests/bpf/progs/map_kptr_fail.c
tools/testing/selftests/bpf/progs/percpu_alloc_fail.c
tools/testing/selftests/bpf/progs/rbtree_fail.c
tools/testing/selftests/bpf/progs/refcounted_kptr_fail.c
tools/testing/selftests/bpf/progs/stream_fail.c
tools/testing/selftests/bpf/progs/task_kfunc_failure.c
tools/testing/selftests/bpf/progs/task_work_fail.c
tools/testing/selftests/bpf/progs/test_bpf_nf_fail.c
tools/testing/selftests/bpf/progs/test_kfunc_dynptr_param.c
tools/testing/selftests/bpf/progs/test_kfunc_param_nullable.c
tools/testing/selftests/bpf/progs/verifier_bits_iter.c
tools/testing/selftests/bpf/progs/verifier_ref_tracking.c
tools/testing/selftests/bpf/progs/verifier_vfs_reject.c
tools/testing/selftests/bpf/progs/wq_failures.c
tools/testing/selftests/bpf/verifier/calls.c

index b148f816f25b08a4cff5bd7a2512b5272f73a35d..d5b4303315dd948efc62a28fe9091d960be0409f 100644 (file)
@@ -913,6 +913,7 @@ struct bpf_verifier_env {
         * e.g., in reg_type_str() to generate reg_type string
         */
        char tmp_str_buf[TMP_STR_BUF_LEN];
+       char tmp_arg_name[32];
        struct bpf_insn insn_buf[INSN_BUF_SIZE];
        struct bpf_insn epilogue_buf[INSN_BUF_SIZE];
        struct bpf_scc_callchain callchain_buf;
index 81d77dfaaaf652f3b1f977d2e1424679478a93e1..ff6ff1c27517f13bb9aaabf3c64d7e9f57df1ccc 100644 (file)
@@ -261,6 +261,36 @@ struct bpf_kfunc_meta {
 
 struct btf *btf_vmlinux;
 
+typedef struct argno {
+       int argno;
+} argno_t;
+
+static argno_t argno_from_reg(u32 regno)
+{
+       return (argno_t){ .argno = regno };
+}
+
+static argno_t argno_from_arg(u32 arg)
+{
+       return (argno_t){ .argno = -arg };
+}
+
+static int reg_from_argno(argno_t a)
+{
+       if (a.argno >= 0)
+               return a.argno;
+       if (a.argno >= -MAX_BPF_FUNC_REG_ARGS)
+               return -a.argno;
+       return -1;
+}
+
+static int arg_from_argno(argno_t a)
+{
+       if (a.argno < 0)
+               return -a.argno;
+       return -1;
+}
+
 static const char *btf_type_name(const struct btf *btf, u32 id)
 {
        return btf_name_by_offset(btf, btf_type_by_id(btf, id)->name_off);
@@ -1742,6 +1772,22 @@ static struct bpf_verifier_state *push_stack(struct bpf_verifier_env *env,
        return &elem->st;
 }
 
+static const char *reg_arg_name(struct bpf_verifier_env *env, argno_t argno)
+{
+       char *buf = env->tmp_arg_name;
+       int len = sizeof(env->tmp_arg_name);
+       int arg, regno = reg_from_argno(argno);
+
+       if (regno >= 0) {
+               snprintf(buf, len, "R%d", regno);
+       } else {
+               arg = arg_from_argno(argno);
+               snprintf(buf, len, "*(R11-%u)", (arg - MAX_BPF_FUNC_REG_ARGS) * BPF_REG_SIZE);
+       }
+
+       return buf;
+}
+
 static const int caller_saved[CALLER_SAVED_REGS] = {
        BPF_REG_0, BPF_REG_1, BPF_REG_2, BPF_REG_3, BPF_REG_4, BPF_REG_5
 };
@@ -4241,7 +4287,7 @@ enum bpf_access_src {
 };
 
 static int check_stack_range_initialized(struct bpf_verifier_env *env, struct bpf_reg_state *reg,
-                                        int regno, int off, int access_size,
+                                        argno_t argno, int off, int access_size,
                                         bool zero_size_allowed,
                                         enum bpf_access_type type,
                                         struct bpf_call_arg_meta *meta);
@@ -4265,7 +4311,7 @@ static struct bpf_reg_state *reg_state(struct bpf_verifier_env *env, int regno)
  * instead.
  */
 static int check_stack_read_var_off(struct bpf_verifier_env *env, struct bpf_reg_state *reg,
-                                   int ptr_regno, int off, int size, int dst_regno)
+                                   argno_t ptr_argno, int off, int size, int dst_regno)
 {
        struct bpf_func_state *ptr_state = bpf_func(env, reg);
        int err;
@@ -4273,7 +4319,7 @@ static int check_stack_read_var_off(struct bpf_verifier_env *env, struct bpf_reg
 
        /* Note that we pass a NULL meta, so raw access will not be permitted.
         */
-       err = check_stack_range_initialized(env, reg, ptr_regno, off, size,
+       err = check_stack_range_initialized(env, reg, ptr_argno, off, size,
                                            false, BPF_READ, NULL);
        if (err)
                return err;
@@ -4295,7 +4341,7 @@ static int check_stack_read_var_off(struct bpf_verifier_env *env, struct bpf_reg
  * can be -1, meaning that the read value is not going to a register.
  */
 static int check_stack_read(struct bpf_verifier_env *env,
-                           struct bpf_reg_state *reg, int ptr_regno, int off, int size,
+                           struct bpf_reg_state *reg, argno_t ptr_argno, int off, int size,
                            int dst_regno)
 {
        struct bpf_func_state *state = bpf_func(env, reg);
@@ -4333,7 +4379,7 @@ static int check_stack_read(struct bpf_verifier_env *env,
                 * than fixed offset ones. Note that dst_regno >= 0 on this
                 * branch.
                 */
-               err = check_stack_read_var_off(env, reg, ptr_regno, off, size,
+               err = check_stack_read_var_off(env, reg, ptr_argno, off, size,
                                               dst_regno);
        }
        return err;
@@ -4393,7 +4439,7 @@ static int check_map_access_type(struct bpf_verifier_env *env, struct bpf_reg_st
 }
 
 /* check read/write into memory region (e.g., map value, ringbuf sample, etc) */
-static int __check_mem_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno,
+static int __check_mem_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                              int off, int size, u32 mem_size,
                              bool zero_size_allowed)
 {
@@ -4414,8 +4460,8 @@ static int __check_mem_access(struct bpf_verifier_env *env, struct bpf_reg_state
        case PTR_TO_PACKET:
        case PTR_TO_PACKET_META:
        case PTR_TO_PACKET_END:
-               verbose(env, "invalid access to packet, off=%d size=%d, R%d(id=%d,off=%d,r=%d)\n",
-                       off, size, regno, reg->id, off, mem_size);
+               verbose(env, "invalid access to packet, off=%d size=%d, %s(id=%d,off=%d,r=%d)\n",
+                       off, size, reg_arg_name(env, argno), reg->id, off, mem_size);
                break;
        case PTR_TO_CTX:
                verbose(env, "invalid access to context, ctx_size=%d off=%d size=%d\n",
@@ -4431,7 +4477,7 @@ static int __check_mem_access(struct bpf_verifier_env *env, struct bpf_reg_state
 }
 
 /* check read/write into a memory region with possible variable offset */
-static int check_mem_region_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, u32 regno,
+static int check_mem_region_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                                   int off, int size, u32 mem_size,
                                   bool zero_size_allowed)
 {
@@ -4451,15 +4497,15 @@ static int check_mem_region_access(struct bpf_verifier_env *env, struct bpf_reg_
            (reg->smin_value == S64_MIN ||
             (off + reg->smin_value != (s64)(s32)(off + reg->smin_value)) ||
              reg->smin_value + off < 0)) {
-               verbose(env, "R%d min value is negative, either use unsigned index or do a if (index >=0) check.\n",
-                       regno);
+               verbose(env, "%s min value is negative, either use unsigned index or do a if (index >=0) check.\n",
+                       reg_arg_name(env, argno));
                return -EACCES;
        }
-       err = __check_mem_access(env, reg, regno, reg->smin_value + off, size,
+       err = __check_mem_access(env, reg, argno, reg->smin_value + off, size,
                                 mem_size, zero_size_allowed);
        if (err) {
-               verbose(env, "R%d min value is outside of the allowed memory range\n",
-                       regno);
+               verbose(env, "%s min value is outside of the allowed memory range\n",
+                       reg_arg_name(env, argno));
                return err;
        }
 
@@ -4468,15 +4514,15 @@ static int check_mem_region_access(struct bpf_verifier_env *env, struct bpf_reg_
         * If reg->umax_value + off could overflow, treat that as unbounded too.
         */
        if (reg->umax_value >= BPF_MAX_VAR_OFF) {
-               verbose(env, "R%d unbounded memory access, make sure to bounds check any such access\n",
-                       regno);
+               verbose(env, "%s unbounded memory access, make sure to bounds check any such access\n",
+                       reg_arg_name(env, argno));
                return -EACCES;
        }
-       err = __check_mem_access(env, reg, regno, reg->umax_value + off, size,
+       err = __check_mem_access(env, reg, argno, reg->umax_value + off, size,
                                 mem_size, zero_size_allowed);
        if (err) {
-               verbose(env, "R%d max value is outside of the allowed memory range\n",
-                       regno);
+               verbose(env, "%s max value is outside of the allowed memory range\n",
+                       reg_arg_name(env, argno));
                return err;
        }
 
@@ -4484,7 +4530,7 @@ static int check_mem_region_access(struct bpf_verifier_env *env, struct bpf_reg_
 }
 
 static int __check_ptr_off_reg(struct bpf_verifier_env *env,
-                              const struct bpf_reg_state *reg, int regno,
+                              const struct bpf_reg_state *reg, argno_t argno,
                               bool fixed_off_ok)
 {
        /* Access to this pointer-typed register or passing it to a helper
@@ -4501,14 +4547,14 @@ static int __check_ptr_off_reg(struct bpf_verifier_env *env,
        }
 
        if (reg->smin_value < 0) {
-               verbose(env, "negative offset %s ptr R%d off=%lld disallowed\n",
-                       reg_type_str(env, reg->type), regno, reg->var_off.value);
+               verbose(env, "negative offset %s ptr %s off=%lld disallowed\n",
+                       reg_type_str(env, reg->type), reg_arg_name(env, argno), reg->var_off.value);
                return -EACCES;
        }
 
        if (!fixed_off_ok && reg->var_off.value != 0) {
-               verbose(env, "dereference of modified %s ptr R%d off=%lld disallowed\n",
-                       reg_type_str(env, reg->type), regno, reg->var_off.value);
+               verbose(env, "dereference of modified %s ptr %s off=%lld disallowed\n",
+                       reg_type_str(env, reg->type), reg_arg_name(env, argno), reg->var_off.value);
                return -EACCES;
        }
 
@@ -4518,7 +4564,7 @@ static int __check_ptr_off_reg(struct bpf_verifier_env *env,
 static int check_ptr_off_reg(struct bpf_verifier_env *env,
                             const struct bpf_reg_state *reg, int regno)
 {
-       return __check_ptr_off_reg(env, reg, regno, false);
+       return __check_ptr_off_reg(env, reg, argno_from_reg(regno), false);
 }
 
 static int map_kptr_match_type(struct bpf_verifier_env *env,
@@ -4556,7 +4602,7 @@ static int map_kptr_match_type(struct bpf_verifier_env *env,
         * Since ref_ptr cannot be accessed directly by BPF insns, check for
         * reg->ref_obj_id is not needed here.
         */
-       if (__check_ptr_off_reg(env, reg, regno, true))
+       if (__check_ptr_off_reg(env, reg, argno_from_reg(regno), true))
                return -EACCES;
 
        /* A full type match is needed, as BTF can be vmlinux, module or prog BTF, and
@@ -4776,7 +4822,7 @@ static u32 map_mem_size(const struct bpf_map *map)
 }
 
 /* check read/write into a map element with possible variable offset */
-static int check_map_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, u32 regno,
+static int check_map_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                            int off, int size, bool zero_size_allowed,
                            enum bpf_access_src src)
 {
@@ -4785,7 +4831,7 @@ static int check_map_access(struct bpf_verifier_env *env, struct bpf_reg_state *
        struct btf_record *rec;
        int err, i;
 
-       err = check_mem_region_access(env, reg, regno, off, size, mem_size, zero_size_allowed);
+       err = check_mem_region_access(env, reg, argno, off, size, mem_size, zero_size_allowed);
        if (err)
                return err;
 
@@ -4881,17 +4927,17 @@ static bool may_access_direct_pkt_data(struct bpf_verifier_env *env,
        }
 }
 
-static int check_packet_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, u32 regno, int off,
+static int check_packet_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno, int off,
                               int size, bool zero_size_allowed)
 {
        int err;
 
        if (reg->range < 0) {
-               verbose(env, "R%d offset is outside of the packet\n", regno);
+               verbose(env, "%s offset is outside of the packet\n", reg_arg_name(env, argno));
                return -EINVAL;
        }
 
-       err = check_mem_region_access(env, reg, regno, off, size, reg->range, zero_size_allowed);
+       err = check_mem_region_access(env, reg, argno, off, size, reg->range, zero_size_allowed);
        if (err)
                return err;
 
@@ -4946,7 +4992,7 @@ static int __check_ctx_access(struct bpf_verifier_env *env, int insn_idx, int of
        return -EACCES;
 }
 
-static int check_ctx_access(struct bpf_verifier_env *env, int insn_idx, struct bpf_reg_state *reg, u32 regno,
+static int check_ctx_access(struct bpf_verifier_env *env, int insn_idx, struct bpf_reg_state *reg, argno_t argno,
                            int off, int access_size, enum bpf_access_type t,
                            struct bpf_insn_access_aux *info)
 {
@@ -4959,9 +5005,9 @@ static int check_ctx_access(struct bpf_verifier_env *env, int insn_idx, struct b
        int err;
 
        if (var_off_ok)
-               err = check_mem_region_access(env, reg, regno, off, access_size, U16_MAX, false);
+               err = check_mem_region_access(env, reg, argno, off, access_size, U16_MAX, false);
        else
-               err = __check_ptr_off_reg(env, reg, regno, fixed_off_ok);
+               err = __check_ptr_off_reg(env, reg, argno, fixed_off_ok);
        if (err)
                return err;
        off += reg->umax_value;
@@ -4985,15 +5031,15 @@ static int check_flow_keys_access(struct bpf_verifier_env *env, int off,
 }
 
 static int check_sock_access(struct bpf_verifier_env *env, int insn_idx,
-                            struct bpf_reg_state *reg, u32 regno, int off, int size,
+                            struct bpf_reg_state *reg, argno_t argno, int off, int size,
                             enum bpf_access_type t)
 {
        struct bpf_insn_access_aux info = {};
        bool valid;
 
        if (reg->smin_value < 0) {
-               verbose(env, "R%d min value is negative, either use unsigned index or do a if (index >=0) check.\n",
-                       regno);
+               verbose(env, "%s min value is negative, either use unsigned index or do a if (index >=0) check.\n",
+                       reg_arg_name(env, argno));
                return -EACCES;
        }
 
@@ -5021,8 +5067,8 @@ static int check_sock_access(struct bpf_verifier_env *env, int insn_idx,
                return 0;
        }
 
-       verbose(env, "R%d invalid %s access off=%d size=%d\n",
-               regno, reg_type_str(env, reg->type), off, size);
+       verbose(env, "%s invalid %s access off=%d size=%d\n",
+               reg_arg_name(env, argno), reg_type_str(env, reg->type), off, size);
 
        return -EACCES;
 }
@@ -5535,12 +5581,12 @@ static int check_max_stack_depth(struct bpf_verifier_env *env)
 static int __check_buffer_access(struct bpf_verifier_env *env,
                                 const char *buf_info,
                                 const struct bpf_reg_state *reg,
-                                int regno, int off, int size)
+                                argno_t argno, int off, int size)
 {
        if (off < 0) {
                verbose(env,
-                       "R%d invalid %s buffer access: off=%d, size=%d\n",
-                       regno, buf_info, off, size);
+                       "%s invalid %s buffer access: off=%d, size=%d\n",
+                       reg_arg_name(env, argno), buf_info, off, size);
                return -EACCES;
        }
        if (!tnum_is_const(reg->var_off)) {
@@ -5548,8 +5594,8 @@ static int __check_buffer_access(struct bpf_verifier_env *env,
 
                tnum_strn(tn_buf, sizeof(tn_buf), reg->var_off);
                verbose(env,
-                       "R%d invalid variable buffer offset: off=%d, var_off=%s\n",
-                       regno, off, tn_buf);
+                       "%s invalid variable buffer offset: off=%d, var_off=%s\n",
+                       reg_arg_name(env, argno), off, tn_buf);
                return -EACCES;
        }
 
@@ -5558,11 +5604,11 @@ static int __check_buffer_access(struct bpf_verifier_env *env,
 
 static int check_tp_buffer_access(struct bpf_verifier_env *env,
                                  const struct bpf_reg_state *reg,
-                                 int regno, int off, int size)
+                                 argno_t argno, int off, int size)
 {
        int err;
 
-       err = __check_buffer_access(env, "tracepoint", reg, regno, off, size);
+       err = __check_buffer_access(env, "tracepoint", reg, argno, off, size);
        if (err)
                return err;
 
@@ -5574,14 +5620,14 @@ static int check_tp_buffer_access(struct bpf_verifier_env *env,
 
 static int check_buffer_access(struct bpf_verifier_env *env,
                               const struct bpf_reg_state *reg,
-                              int regno, int off, int size,
+                              argno_t argno, int off, int size,
                               bool zero_size_allowed,
                               u32 *max_access)
 {
        const char *buf_info = type_is_rdonly_mem(reg->type) ? "rdonly" : "rdwr";
        int err;
 
-       err = __check_buffer_access(env, buf_info, reg, regno, off, size);
+       err = __check_buffer_access(env, buf_info, reg, argno, off, size);
        if (err)
                return err;
 
@@ -5954,7 +6000,7 @@ static bool type_is_trusted_or_null(struct bpf_verifier_env *env,
 
 static int check_ptr_to_btf_access(struct bpf_verifier_env *env,
                                   struct bpf_reg_state *regs, struct bpf_reg_state *reg,
-                                  int regno, int off, int size,
+                                  argno_t argno, int off, int size,
                                   enum bpf_access_type atype,
                                   int value_regno)
 {
@@ -5983,8 +6029,8 @@ static int check_ptr_to_btf_access(struct bpf_verifier_env *env,
 
                tnum_strn(tn_buf, sizeof(tn_buf), reg->var_off);
                verbose(env,
-                       "R%d is ptr_%s invalid variable offset: off=%d, var_off=%s\n",
-                       regno, tname, off, tn_buf);
+                       "%s is ptr_%s invalid variable offset: off=%d, var_off=%s\n",
+                       reg_arg_name(env, argno), tname, off, tn_buf);
                return -EACCES;
        }
 
@@ -5992,22 +6038,22 @@ static int check_ptr_to_btf_access(struct bpf_verifier_env *env,
 
        if (off < 0) {
                verbose(env,
-                       "R%d is ptr_%s invalid negative access: off=%d\n",
-                       regno, tname, off);
+                       "%s is ptr_%s invalid negative access: off=%d\n",
+                       reg_arg_name(env, argno), tname, off);
                return -EACCES;
        }
 
        if (reg->type & MEM_USER) {
                verbose(env,
-                       "R%d is ptr_%s access user memory: off=%d\n",
-                       regno, tname, off);
+                       "%s is ptr_%s access user memory: off=%d\n",
+                       reg_arg_name(env, argno), tname, off);
                return -EACCES;
        }
 
        if (reg->type & MEM_PERCPU) {
                verbose(env,
-                       "R%d is ptr_%s access percpu memory: off=%d\n",
-                       regno, tname, off);
+                       "%s is ptr_%s access percpu memory: off=%d\n",
+                       reg_arg_name(env, argno), tname, off);
                return -EACCES;
        }
 
@@ -6110,7 +6156,7 @@ static int check_ptr_to_btf_access(struct bpf_verifier_env *env,
 
 static int check_ptr_to_map_access(struct bpf_verifier_env *env,
                                   struct bpf_reg_state *regs, struct bpf_reg_state *reg,
-                                  int regno, int off, int size,
+                                  argno_t argno, int off, int size,
                                   enum bpf_access_type atype,
                                   int value_regno)
 {
@@ -6144,8 +6190,8 @@ static int check_ptr_to_map_access(struct bpf_verifier_env *env,
        }
 
        if (off < 0) {
-               verbose(env, "R%d is %s invalid negative access: off=%d\n",
-                       regno, tname, off);
+               verbose(env, "%s is %s invalid negative access: off=%d\n",
+                       reg_arg_name(env, argno), tname, off);
                return -EACCES;
        }
 
@@ -6203,7 +6249,7 @@ static int check_stack_slot_within_bounds(struct bpf_verifier_env *env,
  */
 static int check_stack_access_within_bounds(
                struct bpf_verifier_env *env, struct bpf_reg_state *reg,
-               int regno, int off, int access_size,
+               argno_t argno, int off, int access_size,
                enum bpf_access_type type)
 {
        struct bpf_func_state *state = bpf_func(env, reg);
@@ -6222,8 +6268,8 @@ static int check_stack_access_within_bounds(
        } else {
                if (reg->smax_value >= BPF_MAX_VAR_OFF ||
                    reg->smin_value <= -BPF_MAX_VAR_OFF) {
-                       verbose(env, "invalid unbounded variable-offset%s stack R%d\n",
-                               err_extra, regno);
+                       verbose(env, "invalid unbounded variable-offset%s stack %s\n",
+                               err_extra, reg_arg_name(env, argno));
                        return -EACCES;
                }
                min_off = reg->smin_value + off;
@@ -6241,14 +6287,14 @@ static int check_stack_access_within_bounds(
 
        if (err) {
                if (tnum_is_const(reg->var_off)) {
-                       verbose(env, "invalid%s stack R%d off=%lld size=%d\n",
-                               err_extra, regno, min_off, access_size);
+                       verbose(env, "invalid%s stack %s off=%lld size=%d\n",
+                               err_extra, reg_arg_name(env, argno), min_off, access_size);
                } else {
                        char tn_buf[48];
 
                        tnum_strn(tn_buf, sizeof(tn_buf), reg->var_off);
-                       verbose(env, "invalid variable-offset%s stack R%d var_off=%s off=%d size=%d\n",
-                               err_extra, regno, tn_buf, off, access_size);
+                       verbose(env, "invalid variable-offset%s stack %s var_off=%s off=%d size=%d\n",
+                               err_extra, reg_arg_name(env, argno), tn_buf, off, access_size);
                }
                return err;
        }
@@ -6293,7 +6339,7 @@ static void add_scalar_to_reg(struct bpf_reg_state *dst_reg, s64 val)
  * if t==write && value_regno==-1, some unknown value is stored into memory
  * if t==read && value_regno==-1, don't care what we read from memory
  */
-static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct bpf_reg_state *reg, u32 regno,
+static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct bpf_reg_state *reg, argno_t argno,
                            int off, int bpf_size, enum bpf_access_type t,
                            int value_regno, bool strict_alignment_once, bool is_ldsx)
 {
@@ -6310,11 +6356,12 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
 
        if (reg->type == PTR_TO_MAP_KEY) {
                if (t == BPF_WRITE) {
-                       verbose(env, "write to change key R%d not allowed\n", regno);
+                       verbose(env, "write to change key %s not allowed\n",
+                               reg_arg_name(env, argno));
                        return -EACCES;
                }
 
-               err = check_mem_region_access(env, reg, regno, off, size,
+               err = check_mem_region_access(env, reg, argno, off, size,
                                              reg->map_ptr->key_size, false);
                if (err)
                        return err;
@@ -6331,7 +6378,7 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                err = check_map_access_type(env, reg, off, size, t);
                if (err)
                        return err;
-               err = check_map_access(env, reg, regno, off, size, false, ACCESS_DIRECT);
+               err = check_map_access(env, reg, argno, off, size, false, ACCESS_DIRECT);
                if (err)
                        return err;
                if (tnum_is_const(reg->var_off))
@@ -6378,14 +6425,14 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                bool rdonly_untrusted = rdonly_mem && (reg->type & PTR_UNTRUSTED);
 
                if (type_may_be_null(reg->type)) {
-                       verbose(env, "R%d invalid mem access '%s'\n", regno,
+                       verbose(env, "%s invalid mem access '%s'\n", reg_arg_name(env, argno),
                                reg_type_str(env, reg->type));
                        return -EACCES;
                }
 
                if (t == BPF_WRITE && rdonly_mem) {
-                       verbose(env, "R%d cannot write into %s\n",
-                               regno, reg_type_str(env, reg->type));
+                       verbose(env, "%s cannot write into %s\n",
+                               reg_arg_name(env, argno), reg_type_str(env, reg->type));
                        return -EACCES;
                }
 
@@ -6400,7 +6447,7 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                 * instructions, hence no need to check bounds in that case.
                 */
                if (!rdonly_untrusted)
-                       err = check_mem_region_access(env, reg, regno, off, size,
+                       err = check_mem_region_access(env, reg, argno, off, size,
                                                      reg->mem_size, false);
                if (!err && value_regno >= 0 && (t == BPF_READ || rdonly_mem))
                        mark_reg_unknown(env, regs, value_regno);
@@ -6418,7 +6465,7 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                        return -EACCES;
                }
 
-               err = check_ctx_access(env, insn_idx, reg, regno, off, size, t, &info);
+               err = check_ctx_access(env, insn_idx, reg, argno, off, size, t, &info);
                if (!err && t == BPF_READ && value_regno >= 0) {
                        /* ctx access returns either a scalar, or a
                         * PTR_TO_PACKET[_META,_END]. In the latter
@@ -6455,12 +6502,12 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
 
        } else if (reg->type == PTR_TO_STACK) {
                /* Basic bounds checks. */
-               err = check_stack_access_within_bounds(env, reg, regno, off, size, t);
+               err = check_stack_access_within_bounds(env, reg, argno, off, size, t);
                if (err)
                        return err;
 
                if (t == BPF_READ)
-                       err = check_stack_read(env, reg, regno, off, size,
+                       err = check_stack_read(env, reg, argno, off, size,
                                               value_regno);
                else
                        err = check_stack_write(env, reg, off, size,
@@ -6476,7 +6523,7 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                                value_regno);
                        return -EACCES;
                }
-               err = check_packet_access(env, reg, regno, off, size, false);
+               err = check_packet_access(env, reg, argno, off, size, false);
                if (!err && t == BPF_READ && value_regno >= 0)
                        mark_reg_unknown(env, regs, value_regno);
        } else if (reg->type == PTR_TO_FLOW_KEYS) {
@@ -6492,23 +6539,23 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                        mark_reg_unknown(env, regs, value_regno);
        } else if (type_is_sk_pointer(reg->type)) {
                if (t == BPF_WRITE) {
-                       verbose(env, "R%d cannot write into %s\n",
-                               regno, reg_type_str(env, reg->type));
+                       verbose(env, "%s cannot write into %s\n",
+                               reg_arg_name(env, argno), reg_type_str(env, reg->type));
                        return -EACCES;
                }
-               err = check_sock_access(env, insn_idx, reg, regno, off, size, t);
+               err = check_sock_access(env, insn_idx, reg, argno, off, size, t);
                if (!err && value_regno >= 0)
                        mark_reg_unknown(env, regs, value_regno);
        } else if (reg->type == PTR_TO_TP_BUFFER) {
-               err = check_tp_buffer_access(env, reg, regno, off, size);
+               err = check_tp_buffer_access(env, reg, argno, off, size);
                if (!err && t == BPF_READ && value_regno >= 0)
                        mark_reg_unknown(env, regs, value_regno);
        } else if (base_type(reg->type) == PTR_TO_BTF_ID &&
                   !type_may_be_null(reg->type)) {
-               err = check_ptr_to_btf_access(env, regs, reg, regno, off, size, t,
+               err = check_ptr_to_btf_access(env, regs, reg, argno, off, size, t,
                                              value_regno);
        } else if (reg->type == CONST_PTR_TO_MAP) {
-               err = check_ptr_to_map_access(env, regs, reg, regno, off, size, t,
+               err = check_ptr_to_map_access(env, regs, reg, argno, off, size, t,
                                              value_regno);
        } else if (base_type(reg->type) == PTR_TO_BUF &&
                   !type_may_be_null(reg->type)) {
@@ -6517,8 +6564,8 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
 
                if (rdonly_mem) {
                        if (t == BPF_WRITE) {
-                               verbose(env, "R%d cannot write into %s\n",
-                                       regno, reg_type_str(env, reg->type));
+                               verbose(env, "%s cannot write into %s\n",
+                                       reg_arg_name(env, argno), reg_type_str(env, reg->type));
                                return -EACCES;
                        }
                        max_access = &env->prog->aux->max_rdonly_access;
@@ -6526,7 +6573,7 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                        max_access = &env->prog->aux->max_rdwr_access;
                }
 
-               err = check_buffer_access(env, reg, regno, off, size, false,
+               err = check_buffer_access(env, reg, argno, off, size, false,
                                          max_access);
 
                if (!err && value_regno >= 0 && (rdonly_mem || t == BPF_READ))
@@ -6535,7 +6582,7 @@ static int check_mem_access(struct bpf_verifier_env *env, int insn_idx, struct b
                if (t == BPF_READ && value_regno >= 0)
                        mark_reg_unknown(env, regs, value_regno);
        } else {
-               verbose(env, "R%d invalid mem access '%s'\n", regno,
+               verbose(env, "%s invalid mem access '%s'\n", reg_arg_name(env, argno),
                        reg_type_str(env, reg->type));
                return -EACCES;
        }
@@ -6577,7 +6624,7 @@ static int check_load_mem(struct bpf_verifier_env *env, struct bpf_insn *insn,
        /* Check if (src_reg + off) is readable. The state of dst_reg will be
         * updated by this call.
         */
-       err = check_mem_access(env, env->insn_idx, regs + insn->src_reg, insn->src_reg, insn->off,
+       err = check_mem_access(env, env->insn_idx, regs + insn->src_reg, argno_from_reg(insn->src_reg), insn->off,
                               BPF_SIZE(insn->code), BPF_READ, insn->dst_reg,
                               strict_alignment_once, is_ldsx);
        err = err ?: save_aux_ptr_type(env, src_reg_type,
@@ -6607,7 +6654,7 @@ static int check_store_reg(struct bpf_verifier_env *env, struct bpf_insn *insn,
        dst_reg_type = regs[insn->dst_reg].type;
 
        /* Check if (dst_reg + off) is writeable. */
-       err = check_mem_access(env, env->insn_idx, regs + insn->dst_reg, insn->dst_reg, insn->off,
+       err = check_mem_access(env, env->insn_idx, regs + insn->dst_reg, argno_from_reg(insn->dst_reg), insn->off,
                               BPF_SIZE(insn->code), BPF_WRITE, insn->src_reg,
                               strict_alignment_once, false);
        err = err ?: save_aux_ptr_type(env, dst_reg_type, false);
@@ -6685,10 +6732,10 @@ static int check_atomic_rmw(struct bpf_verifier_env *env,
        /* Check whether we can read the memory, with second call for fetch
         * case to simulate the register fill.
         */
-       err = check_mem_access(env, env->insn_idx, dst_reg, insn->dst_reg, insn->off,
+       err = check_mem_access(env, env->insn_idx, dst_reg, argno_from_reg(insn->dst_reg), insn->off,
                               BPF_SIZE(insn->code), BPF_READ, -1, true, false);
        if (!err && load_reg >= 0)
-               err = check_mem_access(env, env->insn_idx, dst_reg, insn->dst_reg,
+               err = check_mem_access(env, env->insn_idx, dst_reg, argno_from_reg(insn->dst_reg),
                                       insn->off, BPF_SIZE(insn->code),
                                       BPF_READ, load_reg, true, false);
        if (err)
@@ -6700,7 +6747,7 @@ static int check_atomic_rmw(struct bpf_verifier_env *env,
                        return err;
        }
        /* Check whether we can write into the same memory. */
-       err = check_mem_access(env, env->insn_idx, dst_reg, insn->dst_reg, insn->off,
+       err = check_mem_access(env, env->insn_idx, dst_reg, argno_from_reg(insn->dst_reg), insn->off,
                               BPF_SIZE(insn->code), BPF_WRITE, -1, true, false);
        if (err)
                return err;
@@ -6789,7 +6836,7 @@ static int check_atomic(struct bpf_verifier_env *env, struct bpf_insn *insn)
  * read offsets are marked as read.
  */
 static int check_stack_range_initialized(
-               struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno, int off,
+               struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno, int off,
                int access_size, bool zero_size_allowed,
                enum bpf_access_type type, struct bpf_call_arg_meta *meta)
 {
@@ -6814,7 +6861,7 @@ static int check_stack_range_initialized(
                return -EACCES;
        }
 
-       err = check_stack_access_within_bounds(env, reg, regno, off, access_size, type);
+       err = check_stack_access_within_bounds(env, reg, argno, off, access_size, type);
        if (err)
                return err;
 
@@ -6831,8 +6878,8 @@ static int check_stack_range_initialized(
                        char tn_buf[48];
 
                        tnum_strn(tn_buf, sizeof(tn_buf), reg->var_off);
-                       verbose(env, "R%d variable offset stack access prohibited for !root, var_off=%s\n",
-                               regno, tn_buf);
+                       verbose(env, "%s variable offset stack access prohibited for !root, var_off=%s\n",
+                               reg_arg_name(env, argno), tn_buf);
                        return -EACCES;
                }
                /* Only initialized buffer on stack is allowed to be accessed
@@ -6875,7 +6922,7 @@ static int check_stack_range_initialized(
                        }
                }
                meta->access_size = access_size;
-               meta->regno = regno;
+               meta->regno = reg_from_argno(argno);
                return 0;
        }
 
@@ -6915,17 +6962,17 @@ static int check_stack_range_initialized(
                if (*stype == STACK_POISON) {
                        if (allow_poison)
                                goto mark;
-                       verbose(env, "reading from stack R%d off %d+%d size %d, slot poisoned by dead code elimination\n",
-                               regno, min_off, i - min_off, access_size);
+                       verbose(env, "reading from stack %s off %d+%d size %d, slot poisoned by dead code elimination\n",
+                               reg_arg_name(env, argno), min_off, i - min_off, access_size);
                } else if (tnum_is_const(reg->var_off)) {
-                       verbose(env, "invalid read from stack R%d off %d+%d size %d\n",
-                               regno, min_off, i - min_off, access_size);
+                       verbose(env, "invalid read from stack %s off %d+%d size %d\n",
+                               reg_arg_name(env, argno), min_off, i - min_off, access_size);
                } else {
                        char tn_buf[48];
 
                        tnum_strn(tn_buf, sizeof(tn_buf), reg->var_off);
-                       verbose(env, "invalid read from stack R%d var_off %s+%d size %d\n",
-                               regno, tn_buf, i - min_off, access_size);
+                       verbose(env, "invalid read from stack %s var_off %s+%d size %d\n",
+                               reg_arg_name(env, argno), tn_buf, i - min_off, access_size);
                }
                return -EACCES;
 mark:
@@ -6934,7 +6981,7 @@ mark:
        return 0;
 }
 
-static int check_helper_mem_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno,
+static int check_helper_mem_access(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                                   int access_size, enum bpf_access_type access_type,
                                   bool zero_size_allowed,
                                   struct bpf_call_arg_meta *meta)
@@ -6945,37 +6992,37 @@ static int check_helper_mem_access(struct bpf_verifier_env *env, struct bpf_reg_
        switch (base_type(reg->type)) {
        case PTR_TO_PACKET:
        case PTR_TO_PACKET_META:
-               return check_packet_access(env, reg, regno, 0, access_size,
+               return check_packet_access(env, reg, argno, 0, access_size,
                                           zero_size_allowed);
        case PTR_TO_MAP_KEY:
                if (access_type == BPF_WRITE) {
-                       verbose(env, "R%d cannot write into %s\n", regno,
-                               reg_type_str(env, reg->type));
+                       verbose(env, "%s cannot write into %s\n",
+                               reg_arg_name(env, argno), reg_type_str(env, reg->type));
                        return -EACCES;
                }
-               return check_mem_region_access(env, reg, regno, 0, access_size,
+               return check_mem_region_access(env, reg, argno, 0, access_size,
                                               reg->map_ptr->key_size, false);
        case PTR_TO_MAP_VALUE:
                if (check_map_access_type(env, reg, 0, access_size, access_type))
                        return -EACCES;
-               return check_map_access(env, reg, regno, 0, access_size,
+               return check_map_access(env, reg, argno, 0, access_size,
                                        zero_size_allowed, ACCESS_HELPER);
        case PTR_TO_MEM:
                if (type_is_rdonly_mem(reg->type)) {
                        if (access_type == BPF_WRITE) {
-                               verbose(env, "R%d cannot write into %s\n", regno,
-                                       reg_type_str(env, reg->type));
+                               verbose(env, "%s cannot write into %s\n",
+                                       reg_arg_name(env, argno), reg_type_str(env, reg->type));
                                return -EACCES;
                        }
                }
-               return check_mem_region_access(env, reg, regno, 0,
+               return check_mem_region_access(env, reg, argno, 0,
                                               access_size, reg->mem_size,
                                               zero_size_allowed);
        case PTR_TO_BUF:
                if (type_is_rdonly_mem(reg->type)) {
                        if (access_type == BPF_WRITE) {
-                               verbose(env, "R%d cannot write into %s\n", regno,
-                                       reg_type_str(env, reg->type));
+                               verbose(env, "%s cannot write into %s\n",
+                                       reg_arg_name(env, argno), reg_type_str(env, reg->type));
                                return -EACCES;
                        }
 
@@ -6983,21 +7030,21 @@ static int check_helper_mem_access(struct bpf_verifier_env *env, struct bpf_reg_
                } else {
                        max_access = &env->prog->aux->max_rdwr_access;
                }
-               return check_buffer_access(env, reg, regno, 0,
+               return check_buffer_access(env, reg, argno, 0,
                                           access_size, zero_size_allowed,
                                           max_access);
        case PTR_TO_STACK:
                return check_stack_range_initialized(
                                env, reg,
-                               regno, 0, access_size,
+                               argno, 0, access_size,
                                zero_size_allowed, access_type, meta);
        case PTR_TO_BTF_ID:
-               return check_ptr_to_btf_access(env, regs, reg, regno, 0,
+               return check_ptr_to_btf_access(env, regs, reg, argno, 0,
                                               access_size, BPF_READ, -1);
        case PTR_TO_CTX:
                /* Only permit reading or writing syscall context using helper calls. */
                if (is_var_ctx_off_allowed(env->prog)) {
-                       int err = check_mem_region_access(env, reg, regno, 0, access_size, U16_MAX,
+                       int err = check_mem_region_access(env, reg, argno, 0, access_size, U16_MAX,
                                                          zero_size_allowed);
                        if (err)
                                return err;
@@ -7012,7 +7059,7 @@ static int check_helper_mem_access(struct bpf_verifier_env *env, struct bpf_reg_
                    bpf_register_is_null(reg))
                        return 0;
 
-               verbose(env, "R%d type=%s ", regno,
+               verbose(env, "%s type=%s ", reg_arg_name(env, argno),
                        reg_type_str(env, reg->type));
                verbose(env, "expected=%s\n", reg_type_str(env, PTR_TO_STACK));
                return -EACCES;
@@ -7026,8 +7073,8 @@ static int check_helper_mem_access(struct bpf_verifier_env *env, struct bpf_reg_
  */
 static int check_mem_size_reg(struct bpf_verifier_env *env,
                              struct bpf_reg_state *mem_reg,
-                             struct bpf_reg_state *size_reg, u32 mem_regno,
-                             u32 size_regno, enum bpf_access_type access_type,
+                             struct bpf_reg_state *size_reg, argno_t mem_argno,
+                             argno_t size_argno, enum bpf_access_type access_type,
                              bool zero_size_allowed,
                              struct bpf_call_arg_meta *meta)
 {
@@ -7052,31 +7099,31 @@ static int check_mem_size_reg(struct bpf_verifier_env *env,
                meta = NULL;
 
        if (size_reg->smin_value < 0) {
-               verbose(env, "R%d min value is negative, either use unsigned or 'var &= const'\n",
-                       size_regno);
+               verbose(env, "%s min value is negative, either use unsigned or 'var &= const'\n",
+                       reg_arg_name(env, size_argno));
                return -EACCES;
        }
 
        if (size_reg->umin_value == 0 && !zero_size_allowed) {
-               verbose(env, "R%d invalid zero-sized read: u64=[%lld,%lld]\n",
-                       size_regno, size_reg->umin_value, size_reg->umax_value);
+               verbose(env, "%s invalid zero-sized read: u64=[%lld,%lld]\n",
+                       reg_arg_name(env, size_argno), size_reg->umin_value, size_reg->umax_value);
                return -EACCES;
        }
 
        if (size_reg->umax_value >= BPF_MAX_VAR_SIZ) {
-               verbose(env, "R%d unbounded memory access, use 'var &= const' or 'if (var < const)'\n",
-                       size_regno);
+               verbose(env, "%s unbounded memory access, use 'var &= const' or 'if (var < const)'\n",
+                       reg_arg_name(env, size_argno));
                return -EACCES;
        }
-       err = check_helper_mem_access(env, mem_reg, mem_regno, size_reg->umax_value,
+       err = check_helper_mem_access(env, mem_reg, mem_argno, size_reg->umax_value,
                                      access_type, zero_size_allowed, meta);
        if (!err)
-               err = mark_chain_precision(env, size_regno);
+               err = mark_chain_precision(env, reg_from_argno(size_argno));
        return err;
 }
 
 static int check_mem_reg(struct bpf_verifier_env *env, struct bpf_reg_state *reg,
-                        u32 regno, u32 mem_size)
+                        argno_t argno, u32 mem_size)
 {
        bool may_be_null = type_may_be_null(reg->type);
        struct bpf_reg_state saved_reg;
@@ -7096,8 +7143,8 @@ static int check_mem_reg(struct bpf_verifier_env *env, struct bpf_reg_state *reg
 
        int size = base_type(reg->type) == PTR_TO_STACK ? -(int)mem_size : mem_size;
 
-       err = check_helper_mem_access(env, reg, regno, size, BPF_READ, true, NULL);
-       err = err ?: check_helper_mem_access(env, reg, regno, size, BPF_WRITE, true, NULL);
+       err = check_helper_mem_access(env, reg, argno, size, BPF_READ, true, NULL);
+       err = err ?: check_helper_mem_access(env, reg, argno, size, BPF_WRITE, true, NULL);
 
        if (may_be_null)
                *reg = saved_reg;
@@ -7106,7 +7153,7 @@ static int check_mem_reg(struct bpf_verifier_env *env, struct bpf_reg_state *reg
 }
 
 static int check_kfunc_mem_size_reg(struct bpf_verifier_env *env, struct bpf_reg_state *mem_reg,
-                                   struct bpf_reg_state *size_reg, u32 mem_regno, u32 size_regno)
+                                   struct bpf_reg_state *size_reg, argno_t mem_argno, argno_t size_argno)
 {
        bool may_be_null = type_may_be_null(mem_reg->type);
        struct bpf_reg_state saved_reg;
@@ -7120,8 +7167,8 @@ static int check_kfunc_mem_size_reg(struct bpf_verifier_env *env, struct bpf_reg
                mark_ptr_not_null_reg(mem_reg);
        }
 
-       err = check_mem_size_reg(env, mem_reg, size_reg, mem_regno, size_regno, BPF_READ, true, &meta);
-       err = err ?: check_mem_size_reg(env, mem_reg, size_reg, mem_regno, size_regno, BPF_WRITE, true, &meta);
+       err = check_mem_size_reg(env, mem_reg, size_reg, mem_argno, size_argno, BPF_READ, true, &meta);
+       err = err ?: check_mem_size_reg(env, mem_reg, size_reg, mem_argno, size_argno, BPF_WRITE, true, &meta);
 
        if (may_be_null)
                *mem_reg = saved_reg;
@@ -7157,7 +7204,7 @@ enum {
  * env->cur_state->active_locks remembers which map value element or allocated
  * object got locked and clears it after bpf_spin_unlock.
  */
-static int process_spin_lock(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno, int flags)
+static int process_spin_lock(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno, int flags)
 {
        bool is_lock = flags & PROCESS_SPIN_LOCK, is_res_lock = flags & PROCESS_RES_LOCK;
        const char *lock_str = is_res_lock ? "bpf_res_spin" : "bpf_spin";
@@ -7173,8 +7220,8 @@ static int process_spin_lock(struct bpf_verifier_env *env, struct bpf_reg_state
 
        if (!is_const) {
                verbose(env,
-                       "R%d doesn't have constant offset. %s_lock has to be at the constant offset\n",
-                       regno, lock_str);
+                       "%s doesn't have constant offset. %s_lock has to be at the constant offset\n",
+                       reg_arg_name(env, argno), lock_str);
                return -EINVAL;
        }
        if (reg->type == PTR_TO_MAP_VALUE) {
@@ -7273,7 +7320,7 @@ static int process_spin_lock(struct bpf_verifier_env *env, struct bpf_reg_state
 }
 
 /* Check if @regno is a pointer to a specific field in a map value */
-static int check_map_field_pointer(struct bpf_verifier_env *env, struct bpf_reg_state *reg, u32 regno,
+static int check_map_field_pointer(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                                   enum btf_field_type field_type,
                                   struct bpf_map_desc *map_desc)
 {
@@ -7285,8 +7332,8 @@ static int check_map_field_pointer(struct bpf_verifier_env *env, struct bpf_reg_
 
        if (!is_const) {
                verbose(env,
-                       "R%d doesn't have constant offset. %s has to be at the constant offset\n",
-                       regno, struct_name);
+                       "%s doesn't have constant offset. %s has to be at the constant offset\n",
+                       reg_arg_name(env, argno), struct_name);
                return -EINVAL;
        }
        if (!map->btf) {
@@ -7326,26 +7373,26 @@ static int check_map_field_pointer(struct bpf_verifier_env *env, struct bpf_reg_
        return 0;
 }
 
-static int process_timer_func(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno,
+static int process_timer_func(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                              struct bpf_map_desc *map)
 {
        if (IS_ENABLED(CONFIG_PREEMPT_RT)) {
                verbose(env, "bpf_timer cannot be used for PREEMPT_RT.\n");
                return -EOPNOTSUPP;
        }
-       return check_map_field_pointer(env, reg, regno, BPF_TIMER, map);
+       return check_map_field_pointer(env, reg, argno, BPF_TIMER, map);
 }
 
-static int process_timer_helper(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno,
+static int process_timer_helper(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                                struct bpf_call_arg_meta *meta)
 {
-       return process_timer_func(env, reg, regno, &meta->map);
+       return process_timer_func(env, reg, argno, &meta->map);
 }
 
-static int process_timer_kfunc(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno,
+static int process_timer_kfunc(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                               struct bpf_kfunc_call_arg_meta *meta)
 {
-       return process_timer_func(env, reg, regno, &meta->map);
+       return process_timer_func(env, reg, argno, &meta->map);
 }
 
 static int process_kptr_func(struct bpf_verifier_env *env, int regno,
@@ -7410,15 +7457,15 @@ static int process_kptr_func(struct bpf_verifier_env *env, int regno,
  * use case. The second level is tracked using the upper bit of bpf_dynptr->size
  * and checked dynamically during runtime.
  */
-static int process_dynptr_func(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno, int insn_idx,
+static int process_dynptr_func(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno, int insn_idx,
                               enum bpf_arg_type arg_type, int clone_ref_obj_id)
 {
        int err;
 
        if (reg->type != PTR_TO_STACK && reg->type != CONST_PTR_TO_DYNPTR) {
                verbose(env,
-                       "arg#%d expected pointer to stack or const struct bpf_dynptr\n",
-                       regno - 1);
+                       "%s expected pointer to stack or const struct bpf_dynptr\n",
+                       reg_arg_name(env, argno));
                return -EINVAL;
        }
 
@@ -7446,7 +7493,7 @@ static int process_dynptr_func(struct bpf_verifier_env *env, struct bpf_reg_stat
 
                /* we write BPF_DW bits (8 bytes) at a time */
                for (i = 0; i < BPF_DYNPTR_SIZE; i += 8) {
-                       err = check_mem_access(env, insn_idx, reg, regno,
+                       err = check_mem_access(env, insn_idx, reg, argno,
                                               i, BPF_DW, BPF_WRITE, -1, false, false);
                        if (err)
                                return err;
@@ -7461,17 +7508,17 @@ static int process_dynptr_func(struct bpf_verifier_env *env, struct bpf_reg_stat
                }
 
                if (!is_dynptr_reg_valid_init(env, reg)) {
-                       verbose(env,
-                               "Expected an initialized dynptr as arg #%d\n",
-                               regno - 1);
+                       verbose(env, "Expected an initialized dynptr as %s\n",
+                               reg_arg_name(env, argno));
                        return -EINVAL;
                }
 
                /* Fold modifiers (in this case, OBJ_RELEASE) when checking expected type */
                if (!is_dynptr_type_expected(env, reg, arg_type & ~OBJ_RELEASE)) {
                        verbose(env,
-                               "Expected a dynptr of type %s as arg #%d\n",
-                               dynptr_type_str(arg_to_dynptr_type(arg_type)), regno - 1);
+                               "Expected a dynptr of type %s as %s\n",
+                               dynptr_type_str(arg_to_dynptr_type(arg_type)),
+                               reg_arg_name(env, argno));
                        return -EINVAL;
                }
 
@@ -7516,14 +7563,16 @@ static bool is_kfunc_arg_iter(struct bpf_kfunc_call_arg_meta *meta, int arg_idx,
        return btf_param_match_suffix(meta->btf, arg, "__iter");
 }
 
-static int process_iter_arg(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno, int insn_idx,
+static int process_iter_arg(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno, int insn_idx,
                            struct bpf_kfunc_call_arg_meta *meta)
 {
        const struct btf_type *t;
+       u32 arg_idx = arg_from_argno(argno) - 1;
        int spi, err, i, nr_slots, btf_id;
 
        if (reg->type != PTR_TO_STACK) {
-               verbose(env, "arg#%d expected pointer to an iterator on stack\n", regno - 1);
+               verbose(env, "%s expected pointer to an iterator on stack\n",
+                       reg_arg_name(env, argno));
                return -EINVAL;
        }
 
@@ -7533,9 +7582,10 @@ static int process_iter_arg(struct bpf_verifier_env *env, struct bpf_reg_state *
         * to any kfunc, if arg has "__iter" suffix, we need to be a bit more
         * conservative here.
         */
-       btf_id = btf_check_iter_arg(meta->btf, meta->func_proto, regno - 1);
+       btf_id = btf_check_iter_arg(meta->btf, meta->func_proto, arg_idx);
        if (btf_id < 0) {
-               verbose(env, "expected valid iter pointer as arg #%d\n", regno - 1);
+               verbose(env, "expected valid iter pointer as %s\n",
+                       reg_arg_name(env, argno));
                return -EINVAL;
        }
        t = btf_type_by_id(meta->btf, btf_id);
@@ -7544,13 +7594,13 @@ static int process_iter_arg(struct bpf_verifier_env *env, struct bpf_reg_state *
        if (is_iter_new_kfunc(meta)) {
                /* bpf_iter_<type>_new() expects pointer to uninit iter state */
                if (!is_iter_reg_valid_uninit(env, reg, nr_slots)) {
-                       verbose(env, "expected uninitialized iter_%s as arg #%d\n",
-                               iter_type_str(meta->btf, btf_id), regno - 1);
+                       verbose(env, "expected uninitialized iter_%s as %s\n",
+                               iter_type_str(meta->btf, btf_id), reg_arg_name(env, argno));
                        return -EINVAL;
                }
 
                for (i = 0; i < nr_slots * 8; i += BPF_REG_SIZE) {
-                       err = check_mem_access(env, insn_idx, reg, regno,
+                       err = check_mem_access(env, insn_idx, reg, argno,
                                               i, BPF_DW, BPF_WRITE, -1, false, false);
                        if (err)
                                return err;
@@ -7568,8 +7618,8 @@ static int process_iter_arg(struct bpf_verifier_env *env, struct bpf_reg_state *
                case 0:
                        break;
                case -EINVAL:
-                       verbose(env, "expected an initialized iter_%s as arg #%d\n",
-                               iter_type_str(meta->btf, btf_id), regno - 1);
+                       verbose(env, "expected an initialized iter_%s as %s\n",
+                               iter_type_str(meta->btf, btf_id), reg_arg_name(env, argno));
                        return err;
                case -EPROTO:
                        verbose(env, "expected an RCU CS when using %s\n", meta->func_name);
@@ -7989,7 +8039,7 @@ static const struct bpf_reg_types *compatible_reg_types[__BPF_ARG_TYPE_MAX] = {
        [ARG_PTR_TO_DYNPTR]             = &dynptr_types,
 };
 
-static int check_reg_type(struct bpf_verifier_env *env, struct bpf_reg_state *reg, u32 regno,
+static int check_reg_type(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                          enum bpf_arg_type arg_type,
                          const u32 *arg_btf_id,
                          struct bpf_call_arg_meta *meta)
@@ -8024,7 +8074,7 @@ static int check_reg_type(struct bpf_verifier_env *env, struct bpf_reg_state *re
                type &= ~DYNPTR_TYPE_FLAG_MASK;
 
        /* Local kptr types are allowed as the source argument of bpf_kptr_xchg */
-       if (meta->func_id == BPF_FUNC_kptr_xchg && type_is_alloc(type) && regno == BPF_REG_2) {
+       if (meta->func_id == BPF_FUNC_kptr_xchg && type_is_alloc(type) && reg_from_argno(argno) == BPF_REG_2) {
                type &= ~MEM_ALLOC;
                type &= ~MEM_PERCPU;
        }
@@ -8038,7 +8088,7 @@ static int check_reg_type(struct bpf_verifier_env *env, struct bpf_reg_state *re
                        goto found;
        }
 
-       verbose(env, "R%d type=%s expected=", regno, reg_type_str(env, reg->type));
+       verbose(env, "%s type=%s expected=", reg_arg_name(env, argno), reg_type_str(env, reg->type));
        for (j = 0; j + 1 < i; j++)
                verbose(env, "%s, ", reg_type_str(env, compatible->types[j]));
        verbose(env, "%s\n", reg_type_str(env, compatible->types[j]));
@@ -8051,9 +8101,9 @@ found:
        if (compatible == &mem_types) {
                if (!(arg_type & MEM_RDONLY)) {
                        verbose(env,
-                               "%s() may write into memory pointed by R%d type=%s\n",
+                               "%s() may write into memory pointed by %s type=%s\n",
                                func_id_name(meta->func_id),
-                               regno, reg_type_str(env, reg->type));
+                               reg_arg_name(env, argno), reg_type_str(env, reg->type));
                        return -EACCES;
                }
                return 0;
@@ -8076,7 +8126,8 @@ found:
 
                if (type_may_be_null(reg->type) &&
                    (!type_may_be_null(arg_type) || arg_type_is_release(arg_type))) {
-                       verbose(env, "Possibly NULL pointer passed to helper arg%d\n", regno);
+                       verbose(env, "Possibly NULL pointer passed to helper %s\n",
+                               reg_arg_name(env, argno));
                        return -EACCES;
                }
 
@@ -8089,25 +8140,26 @@ found:
                }
 
                if (meta->func_id == BPF_FUNC_kptr_xchg) {
-                       if (map_kptr_match_type(env, meta->kptr_field, reg, regno))
+                       if (map_kptr_match_type(env, meta->kptr_field, reg, reg_from_argno(argno)))
                                return -EACCES;
                } else {
                        if (arg_btf_id == BPF_PTR_POISON) {
                                verbose(env, "verifier internal error:");
-                               verbose(env, "R%d has non-overwritten BPF_PTR_POISON type\n",
-                                       regno);
+                               verbose(env, "%s has non-overwritten BPF_PTR_POISON type\n",
+                                       reg_arg_name(env, argno));
                                return -EACCES;
                        }
 
-                       err = __check_ptr_off_reg(env, reg, regno, true);
+                       err = __check_ptr_off_reg(env, reg, argno, true);
                        if (err)
                                return err;
 
                        if (!btf_struct_ids_match(&env->log, reg->btf, reg->btf_id,
                                                  reg->var_off.value, btf_vmlinux, *arg_btf_id,
                                                  strict_type_match)) {
-                               verbose(env, "R%d is of type %s but %s is expected\n",
-                                       regno, btf_type_name(reg->btf, reg->btf_id),
+                               verbose(env, "%s is of type %s but %s is expected\n",
+                                       reg_arg_name(env, argno),
+                                       btf_type_name(reg->btf, reg->btf_id),
                                        btf_type_name(btf_vmlinux, *arg_btf_id));
                                return -EACCES;
                        }
@@ -8124,8 +8176,11 @@ found:
                        return -EFAULT;
                }
                /* Check if local kptr in src arg matches kptr in dst arg */
-               if (meta->func_id == BPF_FUNC_kptr_xchg && regno == BPF_REG_2) {
-                       if (map_kptr_match_type(env, meta->kptr_field, reg, regno))
+               if (meta->func_id == BPF_FUNC_kptr_xchg) {
+                       int regno = reg_from_argno(argno);
+
+                       if (regno == BPF_REG_2 &&
+                           map_kptr_match_type(env, meta->kptr_field, reg, regno))
                                return -EACCES;
                }
                break;
@@ -8159,7 +8214,7 @@ reg_find_field_offset(const struct bpf_reg_state *reg, s32 off, u32 fields)
 }
 
 static int check_func_arg_reg_off(struct bpf_verifier_env *env,
-                                 const struct bpf_reg_state *reg, int regno,
+                                 const struct bpf_reg_state *reg, argno_t argno,
                                  enum bpf_arg_type arg_type)
 {
        u32 type = reg->type;
@@ -8185,8 +8240,8 @@ static int check_func_arg_reg_off(struct bpf_verifier_env *env,
                 * to give the user a better error message.
                 */
                if (!tnum_is_const(reg->var_off) || reg->var_off.value != 0) {
-                       verbose(env, "R%d must have zero offset when passed to release func or trusted arg to kfunc\n",
-                               regno);
+                       verbose(env, "%s must have zero offset when passed to release func or trusted arg to kfunc\n",
+                               reg_arg_name(env, argno));
                        return -EINVAL;
                }
        }
@@ -8222,7 +8277,7 @@ static int check_func_arg_reg_off(struct bpf_verifier_env *env,
                 * cases. var_off always must be 0 for PTR_TO_BTF_ID, hence we
                 * still need to do checks instead of returning.
                 */
-               return __check_ptr_off_reg(env, reg, regno, true);
+               return __check_ptr_off_reg(env, reg, argno, true);
        case PTR_TO_CTX:
                /*
                 * Allow fixed and variable offsets for syscall context, but
@@ -8234,7 +8289,7 @@ static int check_func_arg_reg_off(struct bpf_verifier_env *env,
                        return 0;
                fallthrough;
        default:
-               return __check_ptr_off_reg(env, reg, regno, false);
+               return __check_ptr_off_reg(env, reg, argno, false);
        }
 }
 
@@ -8304,8 +8359,8 @@ static enum bpf_dynptr_type dynptr_get_type(struct bpf_verifier_env *env,
        return state->stack[spi].spilled_ptr.dynptr.type;
 }
 
-static int check_reg_const_str(struct bpf_verifier_env *env,
-                              struct bpf_reg_state *reg, u32 regno)
+static int check_arg_const_str(struct bpf_verifier_env *env,
+                              struct bpf_reg_state *reg, argno_t argno)
 {
        struct bpf_map *map = reg->map_ptr;
        int err;
@@ -8317,17 +8372,18 @@ static int check_reg_const_str(struct bpf_verifier_env *env,
                return -EINVAL;
 
        if (map->map_type == BPF_MAP_TYPE_INSN_ARRAY) {
-               verbose(env, "R%d points to insn_array map which cannot be used as const string\n", regno);
+               verbose(env, "%s points to insn_array map which cannot be used as const string\n",
+                       reg_arg_name(env, argno));
                return -EACCES;
        }
 
        if (!bpf_map_is_rdonly(map)) {
-               verbose(env, "R%d does not point to a readonly map'\n", regno);
+               verbose(env, "%s does not point to a readonly map'\n", reg_arg_name(env, argno));
                return -EACCES;
        }
 
        if (!tnum_is_const(reg->var_off)) {
-               verbose(env, "R%d is not a constant address'\n", regno);
+               verbose(env, "%s is not a constant address'\n", reg_arg_name(env, argno));
                return -EACCES;
        }
 
@@ -8336,7 +8392,7 @@ static int check_reg_const_str(struct bpf_verifier_env *env,
                return -EACCES;
        }
 
-       err = check_map_access(env, reg, regno, 0,
+       err = check_map_access(env, reg, argno, 0,
                               map->value_size - reg->var_off.value, false,
                               ACCESS_HELPER);
        if (err)
@@ -8472,11 +8528,11 @@ static int check_func_arg(struct bpf_verifier_env *env, u32 arg,
            base_type(arg_type) == ARG_PTR_TO_SPIN_LOCK)
                arg_btf_id = fn->arg_btf_id[arg];
 
-       err = check_reg_type(env, reg, regno, arg_type, arg_btf_id, meta);
+       err = check_reg_type(env, reg, argno_from_reg(regno), arg_type, arg_btf_id, meta);
        if (err)
                return err;
 
-       err = check_func_arg_reg_off(env, reg, regno, arg_type);
+       err = check_func_arg_reg_off(env, reg, argno_from_reg(regno), arg_type);
        if (err)
                return err;
 
@@ -8565,7 +8621,7 @@ skip_type_check:
                        return -EFAULT;
                }
                key_size = meta->map.ptr->key_size;
-               err = check_helper_mem_access(env, reg, regno, key_size, BPF_READ, false, NULL);
+               err = check_helper_mem_access(env, reg, argno_from_reg(regno), key_size, BPF_READ, false, NULL);
                if (err)
                        return err;
                if (can_elide_value_nullness(meta->map.ptr->map_type)) {
@@ -8592,7 +8648,7 @@ skip_type_check:
                        return -EFAULT;
                }
                meta->raw_mode = arg_type & MEM_UNINIT;
-               err = check_helper_mem_access(env, reg, regno, meta->map.ptr->value_size,
+               err = check_helper_mem_access(env, reg, argno_from_reg(regno), meta->map.ptr->value_size,
                                              arg_type & MEM_WRITE ? BPF_WRITE : BPF_READ,
                                              false, meta);
                break;
@@ -8610,11 +8666,11 @@ skip_type_check:
                        return -EACCES;
                }
                if (meta->func_id == BPF_FUNC_spin_lock) {
-                       err = process_spin_lock(env, reg, regno, PROCESS_SPIN_LOCK);
+                       err = process_spin_lock(env, reg, argno_from_reg(regno), PROCESS_SPIN_LOCK);
                        if (err)
                                return err;
                } else if (meta->func_id == BPF_FUNC_spin_unlock) {
-                       err = process_spin_lock(env, reg, regno, 0);
+                       err = process_spin_lock(env, reg, argno_from_reg(regno), 0);
                        if (err)
                                return err;
                } else {
@@ -8623,7 +8679,7 @@ skip_type_check:
                }
                break;
        case ARG_PTR_TO_TIMER:
-               err = process_timer_helper(env, reg, regno, meta);
+               err = process_timer_helper(env, reg, argno_from_reg(regno), meta);
                if (err)
                        return err;
                break;
@@ -8636,7 +8692,7 @@ skip_type_check:
                 */
                meta->raw_mode = arg_type & MEM_UNINIT;
                if (arg_type & MEM_FIXED_SIZE) {
-                       err = check_helper_mem_access(env, reg, regno, fn->arg_size[arg],
+                       err = check_helper_mem_access(env, reg, argno_from_reg(regno), fn->arg_size[arg],
                                                      arg_type & MEM_WRITE ? BPF_WRITE : BPF_READ,
                                                      false, meta);
                        if (err)
@@ -8646,19 +8702,21 @@ skip_type_check:
                }
                break;
        case ARG_CONST_SIZE:
-               err = check_mem_size_reg(env, reg_state(env, regno - 1), reg, regno - 1, regno,
+               err = check_mem_size_reg(env, reg_state(env, regno - 1), reg, argno_from_reg(regno - 1),
+                                        argno_from_reg(regno),
                                         fn->arg_type[arg - 1] & MEM_WRITE ?
                                         BPF_WRITE : BPF_READ,
                                         false, meta);
                break;
        case ARG_CONST_SIZE_OR_ZERO:
-               err = check_mem_size_reg(env, reg_state(env, regno - 1), reg, regno - 1, regno,
+               err = check_mem_size_reg(env, reg_state(env, regno - 1), reg, argno_from_reg(regno - 1),
+                                        argno_from_reg(regno),
                                         fn->arg_type[arg - 1] & MEM_WRITE ?
                                         BPF_WRITE : BPF_READ,
                                         true, meta);
                break;
        case ARG_PTR_TO_DYNPTR:
-               err = process_dynptr_func(env, reg, regno, insn_idx, arg_type, 0);
+               err = process_dynptr_func(env, reg, argno_from_reg(regno), insn_idx, arg_type, 0);
                if (err)
                        return err;
                break;
@@ -8675,7 +8733,7 @@ skip_type_check:
                break;
        case ARG_PTR_TO_CONST_STR:
        {
-               err = check_reg_const_str(env, reg, regno);
+               err = check_arg_const_str(env, reg, argno_from_reg(regno));
                if (err)
                        return err;
                break;
@@ -9264,13 +9322,14 @@ static int btf_check_func_arg_match(struct bpf_verifier_env *env, int subprog,
         * verifier sees.
         */
        for (i = 0; i < sub->arg_cnt; i++) {
+               argno_t argno = argno_from_arg(i + 1);
                u32 regno = i + 1;
                struct bpf_reg_state *reg = &regs[regno];
                struct bpf_subprog_arg_info *arg = &sub->args[i];
 
                if (arg->arg_type == ARG_ANYTHING) {
                        if (reg->type != SCALAR_VALUE) {
-                               bpf_log(log, "R%d is not a scalar\n", regno);
+                               bpf_log(log, "%s is not a scalar\n", reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                } else if (arg->arg_type & PTR_UNTRUSTED) {
@@ -9280,24 +9339,26 @@ static int btf_check_func_arg_match(struct bpf_verifier_env *env, int subprog,
                         * invalid memory access.
                         */
                } else if (arg->arg_type == ARG_PTR_TO_CTX) {
-                       ret = check_func_arg_reg_off(env, reg, regno, ARG_PTR_TO_CTX);
+                       ret = check_func_arg_reg_off(env, reg, argno, ARG_PTR_TO_CTX);
                        if (ret < 0)
                                return ret;
                        /* If function expects ctx type in BTF check that caller
                         * is passing PTR_TO_CTX.
                         */
                        if (reg->type != PTR_TO_CTX) {
-                               bpf_log(log, "arg#%d expects pointer to ctx\n", i);
+                               bpf_log(log, "%s expects pointer to ctx\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                } else if (base_type(arg->arg_type) == ARG_PTR_TO_MEM) {
-                       ret = check_func_arg_reg_off(env, reg, regno, ARG_DONTCARE);
+                       ret = check_func_arg_reg_off(env, reg, argno, ARG_DONTCARE);
                        if (ret < 0)
                                return ret;
-                       if (check_mem_reg(env, reg, regno, arg->mem_size))
+                       if (check_mem_reg(env, reg, argno, arg->mem_size))
                                return -EINVAL;
                        if (!(arg->arg_type & PTR_MAYBE_NULL) && (reg->type & PTR_MAYBE_NULL)) {
-                               bpf_log(log, "arg#%d is expected to be non-NULL\n", i);
+                               bpf_log(log, "%s is expected to be non-NULL\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                } else if (base_type(arg->arg_type) == ARG_PTR_TO_ARENA) {
@@ -9309,15 +9370,16 @@ static int btf_check_func_arg_match(struct bpf_verifier_env *env, int subprog,
                         * run-time debug nightmare.
                         */
                        if (reg->type != PTR_TO_ARENA && reg->type != SCALAR_VALUE) {
-                               bpf_log(log, "R%d is not a pointer to arena or scalar.\n", regno);
+                               bpf_log(log, "%s is not a pointer to arena or scalar.\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                } else if (arg->arg_type == ARG_PTR_TO_DYNPTR) {
-                       ret = check_func_arg_reg_off(env, reg, regno, ARG_PTR_TO_DYNPTR);
+                       ret = check_func_arg_reg_off(env, reg, argno, ARG_PTR_TO_DYNPTR);
                        if (ret)
                                return ret;
 
-                       ret = process_dynptr_func(env, reg, regno, -1, arg->arg_type, 0);
+                       ret = process_dynptr_func(env, reg, argno, -1, arg->arg_type, 0);
                        if (ret)
                                return ret;
                } else if (base_type(arg->arg_type) == ARG_PTR_TO_BTF_ID) {
@@ -9328,12 +9390,13 @@ static int btf_check_func_arg_match(struct bpf_verifier_env *env, int subprog,
                                continue;
 
                        memset(&meta, 0, sizeof(meta)); /* leave func_id as zero */
-                       err = check_reg_type(env, reg, regno, arg->arg_type, &arg->btf_id, &meta);
-                       err = err ?: check_func_arg_reg_off(env, reg, regno, arg->arg_type);
+                       err = check_reg_type(env, reg, argno, arg->arg_type, &arg->btf_id, &meta);
+                       err = err ?: check_func_arg_reg_off(env, reg, argno, arg->arg_type);
                        if (err)
                                return err;
                } else {
-                       verifier_bug(env, "unrecognized arg#%d type %d", i, arg->arg_type);
+                       verifier_bug(env, "unrecognized %s type %d",
+                                    reg_arg_name(env, argno), arg->arg_type);
                        return -EFAULT;
                }
        }
@@ -10292,7 +10355,7 @@ static int check_helper_call(struct bpf_verifier_env *env, struct bpf_insn *insn
         * is inferred from register state.
         */
        for (i = 0; i < meta.access_size; i++) {
-               err = check_mem_access(env, insn_idx, regs + meta.regno, meta.regno, i, BPF_B,
+               err = check_mem_access(env, insn_idx, regs + meta.regno, argno_from_reg(meta.regno), i, BPF_B,
                                       BPF_WRITE, -1, false, false);
                if (err)
                        return err;
@@ -11301,7 +11364,7 @@ get_kfunc_ptr_arg_type(struct bpf_verifier_env *env,
                       struct bpf_kfunc_call_arg_meta *meta,
                       const struct btf_type *t, const struct btf_type *ref_t,
                       const char *ref_tname, const struct btf_param *args,
-                      int arg, int nargs, struct bpf_reg_state *reg)
+                      int arg, int nargs, argno_t argno, struct bpf_reg_state *reg)
 {
        u32 regno = arg + 1;
        struct bpf_reg_state *regs = cur_regs(env);
@@ -11376,8 +11439,9 @@ get_kfunc_ptr_arg_type(struct bpf_verifier_env *env,
 
        if ((base_type(reg->type) == PTR_TO_BTF_ID || reg2btf_ids[base_type(reg->type)])) {
                if (!btf_type_is_struct(ref_t)) {
-                       verbose(env, "kernel function %s args#%d pointer type %s %s is not supported\n",
-                               meta->func_name, arg, btf_type_str(ref_t), ref_tname);
+                       verbose(env, "kernel function %s %s pointer type %s %s is not supported\n",
+                               meta->func_name, reg_arg_name(env, argno),
+                               btf_type_str(ref_t), ref_tname);
                        return -EINVAL;
                }
                return KF_ARG_PTR_TO_BTF_ID;
@@ -11393,8 +11457,9 @@ get_kfunc_ptr_arg_type(struct bpf_verifier_env *env,
         */
        if (!btf_type_is_scalar(ref_t) && !__btf_type_is_scalar_struct(env, meta->btf, ref_t, 0) &&
            (arg_mem_size ? !btf_type_is_void(ref_t) : 1)) {
-               verbose(env, "arg#%d pointer type %s %s must point to %sscalar, or struct with scalar\n",
-                       arg, btf_type_str(ref_t), ref_tname, arg_mem_size ? "void, " : "");
+               verbose(env, "%s pointer type %s %s must point to %sscalar, or struct with scalar\n",
+                       reg_arg_name(env, argno),
+                       btf_type_str(ref_t), ref_tname, arg_mem_size ? "void, " : "");
                return -EINVAL;
        }
        return arg_mem_size ? KF_ARG_PTR_TO_MEM_SIZE : KF_ARG_PTR_TO_MEM;
@@ -11405,7 +11470,7 @@ static int process_kf_arg_ptr_to_btf_id(struct bpf_verifier_env *env,
                                        const struct btf_type *ref_t,
                                        const char *ref_tname, u32 ref_id,
                                        struct bpf_kfunc_call_arg_meta *meta,
-                                       int arg)
+                                       int arg, argno_t argno)
 {
        const struct btf_type *reg_ref_t;
        bool strict_type_match = false;
@@ -11463,15 +11528,16 @@ static int process_kf_arg_ptr_to_btf_id(struct bpf_verifier_env *env,
         */
        taking_projection = btf_is_projection_of(ref_tname, reg_ref_tname);
        if (!taking_projection && !struct_same) {
-               verbose(env, "kernel function %s args#%d expected pointer to %s %s but R%d has a pointer to %s %s\n",
-                       meta->func_name, arg, btf_type_str(ref_t), ref_tname, arg + 1,
+               verbose(env, "kernel function %s %s expected pointer to %s %s but %s has a pointer to %s %s\n",
+                       meta->func_name, reg_arg_name(env, argno),
+                       btf_type_str(ref_t), ref_tname, reg_arg_name(env, argno),
                        btf_type_str(reg_ref_t), reg_ref_tname);
                return -EINVAL;
        }
        return 0;
 }
 
-static int process_irq_flag(struct bpf_verifier_env *env, struct bpf_reg_state *reg, int regno,
+static int process_irq_flag(struct bpf_verifier_env *env, struct bpf_reg_state *reg, argno_t argno,
                             struct bpf_kfunc_call_arg_meta *meta)
 {
        int err, kfunc_class = IRQ_NATIVE_KFUNC;
@@ -11494,11 +11560,13 @@ static int process_irq_flag(struct bpf_verifier_env *env, struct bpf_reg_state *
 
        if (irq_save) {
                if (!is_irq_flag_reg_valid_uninit(env, reg)) {
-                       verbose(env, "expected uninitialized irq flag as arg#%d\n", regno - 1);
+                       verbose(env, "expected uninitialized irq flag as %s\n",
+                               reg_arg_name(env, argno));
                        return -EINVAL;
                }
 
-               err = check_mem_access(env, env->insn_idx, reg, regno, 0, BPF_DW, BPF_WRITE, -1, false, false);
+               err = check_mem_access(env, env->insn_idx, reg, argno, 0, BPF_DW,
+                                      BPF_WRITE, -1, false, false);
                if (err)
                        return err;
 
@@ -11508,7 +11576,8 @@ static int process_irq_flag(struct bpf_verifier_env *env, struct bpf_reg_state *
        } else {
                err = is_irq_flag_reg_valid_init(env, reg);
                if (err) {
-                       verbose(env, "expected an initialized irq flag as arg#%d\n", regno - 1);
+                       verbose(env, "expected an initialized irq flag as %s\n",
+                               reg_arg_name(env, argno));
                        return err;
                }
 
@@ -11799,7 +11868,7 @@ static bool check_kfunc_is_graph_node_api(struct bpf_verifier_env *env,
 
 static int
 __process_kf_arg_ptr_to_graph_root(struct bpf_verifier_env *env,
-                                  struct bpf_reg_state *reg, u32 regno,
+                                  struct bpf_reg_state *reg, argno_t argno,
                                   struct bpf_kfunc_call_arg_meta *meta,
                                   enum btf_field_type head_field_type,
                                   struct btf_field **head_field)
@@ -11820,8 +11889,8 @@ __process_kf_arg_ptr_to_graph_root(struct bpf_verifier_env *env,
        head_type_name = btf_field_type_name(head_field_type);
        if (!tnum_is_const(reg->var_off)) {
                verbose(env,
-                       "R%d doesn't have constant offset. %s has to be at the constant offset\n",
-                       regno, head_type_name);
+                       "%s doesn't have constant offset. %s has to be at the constant offset\n",
+                       reg_arg_name(env, argno), head_type_name);
                return -EINVAL;
        }
 
@@ -11849,24 +11918,24 @@ __process_kf_arg_ptr_to_graph_root(struct bpf_verifier_env *env,
 }
 
 static int process_kf_arg_ptr_to_list_head(struct bpf_verifier_env *env,
-                                          struct bpf_reg_state *reg, u32 regno,
+                                          struct bpf_reg_state *reg, argno_t argno,
                                           struct bpf_kfunc_call_arg_meta *meta)
 {
-       return __process_kf_arg_ptr_to_graph_root(env, reg, regno, meta, BPF_LIST_HEAD,
+       return __process_kf_arg_ptr_to_graph_root(env, reg, argno, meta, BPF_LIST_HEAD,
                                                          &meta->arg_list_head.field);
 }
 
 static int process_kf_arg_ptr_to_rbtree_root(struct bpf_verifier_env *env,
-                                            struct bpf_reg_state *reg, u32 regno,
+                                            struct bpf_reg_state *reg, argno_t argno,
                                             struct bpf_kfunc_call_arg_meta *meta)
 {
-       return __process_kf_arg_ptr_to_graph_root(env, reg, regno, meta, BPF_RB_ROOT,
+       return __process_kf_arg_ptr_to_graph_root(env, reg, argno, meta, BPF_RB_ROOT,
                                                          &meta->arg_rbtree_root.field);
 }
 
 static int
 __process_kf_arg_ptr_to_graph_node(struct bpf_verifier_env *env,
-                                  struct bpf_reg_state *reg, u32 regno,
+                                  struct bpf_reg_state *reg, argno_t argno,
                                   struct bpf_kfunc_call_arg_meta *meta,
                                   enum btf_field_type head_field_type,
                                   enum btf_field_type node_field_type,
@@ -11888,8 +11957,8 @@ __process_kf_arg_ptr_to_graph_node(struct bpf_verifier_env *env,
        node_type_name = btf_field_type_name(node_field_type);
        if (!tnum_is_const(reg->var_off)) {
                verbose(env,
-                       "R%d doesn't have constant offset. %s has to be at the constant offset\n",
-                       regno, node_type_name);
+                       "%s doesn't have constant offset. %s has to be at the constant offset\n",
+                       reg_arg_name(env, argno), node_type_name);
                return -EINVAL;
        }
 
@@ -11930,19 +11999,19 @@ __process_kf_arg_ptr_to_graph_node(struct bpf_verifier_env *env,
 }
 
 static int process_kf_arg_ptr_to_list_node(struct bpf_verifier_env *env,
-                                          struct bpf_reg_state *reg, u32 regno,
+                                          struct bpf_reg_state *reg, argno_t argno,
                                           struct bpf_kfunc_call_arg_meta *meta)
 {
-       return __process_kf_arg_ptr_to_graph_node(env, reg, regno, meta,
+       return __process_kf_arg_ptr_to_graph_node(env, reg, argno, meta,
                                                  BPF_LIST_HEAD, BPF_LIST_NODE,
                                                  &meta->arg_list_head.field);
 }
 
 static int process_kf_arg_ptr_to_rbtree_node(struct bpf_verifier_env *env,
-                                            struct bpf_reg_state *reg, u32 regno,
+                                            struct bpf_reg_state *reg, argno_t argno,
                                             struct bpf_kfunc_call_arg_meta *meta)
 {
-       return __process_kf_arg_ptr_to_graph_node(env, reg, regno, meta,
+       return __process_kf_arg_ptr_to_graph_node(env, reg, argno, meta,
                                                  BPF_RB_ROOT, BPF_RB_NODE,
                                                  &meta->arg_rbtree_root.field);
 }
@@ -11994,6 +12063,7 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                struct bpf_reg_state *regs = cur_regs(env), *reg = &regs[i + 1];
                const struct btf_type *t, *ref_t, *resolve_ret;
                enum bpf_arg_type arg_type = ARG_DONTCARE;
+               argno_t argno = argno_from_arg(i + 1);
                u32 regno = i + 1, ref_id, type_size;
                bool is_ret_buf_sz = false;
                int kf_arg_type;
@@ -12016,7 +12086,7 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
 
                if (btf_type_is_scalar(t)) {
                        if (reg->type != SCALAR_VALUE) {
-                               verbose(env, "R%d is not a scalar\n", regno);
+                               verbose(env, "%s is not a scalar\n", reg_arg_name(env, argno));
                                return -EINVAL;
                        }
 
@@ -12026,7 +12096,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                                        return -EFAULT;
                                }
                                if (!tnum_is_const(reg->var_off)) {
-                                       verbose(env, "R%d must be a known constant\n", regno);
+                                       verbose(env, "%s must be a known constant\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
                                ret = mark_chain_precision(env, regno);
@@ -12048,7 +12119,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                                }
 
                                if (!tnum_is_const(reg->var_off)) {
-                                       verbose(env, "R%d is not a const\n", regno);
+                                       verbose(env, "%s is not a const\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
 
@@ -12061,20 +12133,22 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                }
 
                if (!btf_type_is_ptr(t)) {
-                       verbose(env, "Unrecognized arg#%d type %s\n", i, btf_type_str(t));
+                       verbose(env, "Unrecognized %s type %s\n",
+                               reg_arg_name(env, argno), btf_type_str(t));
                        return -EINVAL;
                }
 
                if ((bpf_register_is_null(reg) || type_may_be_null(reg->type)) &&
                    !is_kfunc_arg_nullable(meta->btf, &args[i])) {
-                       verbose(env, "Possibly NULL pointer passed to trusted arg%d\n", i);
+                       verbose(env, "Possibly NULL pointer passed to trusted %s\n",
+                               reg_arg_name(env, argno));
                        return -EACCES;
                }
 
                if (reg->ref_obj_id) {
                        if (is_kfunc_release(meta) && meta->ref_obj_id) {
-                               verifier_bug(env, "more than one arg with ref_obj_id R%d %u %u",
-                                            regno, reg->ref_obj_id,
+                               verifier_bug(env, "more than one arg with ref_obj_id %s %u %u",
+                                            reg_arg_name(env, argno), reg->ref_obj_id,
                                             meta->ref_obj_id);
                                return -EFAULT;
                        }
@@ -12086,7 +12160,7 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                ref_t = btf_type_skip_modifiers(btf, t->type, &ref_id);
                ref_tname = btf_name_by_offset(btf, ref_t->name_off);
 
-               kf_arg_type = get_kfunc_ptr_arg_type(env, meta, t, ref_t, ref_tname, args, i, nargs, reg);
+               kf_arg_type = get_kfunc_ptr_arg_type(env, meta, t, ref_t, ref_tname, args, i, nargs, argno, reg);
                if (kf_arg_type < 0)
                        return kf_arg_type;
 
@@ -12095,7 +12169,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        continue;
                case KF_ARG_PTR_TO_MAP:
                        if (!reg->map_ptr) {
-                               verbose(env, "pointer in R%d isn't map pointer\n", regno);
+                               verbose(env, "pointer in %s isn't map pointer\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        if (meta->map.ptr && (reg->map_ptr->record->wq_off >= 0 ||
@@ -12133,11 +12208,13 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                case KF_ARG_PTR_TO_BTF_ID:
                        if (!is_trusted_reg(reg)) {
                                if (!is_kfunc_rcu(meta)) {
-                                       verbose(env, "R%d must be referenced or trusted\n", regno);
+                                       verbose(env, "%s must be referenced or trusted\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
                                if (!is_rcu_reg(reg)) {
-                                       verbose(env, "R%d must be a rcu pointer\n", regno);
+                                       verbose(env, "%s must be a rcu pointer\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
                        }
@@ -12169,15 +12246,15 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
 
                if (is_kfunc_release(meta) && reg->ref_obj_id)
                        arg_type |= OBJ_RELEASE;
-               ret = check_func_arg_reg_off(env, reg, regno, arg_type);
+               ret = check_func_arg_reg_off(env, reg, argno, arg_type);
                if (ret < 0)
                        return ret;
 
                switch (kf_arg_type) {
                case KF_ARG_PTR_TO_CTX:
                        if (reg->type != PTR_TO_CTX) {
-                               verbose(env, "arg#%d expected pointer to ctx, but got %s\n",
-                                       i, reg_type_str(env, reg->type));
+                               verbose(env, "%s expected pointer to ctx, but got %s\n",
+                                       reg_arg_name(env, argno), reg_type_str(env, reg->type));
                                return -EINVAL;
                        }
 
@@ -12191,16 +12268,19 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                case KF_ARG_PTR_TO_ALLOC_BTF_ID:
                        if (reg->type == (PTR_TO_BTF_ID | MEM_ALLOC)) {
                                if (!is_bpf_obj_drop_kfunc(meta->func_id)) {
-                                       verbose(env, "arg#%d expected for bpf_obj_drop()\n", i);
+                                       verbose(env, "%s expected for bpf_obj_drop()\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
                        } else if (reg->type == (PTR_TO_BTF_ID | MEM_ALLOC | MEM_PERCPU)) {
                                if (!is_bpf_percpu_obj_drop_kfunc(meta->func_id)) {
-                                       verbose(env, "arg#%d expected for bpf_percpu_obj_drop()\n", i);
+                                       verbose(env, "%s expected for bpf_percpu_obj_drop()\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
                        } else {
-                               verbose(env, "arg#%d expected pointer to allocated object\n", i);
+                               verbose(env, "%s expected pointer to allocated object\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        if (!reg->ref_obj_id) {
@@ -12248,7 +12328,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                                }
                        }
 
-                       ret = process_dynptr_func(env, reg, regno, insn_idx, dynptr_arg_type, clone_ref_obj_id);
+                       ret = process_dynptr_func(env, reg, argno, insn_idx,
+                                                 dynptr_arg_type, clone_ref_obj_id);
                        if (ret < 0)
                                return ret;
 
@@ -12273,55 +12354,59 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                                        return -EINVAL;
                                }
                        }
-                       ret = process_iter_arg(env, reg, regno, insn_idx, meta);
+                       ret = process_iter_arg(env, reg, argno, insn_idx, meta);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_LIST_HEAD:
                        if (reg->type != PTR_TO_MAP_VALUE &&
                            reg->type != (PTR_TO_BTF_ID | MEM_ALLOC)) {
-                               verbose(env, "arg#%d expected pointer to map value or allocated object\n", i);
+                               verbose(env, "%s expected pointer to map value or allocated object\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        if (reg->type == (PTR_TO_BTF_ID | MEM_ALLOC) && !reg->ref_obj_id) {
                                verbose(env, "allocated object must be referenced\n");
                                return -EINVAL;
                        }
-                       ret = process_kf_arg_ptr_to_list_head(env, reg, regno, meta);
+                       ret = process_kf_arg_ptr_to_list_head(env, reg, argno, meta);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_RB_ROOT:
                        if (reg->type != PTR_TO_MAP_VALUE &&
                            reg->type != (PTR_TO_BTF_ID | MEM_ALLOC)) {
-                               verbose(env, "arg#%d expected pointer to map value or allocated object\n", i);
+                               verbose(env, "%s expected pointer to map value or allocated object\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        if (reg->type == (PTR_TO_BTF_ID | MEM_ALLOC) && !reg->ref_obj_id) {
                                verbose(env, "allocated object must be referenced\n");
                                return -EINVAL;
                        }
-                       ret = process_kf_arg_ptr_to_rbtree_root(env, reg, regno, meta);
+                       ret = process_kf_arg_ptr_to_rbtree_root(env, reg, argno, meta);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_LIST_NODE:
                        if (reg->type != (PTR_TO_BTF_ID | MEM_ALLOC)) {
-                               verbose(env, "arg#%d expected pointer to allocated object\n", i);
+                               verbose(env, "%s expected pointer to allocated object\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        if (!reg->ref_obj_id) {
                                verbose(env, "allocated object must be referenced\n");
                                return -EINVAL;
                        }
-                       ret = process_kf_arg_ptr_to_list_node(env, reg, regno, meta);
+                       ret = process_kf_arg_ptr_to_list_node(env, reg, argno, meta);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_RB_NODE:
                        if (is_bpf_rbtree_add_kfunc(meta->func_id)) {
                                if (reg->type != (PTR_TO_BTF_ID | MEM_ALLOC)) {
-                                       verbose(env, "arg#%d expected pointer to allocated object\n", i);
+                                       verbose(env, "%s expected pointer to allocated object\n",
+                                               reg_arg_name(env, argno));
                                        return -EINVAL;
                                }
                                if (!reg->ref_obj_id) {
@@ -12339,7 +12424,7 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                                }
                        }
 
-                       ret = process_kf_arg_ptr_to_rbtree_node(env, reg, regno, meta);
+                       ret = process_kf_arg_ptr_to_rbtree_node(env, reg, argno, meta);
                        if (ret < 0)
                                return ret;
                        break;
@@ -12354,24 +12439,26 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        if ((base_type(reg->type) != PTR_TO_BTF_ID ||
                             (bpf_type_has_unsafe_modifiers(reg->type) && !is_rcu_reg(reg))) &&
                            !reg2btf_ids[base_type(reg->type)]) {
-                               verbose(env, "arg#%d is %s ", i, reg_type_str(env, reg->type));
+                               verbose(env, "%s is %s ", reg_arg_name(env, argno),
+                                       reg_type_str(env, reg->type));
                                verbose(env, "expected %s or socket\n",
                                        reg_type_str(env, base_type(reg->type) |
                                                          (type_flag(reg->type) & BPF_REG_TRUSTED_MODIFIERS)));
                                return -EINVAL;
                        }
-                       ret = process_kf_arg_ptr_to_btf_id(env, reg, ref_t, ref_tname, ref_id, meta, i);
+                       ret = process_kf_arg_ptr_to_btf_id(env, reg, ref_t, ref_tname, ref_id, meta, i, argno);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_MEM:
                        resolve_ret = btf_resolve_size(btf, ref_t, &type_size);
                        if (IS_ERR(resolve_ret)) {
-                               verbose(env, "arg#%d reference type('%s %s') size cannot be determined: %ld\n",
-                                       i, btf_type_str(ref_t), ref_tname, PTR_ERR(resolve_ret));
+                               verbose(env, "%s reference type('%s %s') size cannot be determined: %ld\n",
+                                       reg_arg_name(env, argno), btf_type_str(ref_t),
+                                       ref_tname, PTR_ERR(resolve_ret));
                                return -EINVAL;
                        }
-                       ret = check_mem_reg(env, reg, regno, type_size);
+                       ret = check_mem_reg(env, reg, argno, type_size);
                        if (ret < 0)
                                return ret;
                        break;
@@ -12381,11 +12468,15 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        const struct btf_param *buff_arg = &args[i];
                        struct bpf_reg_state *size_reg = &regs[regno + 1];
                        const struct btf_param *size_arg = &args[i + 1];
+                       argno_t next_argno = argno_from_arg(i + 2);
 
                        if (!bpf_register_is_null(buff_reg) || !is_kfunc_arg_nullable(meta->btf, buff_arg)) {
-                               ret = check_kfunc_mem_size_reg(env, buff_reg, size_reg, regno, regno + 1);
+                               ret = check_kfunc_mem_size_reg(env, buff_reg, size_reg,
+                                                              argno, next_argno);
                                if (ret < 0) {
-                                       verbose(env, "arg#%d arg#%d memory, len pair leads to invalid memory access\n", i, i + 1);
+                                       verbose(env, "%s and ", reg_arg_name(env, argno));
+                                       verbose(env, "%s memory, len pair leads to invalid memory access\n",
+                                               reg_arg_name(env, next_argno));
                                        return ret;
                                }
                        }
@@ -12396,7 +12487,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                                        return -EFAULT;
                                }
                                if (!tnum_is_const(size_reg->var_off)) {
-                                       verbose(env, "R%d must be a known constant\n", regno + 1);
+                                       verbose(env, "%s must be a known constant\n",
+                                               reg_arg_name(env, next_argno));
                                        return -EINVAL;
                                }
                                meta->arg_constant.found = true;
@@ -12409,14 +12501,15 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                }
                case KF_ARG_PTR_TO_CALLBACK:
                        if (reg->type != PTR_TO_FUNC) {
-                               verbose(env, "arg%d expected pointer to func\n", i);
+                               verbose(env, "%s expected pointer to func\n", reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        meta->subprogno = reg->subprogno;
                        break;
                case KF_ARG_PTR_TO_REFCOUNTED_KPTR:
                        if (!type_is_ptr_alloc_obj(reg->type)) {
-                               verbose(env, "arg#%d is neither owning or non-owning ref\n", i);
+                               verbose(env, "%s is neither owning or non-owning ref\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
                        if (!type_is_non_owning_ref(reg->type))
@@ -12429,7 +12522,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        }
 
                        if (rec->refcount_off < 0) {
-                               verbose(env, "arg#%d doesn't point to a type with bpf_refcount field\n", i);
+                               verbose(env, "%s doesn't point to a type with bpf_refcount field\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
 
@@ -12438,46 +12532,51 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        break;
                case KF_ARG_PTR_TO_CONST_STR:
                        if (reg->type != PTR_TO_MAP_VALUE) {
-                               verbose(env, "arg#%d doesn't point to a const string\n", i);
+                               verbose(env, "%s doesn't point to a const string\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
-                       ret = check_reg_const_str(env, reg, regno);
+                       ret = check_arg_const_str(env, reg, argno);
                        if (ret)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_WORKQUEUE:
                        if (reg->type != PTR_TO_MAP_VALUE) {
-                               verbose(env, "arg#%d doesn't point to a map value\n", i);
+                               verbose(env, "%s doesn't point to a map value\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
-                       ret = check_map_field_pointer(env, reg, regno, BPF_WORKQUEUE, &meta->map);
+                       ret = check_map_field_pointer(env, reg, argno, BPF_WORKQUEUE, &meta->map);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_TIMER:
                        if (reg->type != PTR_TO_MAP_VALUE) {
-                               verbose(env, "arg#%d doesn't point to a map value\n", i);
+                               verbose(env, "%s doesn't point to a map value\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
-                       ret = process_timer_kfunc(env, reg, regno, meta);
+                       ret = process_timer_kfunc(env, reg, argno, meta);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_TASK_WORK:
                        if (reg->type != PTR_TO_MAP_VALUE) {
-                               verbose(env, "arg#%d doesn't point to a map value\n", i);
+                               verbose(env, "%s doesn't point to a map value\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
-                       ret = check_map_field_pointer(env, reg, regno, BPF_TASK_WORK, &meta->map);
+                       ret = check_map_field_pointer(env, reg, argno, BPF_TASK_WORK, &meta->map);
                        if (ret < 0)
                                return ret;
                        break;
                case KF_ARG_PTR_TO_IRQ_FLAG:
                        if (reg->type != PTR_TO_STACK) {
-                               verbose(env, "arg#%d doesn't point to an irq flag on stack\n", i);
+                               verbose(env, "%s doesn't point to an irq flag on stack\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
-                       ret = process_irq_flag(env, reg, regno, meta);
+                       ret = process_irq_flag(env, reg, argno, meta);
                        if (ret < 0)
                                return ret;
                        break;
@@ -12486,7 +12585,8 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        int flags = PROCESS_RES_LOCK;
 
                        if (reg->type != PTR_TO_MAP_VALUE && reg->type != (PTR_TO_BTF_ID | MEM_ALLOC)) {
-                               verbose(env, "arg#%d doesn't point to map value or allocated object\n", i);
+                               verbose(env, "%s doesn't point to map value or allocated object\n",
+                                       reg_arg_name(env, argno));
                                return -EINVAL;
                        }
 
@@ -12498,7 +12598,7 @@ static int check_kfunc_args(struct bpf_verifier_env *env, struct bpf_kfunc_call_
                        if (meta->func_id == special_kfunc_list[KF_bpf_res_spin_lock_irqsave] ||
                            meta->func_id == special_kfunc_list[KF_bpf_res_spin_unlock_irqrestore])
                                flags |= PROCESS_LOCK_IRQ;
-                       ret = process_spin_lock(env, reg, regno, flags);
+                       ret = process_spin_lock(env, reg, argno, flags);
                        if (ret < 0)
                                return ret;
                        break;
@@ -13649,7 +13749,7 @@ static int sanitize_check_bounds(struct bpf_verifier_env *env,
                        return -EACCES;
                break;
        case PTR_TO_MAP_VALUE:
-               if (check_map_access(env, dst_reg, dst, 0, 1, false, ACCESS_HELPER)) {
+               if (check_map_access(env, dst_reg, argno_from_reg(dst), 0, 1, false, ACCESS_HELPER)) {
                        verbose(env, "R%d pointer arithmetic of map value goes out of range, "
                                "prohibited for !root\n", dst);
                        return -EACCES;
@@ -16831,7 +16931,7 @@ static int check_return_code(struct bpf_verifier_env *env, int regno, const char
                                                prog->aux->attach_func_proto->type,
                                                NULL);
                if (ret_type && ret_type == reg_type && reg->ref_obj_id)
-                       return __check_ptr_off_reg(env, reg, regno, false);
+                       return __check_ptr_off_reg(env, reg, argno_from_reg(regno), false);
        }
 
        /* eBPF calling convention is such that R0 is used
@@ -17535,7 +17635,7 @@ static int do_check_insn(struct bpf_verifier_env *env, bool *do_print_state)
 
                dst_reg_type = cur_regs(env)[insn->dst_reg].type;
 
-               err = check_mem_access(env, env->insn_idx, cur_regs(env) + insn->dst_reg, insn->dst_reg,
+               err = check_mem_access(env, env->insn_idx, cur_regs(env) + insn->dst_reg, argno_from_reg(insn->dst_reg),
                                       insn->off, BPF_SIZE(insn->code),
                                       BPF_WRITE, -1, false, false);
                if (err)
@@ -18714,7 +18814,7 @@ static int do_check_common(struct bpf_verifier_env *env, int subprog)
                                mark_reg_unknown(env, regs, i);
                        } else {
                                verifier_bug(env, "unhandled arg#%d type %d",
-                                            i - BPF_REG_1, arg->arg_type);
+                                            i - BPF_REG_1 + 1, arg->arg_type);
                                ret = -EFAULT;
                                goto out;
                        }
index 215878ea04deec17d3ac0214f853a9971cb54f30..b33dba4b126e22b7979dfca7995684a1a579fd30 100644 (file)
@@ -11,18 +11,18 @@ struct {
        const char *prog_name;
        const char *err_msg;
 } test_bpf_nf_fail_tests[] = {
-       { "alloc_release", "kernel function bpf_ct_release args#0 expected pointer to STRUCT nf_conn but" },
-       { "insert_insert", "kernel function bpf_ct_insert_entry args#0 expected pointer to STRUCT nf_conn___init but" },
-       { "lookup_insert", "kernel function bpf_ct_insert_entry args#0 expected pointer to STRUCT nf_conn___init but" },
-       { "set_timeout_after_insert", "kernel function bpf_ct_set_timeout args#0 expected pointer to STRUCT nf_conn___init but" },
-       { "set_status_after_insert", "kernel function bpf_ct_set_status args#0 expected pointer to STRUCT nf_conn___init but" },
-       { "change_timeout_after_alloc", "kernel function bpf_ct_change_timeout args#0 expected pointer to STRUCT nf_conn but" },
-       { "change_status_after_alloc", "kernel function bpf_ct_change_status args#0 expected pointer to STRUCT nf_conn but" },
+       { "alloc_release", "kernel function bpf_ct_release R1 expected pointer to STRUCT nf_conn but" },
+       { "insert_insert", "kernel function bpf_ct_insert_entry R1 expected pointer to STRUCT nf_conn___init but" },
+       { "lookup_insert", "kernel function bpf_ct_insert_entry R1 expected pointer to STRUCT nf_conn___init but" },
+       { "set_timeout_after_insert", "kernel function bpf_ct_set_timeout R1 expected pointer to STRUCT nf_conn___init but" },
+       { "set_status_after_insert", "kernel function bpf_ct_set_status R1 expected pointer to STRUCT nf_conn___init but" },
+       { "change_timeout_after_alloc", "kernel function bpf_ct_change_timeout R1 expected pointer to STRUCT nf_conn but" },
+       { "change_status_after_alloc", "kernel function bpf_ct_change_status R1 expected pointer to STRUCT nf_conn but" },
        { "write_not_allowlisted_field", "no write support to nf_conn at off" },
-       { "lookup_null_bpf_tuple", "Possibly NULL pointer passed to trusted arg1" },
-       { "lookup_null_bpf_opts", "Possibly NULL pointer passed to trusted arg3" },
-       { "xdp_lookup_null_bpf_tuple", "Possibly NULL pointer passed to trusted arg1" },
-       { "xdp_lookup_null_bpf_opts", "Possibly NULL pointer passed to trusted arg3" },
+       { "lookup_null_bpf_tuple", "Possibly NULL pointer passed to trusted R2" },
+       { "lookup_null_bpf_opts", "Possibly NULL pointer passed to trusted R4" },
+       { "xdp_lookup_null_bpf_tuple", "Possibly NULL pointer passed to trusted R2" },
+       { "xdp_lookup_null_bpf_opts", "Possibly NULL pointer passed to trusted R4" },
 };
 
 enum {
index c40df623a8f798387dd61477930cfae74c7949dd..6300b67a3a84679b4c6b0e1f4fc82edbebb6d3e3 100644 (file)
@@ -12,7 +12,7 @@ struct {
        const char *err_msg;
 } cb_refs_tests[] = {
        { "underflow_prog", "must point to scalar, or struct with scalar" },
-       { "leak_prog", "Possibly NULL pointer passed to helper arg2" },
+       { "leak_prog", "Possibly NULL pointer passed to helper R2" },
        { "nested_cb", "Unreleased reference id=4 alloc_insn=2" }, /* alloc_insn=2{4,5} */
        { "non_cb_transfer_ref", "Unreleased reference id=4 alloc_insn=1" }, /* alloc_insn=1{1,2} */
 };
index 62f3fb79f5d13671fd5b3de3fafb36a65b5088b9..3df07680f9e069de283379248e2a16eb35ec557d 100644 (file)
@@ -68,7 +68,7 @@ static struct kfunc_test_params kfunc_tests[] = {
        TC_FAIL(kfunc_call_test_get_mem_fail_oob, 0, "min value is outside of the allowed memory range"),
        TC_FAIL(kfunc_call_test_get_mem_fail_not_const, 0, "is not a const"),
        TC_FAIL(kfunc_call_test_mem_acquire_fail, 0, "acquire kernel function does not return PTR_TO_BTF_ID"),
-       TC_FAIL(kfunc_call_test_pointer_arg_type_mismatch, 0, "arg#0 expected pointer to ctx, but got scalar"),
+       TC_FAIL(kfunc_call_test_pointer_arg_type_mismatch, 0, "R1 expected pointer to ctx, but got scalar"),
 
        /* success cases */
        TC_TEST(kfunc_call_test1, 12),
index 6f25b5f39a79cd2e2547638a7726f444d81c1543..dbff099860ba687cb0db80ecb8d12bf4bb224113 100644 (file)
@@ -81,8 +81,8 @@ static struct {
        { "direct_write_node", "direct access to bpf_list_node is disallowed" },
        { "use_after_unlock_push_front", "invalid mem access 'scalar'" },
        { "use_after_unlock_push_back", "invalid mem access 'scalar'" },
-       { "double_push_front", "arg#1 expected pointer to allocated object" },
-       { "double_push_back", "arg#1 expected pointer to allocated object" },
+       { "double_push_front", "R2 expected pointer to allocated object" },
+       { "double_push_back", "R2 expected pointer to allocated object" },
        { "no_node_value_type", "bpf_list_node not found at offset=0" },
        { "incorrect_value_type",
          "operation on bpf_list_head expects arg#1 bpf_list_node at offset=48 in struct foo, "
index 9fe9c4a4e8f647b766dda2137a1992d171596d9e..a875ba8e50070dcd7d36e3a02f9f809182c325d6 100644 (file)
@@ -29,7 +29,7 @@ static struct __cgrps_kfunc_map_value *insert_lookup_cgrp(struct cgroup *cgrp)
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(cgrp_kfunc_acquire_untrusted, struct cgroup *cgrp, const char *path)
 {
        struct cgroup *acquired;
@@ -48,7 +48,7 @@ int BPF_PROG(cgrp_kfunc_acquire_untrusted, struct cgroup *cgrp, const char *path
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(cgrp_kfunc_acquire_no_null_check, struct cgroup *cgrp, const char *path)
 {
        struct cgroup *acquired;
@@ -64,7 +64,7 @@ int BPF_PROG(cgrp_kfunc_acquire_no_null_check, struct cgroup *cgrp, const char *
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("arg#0 pointer type STRUCT cgroup must point")
+__failure __msg("R1 pointer type STRUCT cgroup must point")
 int BPF_PROG(cgrp_kfunc_acquire_fp, struct cgroup *cgrp, const char *path)
 {
        struct cgroup *acquired, *stack_cgrp = (struct cgroup *)&path;
@@ -106,7 +106,7 @@ int BPF_PROG(cgrp_kfunc_acquire_trusted_walked, struct cgroup *cgrp, const char
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(cgrp_kfunc_acquire_null, struct cgroup *cgrp, const char *path)
 {
        struct cgroup *acquired;
@@ -175,7 +175,7 @@ int BPF_PROG(cgrp_kfunc_rcu_get_release, struct cgroup *cgrp, const char *path)
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(cgrp_kfunc_release_untrusted, struct cgroup *cgrp, const char *path)
 {
        struct __cgrps_kfunc_map_value *v;
@@ -191,7 +191,7 @@ int BPF_PROG(cgrp_kfunc_release_untrusted, struct cgroup *cgrp, const char *path
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("arg#0 pointer type STRUCT cgroup must point")
+__failure __msg("R1 pointer type STRUCT cgroup must point")
 int BPF_PROG(cgrp_kfunc_release_fp, struct cgroup *cgrp, const char *path)
 {
        struct cgroup *acquired = (struct cgroup *)&path;
@@ -203,7 +203,7 @@ int BPF_PROG(cgrp_kfunc_release_fp, struct cgroup *cgrp, const char *path)
 }
 
 SEC("tp_btf/cgroup_mkdir")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(cgrp_kfunc_release_null, struct cgroup *cgrp, const char *path)
 {
        struct __cgrps_kfunc_map_value local, *v;
index 61c32e91e8c3403948ab366f3dd79d1f2052cffd..4c45346fe6f7a0c37f232600662b1a179a5398d8 100644 (file)
@@ -45,7 +45,7 @@ int BPF_PROG(test_alloc_no_release, struct task_struct *task, u64 clone_flags)
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("NULL pointer passed to trusted arg0")
+__failure __msg("NULL pointer passed to trusted R1")
 int BPF_PROG(test_alloc_double_release, struct task_struct *task, u64 clone_flags)
 {
        struct bpf_cpumask *cpumask;
@@ -73,7 +73,7 @@ int BPF_PROG(test_acquire_wrong_cpumask, struct task_struct *task, u64 clone_fla
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("bpf_cpumask_set_cpu args#1 expected pointer to STRUCT bpf_cpumask")
+__failure __msg("bpf_cpumask_set_cpu R2 expected pointer to STRUCT bpf_cpumask")
 int BPF_PROG(test_mutate_cpumask, struct task_struct *task, u64 clone_flags)
 {
        /* Can't set the CPU of a non-struct bpf_cpumask. */
@@ -107,7 +107,7 @@ int BPF_PROG(test_insert_remove_no_release, struct task_struct *task, u64 clone_
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("NULL pointer passed to trusted arg0")
+__failure __msg("NULL pointer passed to trusted R1")
 int BPF_PROG(test_cpumask_null, struct task_struct *task, u64 clone_flags)
 {
   /* NULL passed to kfunc. */
@@ -151,7 +151,7 @@ int BPF_PROG(test_global_mask_out_of_rcu, struct task_struct *task, u64 clone_fl
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("NULL pointer passed to trusted arg1")
+__failure __msg("NULL pointer passed to trusted R2")
 int BPF_PROG(test_global_mask_no_null_check, struct task_struct *task, u64 clone_flags)
 {
        struct bpf_cpumask *local, *prev;
@@ -179,7 +179,7 @@ int BPF_PROG(test_global_mask_no_null_check, struct task_struct *task, u64 clone
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to helper arg2")
+__failure __msg("Possibly NULL pointer passed to helper R2")
 int BPF_PROG(test_global_mask_rcu_no_null_check, struct task_struct *task, u64 clone_flags)
 {
        struct bpf_cpumask *prev, *curr;
index b62773ce5219b061290a919de27880e4ba4ebce3..dbd97add5a5a1b117b61ab70ebcd7a2bc0c6db7b 100644 (file)
@@ -149,7 +149,7 @@ int ringbuf_release_uninit_dynptr(void *ctx)
 
 /* A dynptr can't be used after it has been invalidated */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #2")
+__failure __msg("Expected an initialized dynptr as R3")
 int use_after_invalid(void *ctx)
 {
        struct bpf_dynptr ptr;
@@ -448,7 +448,7 @@ int invalid_helper2(void *ctx)
 
 /* A bpf_dynptr is invalidated if it's been written into */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #0")
+__failure __msg("Expected an initialized dynptr as R1")
 int invalid_write1(void *ctx)
 {
        struct bpf_dynptr ptr;
@@ -1642,7 +1642,7 @@ int invalid_slice_rdwr_rdonly(struct __sk_buff *skb)
 
 /* bpf_dynptr_adjust can only be called on initialized dynptrs */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #0")
+__failure __msg("Expected an initialized dynptr as R1")
 int dynptr_adjust_invalid(void *ctx)
 {
        struct bpf_dynptr ptr = {};
@@ -1655,7 +1655,7 @@ int dynptr_adjust_invalid(void *ctx)
 
 /* bpf_dynptr_is_null can only be called on initialized dynptrs */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #0")
+__failure __msg("Expected an initialized dynptr as R1")
 int dynptr_is_null_invalid(void *ctx)
 {
        struct bpf_dynptr ptr = {};
@@ -1668,7 +1668,7 @@ int dynptr_is_null_invalid(void *ctx)
 
 /* bpf_dynptr_is_rdonly can only be called on initialized dynptrs */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #0")
+__failure __msg("Expected an initialized dynptr as R1")
 int dynptr_is_rdonly_invalid(void *ctx)
 {
        struct bpf_dynptr ptr = {};
@@ -1681,7 +1681,7 @@ int dynptr_is_rdonly_invalid(void *ctx)
 
 /* bpf_dynptr_size can only be called on initialized dynptrs */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #0")
+__failure __msg("Expected an initialized dynptr as R1")
 int dynptr_size_invalid(void *ctx)
 {
        struct bpf_dynptr ptr = {};
@@ -1694,7 +1694,7 @@ int dynptr_size_invalid(void *ctx)
 
 /* Only initialized dynptrs can be cloned */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #0")
+__failure __msg("Expected an initialized dynptr as R1")
 int clone_invalid1(void *ctx)
 {
        struct bpf_dynptr ptr1 = {};
@@ -1728,7 +1728,7 @@ int clone_invalid2(struct xdp_md *xdp)
 
 /* Invalidating a dynptr should invalidate its clones */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #2")
+__failure __msg("Expected an initialized dynptr as R3")
 int clone_invalidate1(void *ctx)
 {
        struct bpf_dynptr clone;
@@ -1749,7 +1749,7 @@ int clone_invalidate1(void *ctx)
 
 /* Invalidating a dynptr should invalidate its parent */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #2")
+__failure __msg("Expected an initialized dynptr as R3")
 int clone_invalidate2(void *ctx)
 {
        struct bpf_dynptr ptr;
@@ -1770,7 +1770,7 @@ int clone_invalidate2(void *ctx)
 
 /* Invalidating a dynptr should invalidate its siblings */
 SEC("?raw_tp")
-__failure __msg("Expected an initialized dynptr as arg #2")
+__failure __msg("Expected an initialized dynptr as R3")
 int clone_invalidate3(void *ctx)
 {
        struct bpf_dynptr ptr;
@@ -1981,7 +1981,7 @@ __noinline long global_call_bpf_dynptr(const struct bpf_dynptr *dynptr)
 }
 
 SEC("?raw_tp")
-__failure __msg("arg#0 expected pointer to stack or const struct bpf_dynptr")
+__failure __msg("R1 expected pointer to stack or const struct bpf_dynptr")
 int test_dynptr_reg_type(void *ctx)
 {
        struct task_struct *current = NULL;
index 32fe28ed243921f88e41ef913638b88ac19a6d71..0739620dea8a76e640923868c0ee85d16f83c6bc 100644 (file)
@@ -30,7 +30,7 @@ int on_nanosleep_unreleased_ref(void *ctx)
 
 SEC("xdp")
 __failure
-__msg("Expected a dynptr of type file as arg #0")
+__msg("Expected a dynptr of type file as R1")
 int xdp_wrong_dynptr_type(struct xdp_md *xdp)
 {
        struct bpf_dynptr dynptr;
@@ -42,7 +42,7 @@ int xdp_wrong_dynptr_type(struct xdp_md *xdp)
 
 SEC("xdp")
 __failure
-__msg("Expected an initialized dynptr as arg #0")
+__msg("Expected an initialized dynptr as R1")
 int xdp_no_dynptr_type(struct xdp_md *xdp)
 {
        struct bpf_dynptr dynptr;
index e11e82d989040b75f928752155c596d33f245d36..a4a007866a332ab68f006ead11efc521a5661a1c 100644 (file)
@@ -15,7 +15,7 @@ struct bpf_res_spin_lock lockA __hidden SEC(".data.A");
 struct bpf_res_spin_lock lockB __hidden SEC(".data.B");
 
 SEC("?tc")
-__failure __msg("arg#0 doesn't point to an irq flag on stack")
+__failure __msg("R1 doesn't point to an irq flag on stack")
 int irq_save_bad_arg(struct __sk_buff *ctx)
 {
        bpf_local_irq_save(&global_flags);
@@ -23,7 +23,7 @@ int irq_save_bad_arg(struct __sk_buff *ctx)
 }
 
 SEC("?tc")
-__failure __msg("arg#0 doesn't point to an irq flag on stack")
+__failure __msg("R1 doesn't point to an irq flag on stack")
 int irq_restore_bad_arg(struct __sk_buff *ctx)
 {
        bpf_local_irq_restore(&global_flags);
index 86b74e3579d9d5f72b8634804becde22c491a452..0fa70b133d932246243da34849db08af57383008 100644 (file)
@@ -1605,7 +1605,7 @@ int iter_subprog_check_stacksafe(const void *ctx)
 struct bpf_iter_num global_it;
 
 SEC("raw_tp")
-__failure __msg("arg#0 expected pointer to an iterator on stack")
+__failure __msg("R1 expected pointer to an iterator on stack")
 int iter_new_bad_arg(const void *ctx)
 {
        bpf_iter_num_new(&global_it, 0, 1);
@@ -1613,7 +1613,7 @@ int iter_new_bad_arg(const void *ctx)
 }
 
 SEC("raw_tp")
-__failure __msg("arg#0 expected pointer to an iterator on stack")
+__failure __msg("R1 expected pointer to an iterator on stack")
 int iter_next_bad_arg(const void *ctx)
 {
        bpf_iter_num_next(&global_it);
@@ -1621,7 +1621,7 @@ int iter_next_bad_arg(const void *ctx)
 }
 
 SEC("raw_tp")
-__failure __msg("arg#0 expected pointer to an iterator on stack")
+__failure __msg("R1 expected pointer to an iterator on stack")
 int iter_destroy_bad_arg(const void *ctx)
 {
        bpf_iter_num_destroy(&global_it);
index d273b46dfc7c19e73c6c88e03b59bae617d960b8..af8f9ec1ea98a115b6462e668631251167e06598 100644 (file)
@@ -73,7 +73,7 @@ int create_and_forget_to_destroy_fail(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected an initialized iter_num as arg #0")
+__failure __msg("expected an initialized iter_num as R1")
 int destroy_without_creating_fail(void *ctx)
 {
        /* init with zeros to stop verifier complaining about uninit stack */
@@ -91,7 +91,7 @@ int destroy_without_creating_fail(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected an initialized iter_num as arg #0")
+__failure __msg("expected an initialized iter_num as R1")
 int compromise_iter_w_direct_write_fail(void *ctx)
 {
        struct bpf_iter_num iter;
@@ -143,7 +143,7 @@ int compromise_iter_w_direct_write_and_skip_destroy_fail(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected an initialized iter_num as arg #0")
+__failure __msg("expected an initialized iter_num as R1")
 int compromise_iter_w_helper_write_fail(void *ctx)
 {
        struct bpf_iter_num iter;
@@ -230,7 +230,7 @@ int valid_stack_reuse(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected uninitialized iter_num as arg #0")
+__failure __msg("expected uninitialized iter_num as R1")
 int double_create_fail(void *ctx)
 {
        struct bpf_iter_num iter;
@@ -258,7 +258,7 @@ int double_create_fail(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected an initialized iter_num as arg #0")
+__failure __msg("expected an initialized iter_num as R1")
 int double_destroy_fail(void *ctx)
 {
        struct bpf_iter_num iter;
@@ -284,7 +284,7 @@ int double_destroy_fail(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected an initialized iter_num as arg #0")
+__failure __msg("expected an initialized iter_num as R1")
 int next_without_new_fail(void *ctx)
 {
        struct bpf_iter_num iter;
@@ -305,7 +305,7 @@ int next_without_new_fail(void *ctx)
 }
 
 SEC("?raw_tp")
-__failure __msg("expected an initialized iter_num as arg #0")
+__failure __msg("expected an initialized iter_num as R1")
 int next_after_destroy_fail(void *ctx)
 {
        struct bpf_iter_num iter;
index 5379e9960ffd2d86bae8ed67f39d40a1aa631e18..76012dbbdb413319de79b61e11f2513e0e998a22 100644 (file)
@@ -29,7 +29,7 @@ out:
 }
 
 SEC("raw_tp/sys_enter")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int iter_next_trusted_or_null(const void *ctx)
 {
        struct task_struct *cur_task = bpf_get_current_task_btf();
@@ -67,7 +67,7 @@ out:
 }
 
 SEC("raw_tp/sys_enter")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int iter_next_rcu_or_null(const void *ctx)
 {
        struct task_struct *cur_task = bpf_get_current_task_btf();
index 83791348bed5268c155b21a772c5f952994f27f6..9b760dac333e4e69edd69f3f55b51506bf913e0c 100644 (file)
@@ -79,7 +79,7 @@ int testmod_seq_truncated(const void *ctx)
 
 SEC("?raw_tp")
 __failure
-__msg("expected an initialized iter_testmod_seq as arg #1")
+__msg("expected an initialized iter_testmod_seq as R2")
 int testmod_seq_getter_before_bad(const void *ctx)
 {
        struct bpf_iter_testmod_seq it;
@@ -89,7 +89,7 @@ int testmod_seq_getter_before_bad(const void *ctx)
 
 SEC("?raw_tp")
 __failure
-__msg("expected an initialized iter_testmod_seq as arg #1")
+__msg("expected an initialized iter_testmod_seq as R2")
 int testmod_seq_getter_after_bad(const void *ctx)
 {
        struct bpf_iter_testmod_seq it;
index ee053b24e6ca6f54a2ffbd2d89bcb69cacb30c32..8f36e74fd8f9dea77ff6948242501a098eb6be81 100644 (file)
@@ -364,7 +364,7 @@ int kptr_xchg_ref_state(struct __sk_buff *ctx)
 }
 
 SEC("?tc")
-__failure __msg("Possibly NULL pointer passed to helper arg2")
+__failure __msg("Possibly NULL pointer passed to helper R2")
 int kptr_xchg_possibly_null(struct __sk_buff *ctx)
 {
        struct prog_test_ref_kfunc *p;
index 81813c724fa962584f91b99746f7d2557d65270f..08379c3b6a038b420353c5f6cbdf2cd39838da6b 100644 (file)
@@ -110,7 +110,7 @@ int BPF_PROG(test_array_map_3)
 }
 
 SEC("?fentry.s/bpf_fentry_test1")
-__failure __msg("arg#0 expected for bpf_percpu_obj_drop()")
+__failure __msg("R1 expected for bpf_percpu_obj_drop()")
 int BPF_PROG(test_array_map_4)
 {
        struct val_t __percpu_kptr *p;
@@ -124,7 +124,7 @@ int BPF_PROG(test_array_map_4)
 }
 
 SEC("?fentry.s/bpf_fentry_test1")
-__failure __msg("arg#0 expected for bpf_obj_drop()")
+__failure __msg("R1 expected for bpf_obj_drop()")
 int BPF_PROG(test_array_map_5)
 {
        struct val_t *p;
index 70b7baf9304bb8184eb1ff7d55347a1786e83745..555379952dcc27c9e0e11867273e852262b29f17 100644 (file)
@@ -134,7 +134,7 @@ unlock_err:
 }
 
 SEC("?tc")
-__failure __msg("arg#1 expected pointer to allocated object")
+__failure __msg("R2 expected pointer to allocated object")
 long rbtree_api_add_to_multiple_trees(void *ctx)
 {
        struct node_data *n;
@@ -153,7 +153,7 @@ long rbtree_api_add_to_multiple_trees(void *ctx)
 }
 
 SEC("?tc")
-__failure __msg("Possibly NULL pointer passed to trusted arg1")
+__failure __msg("Possibly NULL pointer passed to trusted R2")
 long rbtree_api_use_unchecked_remove_retval(void *ctx)
 {
        struct bpf_rb_node *res;
@@ -281,7 +281,7 @@ long add_with_cb(bool (cb)(struct bpf_rb_node *a, const struct bpf_rb_node *b))
 }
 
 SEC("?tc")
-__failure __msg("arg#1 expected pointer to allocated object")
+__failure __msg("R2 expected pointer to allocated object")
 long rbtree_api_add_bad_cb_bad_fn_call_add(void *ctx)
 {
        return add_with_cb(less__bad_fn_call_add);
index b2808bfcec296d2ef12bfcddd90dcac4973ae7bd..7247a20c0a3bf53e96ef2410a75eb3ad4476ba9a 100644 (file)
@@ -54,7 +54,7 @@ long rbtree_refcounted_node_ref_escapes(void *ctx)
 }
 
 SEC("?tc")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 long refcount_acquire_maybe_null(void *ctx)
 {
        struct node_acquire *n, *m;
index 8e8249f3521cf3f2880ca4ed88ed56526f0c53d3..21428bb1ee597cf665acb2a443adcf81b7fa7395 100644 (file)
@@ -23,7 +23,7 @@ int stream_vprintk_scalar_arg(void *ctx)
 }
 
 SEC("syscall")
-__failure __msg("arg#1 doesn't point to a const string")
+__failure __msg("R2 doesn't point to a const string")
 int stream_vprintk_string_arg(void *ctx)
 {
        bpf_stream_vprintk(BPF_STDOUT, ctx, NULL, 0);
index 4c07ea193f721d4799921c5950acd49428bf8bd2..41047d81ec428a3cc9beff06a4fb1cb9eb113ea9 100644 (file)
@@ -28,7 +28,7 @@ static struct __tasks_kfunc_map_value *insert_lookup_task(struct task_struct *ta
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_acquire_untrusted, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired;
@@ -49,7 +49,7 @@ int BPF_PROG(task_kfunc_acquire_untrusted, struct task_struct *task, u64 clone_f
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("arg#0 pointer type STRUCT task_struct must point")
+__failure __msg("R1 pointer type STRUCT task_struct must point")
 int BPF_PROG(task_kfunc_acquire_fp, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired, *stack_task = (struct task_struct *)&clone_flags;
@@ -100,7 +100,7 @@ int BPF_PROG(task_kfunc_acquire_unsafe_kretprobe_rcu, struct task_struct *task,
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_acquire_null, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired;
@@ -149,7 +149,7 @@ int BPF_PROG(task_kfunc_xchg_unreleased, struct task_struct *task, u64 clone_fla
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_acquire_release_no_null_check, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired;
@@ -162,7 +162,7 @@ int BPF_PROG(task_kfunc_acquire_release_no_null_check, struct task_struct *task,
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_release_untrusted, struct task_struct *task, u64 clone_flags)
 {
        struct __tasks_kfunc_map_value *v;
@@ -178,7 +178,7 @@ int BPF_PROG(task_kfunc_release_untrusted, struct task_struct *task, u64 clone_f
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("arg#0 pointer type STRUCT task_struct must point")
+__failure __msg("R1 pointer type STRUCT task_struct must point")
 int BPF_PROG(task_kfunc_release_fp, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired = (struct task_struct *)&clone_flags;
@@ -190,7 +190,7 @@ int BPF_PROG(task_kfunc_release_fp, struct task_struct *task, u64 clone_flags)
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_release_null, struct task_struct *task, u64 clone_flags)
 {
        struct __tasks_kfunc_map_value local, *v;
@@ -234,7 +234,7 @@ int BPF_PROG(task_kfunc_release_unacquired, struct task_struct *task, u64 clone_
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_from_pid_no_null_check, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired;
@@ -248,7 +248,7 @@ int BPF_PROG(task_kfunc_from_pid_no_null_check, struct task_struct *task, u64 cl
 }
 
 SEC("tp_btf/task_newtask")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(task_kfunc_from_vpid_no_null_check, struct task_struct *task, u64 clone_flags)
 {
        struct task_struct *acquired;
index 82e4b891333385d26abbf9987e23bb545f8728de..3186e7b4b24e0006ed23e22914f81ae26a5182f5 100644 (file)
@@ -58,7 +58,7 @@ int mismatch_map(struct pt_regs *args)
 }
 
 SEC("perf_event")
-__failure __msg("arg#1 doesn't point to a map value")
+__failure __msg("R2 doesn't point to a map value")
 int no_map_task_work(struct pt_regs *args)
 {
        struct task_struct *task;
@@ -70,7 +70,7 @@ int no_map_task_work(struct pt_regs *args)
 }
 
 SEC("perf_event")
-__failure __msg("Possibly NULL pointer passed to trusted arg1")
+__failure __msg("Possibly NULL pointer passed to trusted R2")
 int task_work_null(struct pt_regs *args)
 {
        struct task_struct *task;
@@ -81,7 +81,7 @@ int task_work_null(struct pt_regs *args)
 }
 
 SEC("perf_event")
-__failure __msg("Possibly NULL pointer passed to trusted arg2")
+__failure __msg("Possibly NULL pointer passed to trusted R3")
 int map_null(struct pt_regs *args)
 {
        struct elem *work;
index 2c156cd166afe7a6ea02e0fc0ad5c148b1f1bb0e..332cda89caba05406c6eee84e9c36ca1922d4b74 100644 (file)
@@ -152,7 +152,7 @@ int change_status_after_alloc(struct __sk_buff *ctx)
 }
 
 SEC("?tc")
-__failure __msg("Possibly NULL pointer passed to trusted arg1")
+__failure __msg("Possibly NULL pointer passed to trusted R2")
 int lookup_null_bpf_tuple(struct __sk_buff *ctx)
 {
        struct bpf_ct_opts___local opts = {};
@@ -165,7 +165,7 @@ int lookup_null_bpf_tuple(struct __sk_buff *ctx)
 }
 
 SEC("?tc")
-__failure __msg("Possibly NULL pointer passed to trusted arg3")
+__failure __msg("Possibly NULL pointer passed to trusted R4")
 int lookup_null_bpf_opts(struct __sk_buff *ctx)
 {
        struct bpf_sock_tuple tup = {};
@@ -178,7 +178,7 @@ int lookup_null_bpf_opts(struct __sk_buff *ctx)
 }
 
 SEC("?xdp")
-__failure __msg("Possibly NULL pointer passed to trusted arg1")
+__failure __msg("Possibly NULL pointer passed to trusted R2")
 int xdp_lookup_null_bpf_tuple(struct xdp_md *ctx)
 {
        struct bpf_ct_opts___local opts = {};
@@ -191,7 +191,7 @@ int xdp_lookup_null_bpf_tuple(struct xdp_md *ctx)
 }
 
 SEC("?xdp")
-__failure __msg("Possibly NULL pointer passed to trusted arg3")
+__failure __msg("Possibly NULL pointer passed to trusted R4")
 int xdp_lookup_null_bpf_opts(struct xdp_md *ctx)
 {
        struct bpf_sock_tuple tup = {};
index 1c6cfd0888ba792300e4e741ca00d554acc11d84..bf48fc43c7ab6bd1fcaca220a95f2ea85916628a 100644 (file)
@@ -40,7 +40,7 @@ int BPF_PROG(not_valid_dynptr, int cmd, union bpf_attr *attr, unsigned int size,
 }
 
 SEC("?lsm.s/bpf")
-__failure __msg("arg#0 expected pointer to stack or const struct bpf_dynptr")
+__failure __msg("R1 expected pointer to stack or const struct bpf_dynptr")
 int BPF_PROG(not_ptr_to_stack, int cmd, union bpf_attr *attr, unsigned int size, bool kernel)
 {
        static struct bpf_dynptr val;
index 967081bbcfe1f5531dcbc72489380c4bfd792ac3..ca35b92ea09508416f229da90a3b4f6fadcf050a 100644 (file)
@@ -29,7 +29,7 @@ int kfunc_dynptr_nullable_test2(struct __sk_buff *skb)
 }
 
 SEC("tc")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int kfunc_dynptr_nullable_test3(struct __sk_buff *skb)
 {
        struct bpf_dynptr data;
index 8bcddadfc4daed3c34f474dea952499fe8256393..dd97f20275054dc771efe3ec8c206b0ccf9cdd3a 100644 (file)
@@ -32,7 +32,7 @@ int BPF_PROG(no_destroy, struct bpf_iter_meta *meta, struct cgroup *cgrp)
 
 SEC("iter/cgroup")
 __description("uninitialized iter in ->next()")
-__failure __msg("expected an initialized iter_bits as arg #0")
+__failure __msg("expected an initialized iter_bits as R1")
 int BPF_PROG(next_uninit, struct bpf_iter_meta *meta, struct cgroup *cgrp)
 {
        struct bpf_iter_bits it = {};
@@ -43,7 +43,7 @@ int BPF_PROG(next_uninit, struct bpf_iter_meta *meta, struct cgroup *cgrp)
 
 SEC("iter/cgroup")
 __description("uninitialized iter in ->destroy()")
-__failure __msg("expected an initialized iter_bits as arg #0")
+__failure __msg("expected an initialized iter_bits as R1")
 int BPF_PROG(destroy_uninit, struct bpf_iter_meta *meta, struct cgroup *cgrp)
 {
        struct bpf_iter_bits it = {};
index 910365201f68395246bbc5bf8e08fab2aaff3cdb..139f70bb3595fe6c827555da9487c1361ead356c 100644 (file)
@@ -263,7 +263,7 @@ l0_%=:      r0 = 0;                                         \
 
 SEC("lsm.s/bpf")
 __description("reference tracking: release user key reference without check")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 __naked void user_key_reference_without_check(void)
 {
        asm volatile ("                                 \
@@ -282,7 +282,7 @@ __naked void user_key_reference_without_check(void)
 
 SEC("lsm.s/bpf")
 __description("reference tracking: release system key reference without check")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 __naked void system_key_reference_without_check(void)
 {
        asm volatile ("                                 \
@@ -300,7 +300,7 @@ __naked void system_key_reference_without_check(void)
 
 SEC("lsm.s/bpf")
 __description("reference tracking: release with NULL key pointer")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 __naked void release_with_null_key_pointer(void)
 {
        asm volatile ("                                 \
index 4b392c6c8fc41e0f5ab870c366cf459edfbae863..0990de0768440592108fd0399e6314aee45f66ea 100644 (file)
@@ -13,7 +13,7 @@
 static char buf[PATH_MAX];
 
 SEC("lsm.s/file_open")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(get_task_exe_file_kfunc_null)
 {
        struct file *acquired;
@@ -28,7 +28,7 @@ int BPF_PROG(get_task_exe_file_kfunc_null)
 }
 
 SEC("lsm.s/inode_getxattr")
-__failure __msg("arg#0 pointer type STRUCT task_struct must point to scalar, or struct with scalar")
+__failure __msg("R1 pointer type STRUCT task_struct must point to scalar, or struct with scalar")
 int BPF_PROG(get_task_exe_file_kfunc_fp)
 {
        u64 x;
@@ -89,7 +89,7 @@ int BPF_PROG(put_file_kfunc_unacquired, struct file *file)
 }
 
 SEC("lsm.s/file_open")
-__failure __msg("Possibly NULL pointer passed to trusted arg0")
+__failure __msg("Possibly NULL pointer passed to trusted R1")
 int BPF_PROG(path_d_path_kfunc_null)
 {
        /* Can't pass NULL value to bpf_path_d_path() kfunc. */
@@ -128,7 +128,7 @@ int BPF_PROG(path_d_path_kfunc_untrusted_from_current)
 }
 
 SEC("lsm.s/file_open")
-__failure __msg("kernel function bpf_path_d_path args#0 expected pointer to STRUCT path but R1 has a pointer to STRUCT file")
+__failure __msg("kernel function bpf_path_d_path R1 expected pointer to STRUCT path but R1 has a pointer to STRUCT file")
 int BPF_PROG(path_d_path_kfunc_type_mismatch, struct file *file)
 {
        bpf_path_d_path((struct path *)&file->f_task_work, buf, sizeof(buf));
index 3767f5595bbc2db9b003d1dc2641d150c016c190..32dc8827e128b94786ead3481ed0aad0a6dad112 100644 (file)
@@ -98,7 +98,7 @@ __failure
  * is a correct bpf_wq pointer.
  */
 __msg(": (85) call bpf_wq_set_callback#") /* anchor message */
-__msg("arg#0 doesn't point to a map value")
+__msg("R1 doesn't point to a map value")
 long test_wrong_wq_pointer(void *ctx)
 {
        int key = 0;
index c3164b9b2be54db8cb274c0b8245a4e4544e7c6f..0bb4337552c8a5ab58a4369ef8a790f96843ff4c 100644 (file)
@@ -31,7 +31,7 @@
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "arg#0 pointer type STRUCT prog_test_fail1 must point to scalar",
+       .errstr = "R1 pointer type STRUCT prog_test_fail1 must point to scalar",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_test_fail1", 2 },
        },
@@ -46,7 +46,7 @@
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "max struct nesting depth exceeded\narg#0 pointer type STRUCT prog_test_fail2",
+       .errstr = "max struct nesting depth exceeded\nR1 pointer type STRUCT prog_test_fail2",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_test_fail2", 2 },
        },
@@ -61,7 +61,7 @@
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "arg#0 pointer type STRUCT prog_test_fail3 must point to scalar",
+       .errstr = "R1 pointer type STRUCT prog_test_fail3 must point to scalar",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_test_fail3", 2 },
        },
@@ -76,7 +76,7 @@
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "arg#0 expected pointer to ctx, but got fp",
+       .errstr = "R1 expected pointer to ctx, but got fp",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_test_pass_ctx", 2 },
        },
@@ -91,7 +91,7 @@
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "arg#0 pointer type UNKNOWN  must point to scalar",
+       .errstr = "R1 pointer type UNKNOWN  must point to scalar",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_test_mem_len_fail1", 2 },
        },
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "Possibly NULL pointer passed to trusted arg0",
+       .errstr = "Possibly NULL pointer passed to trusted R1",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_test_acquire", 3 },
                { "bpf_kfunc_call_test_release", 5 },
        },
        .prog_type = BPF_PROG_TYPE_SCHED_CLS,
        .result = REJECT,
-       .errstr = "kernel function bpf_kfunc_call_memb1_release args#0 expected pointer",
+       .errstr = "kernel function bpf_kfunc_call_memb1_release R1 expected pointer",
        .fixup_kfunc_btf_id = {
                { "bpf_kfunc_call_memb_acquire", 1 },
                { "bpf_kfunc_call_memb1_release", 5 },