int register_btf_id_dtor_kfuncs(const struct btf_id_dtor_kfunc *dtors, u32 add_cnt,
                                struct module *owner);
 struct btf_struct_meta *btf_find_struct_meta(const struct btf *btf, u32 btf_id);
-const struct btf_type *
-btf_get_prog_ctx_type(struct bpf_verifier_log *log, const struct btf *btf,
-                     const struct btf_type *t, enum bpf_prog_type prog_type,
-                     int arg);
+bool btf_is_prog_ctx_type(struct bpf_verifier_log *log, const struct btf *btf,
+                          const struct btf_type *t, enum bpf_prog_type prog_type,
+                          int arg);
 int get_kern_ctx_btf_id(struct bpf_verifier_log *log, enum bpf_prog_type prog_type);
 bool btf_types_are_same(const struct btf *btf1, u32 id1,
                        const struct btf *btf2, u32 id2);
 {
        return NULL;
 }
-static inline const struct btf_member *
-btf_get_prog_ctx_type(struct bpf_verifier_log *log, const struct btf *btf,
-                     const struct btf_type *t, enum bpf_prog_type prog_type,
-                     int arg)
+static inline bool
+btf_is_prog_ctx_type(struct bpf_verifier_log *log, const struct btf *btf,
+                    const struct btf_type *t, enum bpf_prog_type prog_type,
+                    int arg)
 {
-       return NULL;
+       return false;
 }
 static inline int get_kern_ctx_btf_id(struct bpf_verifier_log *log,
                                      enum bpf_prog_type prog_type) {
 
        return ctx_type->type;
 }
 
-const struct btf_type *
-btf_get_prog_ctx_type(struct bpf_verifier_log *log, const struct btf *btf,
-                     const struct btf_type *t, enum bpf_prog_type prog_type,
-                     int arg)
+bool btf_is_prog_ctx_type(struct bpf_verifier_log *log, const struct btf *btf,
+                         const struct btf_type *t, enum bpf_prog_type prog_type,
+                         int arg)
 {
        const struct btf_type *ctx_type;
        const char *tname, *ctx_tname;
                 * is not supported yet.
                 * BPF_PROG_TYPE_RAW_TRACEPOINT is fine.
                 */
-               return NULL;
+               return false;
        }
        tname = btf_name_by_offset(btf, t->name_off);
        if (!tname) {
                bpf_log(log, "arg#%d struct doesn't have a name\n", arg);
-               return NULL;
+               return false;
        }
 
        ctx_type = find_canonical_prog_ctx_type(prog_type);
        if (!ctx_type) {
                bpf_log(log, "btf_vmlinux is malformed\n");
                /* should not happen */
-               return NULL;
+               return false;
        }
 again:
        ctx_tname = btf_name_by_offset(btf_vmlinux, ctx_type->name_off);
        if (!ctx_tname) {
                /* should not happen */
                bpf_log(log, "Please fix kernel include/linux/bpf_types.h\n");
-               return NULL;
+               return false;
        }
        /* only compare that prog's ctx type name is the same as
         * kernel expects. No need to compare field by field.
         * { // no fields of skb are ever used }
         */
        if (strcmp(ctx_tname, "__sk_buff") == 0 && strcmp(tname, "sk_buff") == 0)
-               return ctx_type;
+               return true;
        if (strcmp(ctx_tname, "xdp_md") == 0 && strcmp(tname, "xdp_buff") == 0)
-               return ctx_type;
+               return true;
        if (strcmp(ctx_tname, tname)) {
                /* bpf_user_pt_regs_t is a typedef, so resolve it to
                 * underlying struct and check name again
                 */
                if (!btf_type_is_modifier(ctx_type))
-                       return NULL;
+                       return false;
                while (btf_type_is_modifier(ctx_type))
                        ctx_type = btf_type_by_id(btf_vmlinux, ctx_type->type);
                goto again;
        }
-       return ctx_type;
+       return true;
 }
 
 /* forward declarations for arch-specific underlying types of
                                     enum bpf_prog_type prog_type,
                                     int arg)
 {
-       if (!btf_get_prog_ctx_type(log, btf, t, prog_type, arg))
+       if (!btf_is_prog_ctx_type(log, btf, t, prog_type, arg))
                return -ENOENT;
        return find_kern_ctx_type_id(prog_type);
 }
                if (!btf_type_is_ptr(t))
                        goto skip_pointer;
 
-               if ((tags & ARG_TAG_CTX) || btf_get_prog_ctx_type(log, btf, t, prog_type, i)) {
+               if ((tags & ARG_TAG_CTX) || btf_is_prog_ctx_type(log, btf, t, prog_type, i)) {
                        if (tags & ~ARG_TAG_CTX) {
                                bpf_log(log, "arg#%d has invalid combination of tags\n", i);
                                return -EINVAL;
 
         * type to our caller. When a set of conditions hold in the BTF type of
         * arguments, we resolve it to a known kfunc_ptr_arg_type.
         */
-       if (btf_get_prog_ctx_type(&env->log, meta->btf, t, resolve_prog_type(env->prog), argno))
+       if (btf_is_prog_ctx_type(&env->log, meta->btf, t, resolve_prog_type(env->prog), argno))
                return KF_ARG_PTR_TO_CTX;
 
        if (is_kfunc_arg_alloc_obj(meta->btf, &args[argno]))