|
@@ -1528,14 +1528,19 @@ static bool __is_pointer_value(bool allow_ptr_leaks,
|
|
|
return reg->type != SCALAR_VALUE;
|
|
|
}
|
|
|
|
|
|
+static struct bpf_reg_state *reg_state(struct bpf_verifier_env *env, int regno)
|
|
|
+{
|
|
|
+ return cur_regs(env) + regno;
|
|
|
+}
|
|
|
+
|
|
|
static bool is_pointer_value(struct bpf_verifier_env *env, int regno)
|
|
|
{
|
|
|
- return __is_pointer_value(env->allow_ptr_leaks, cur_regs(env) + regno);
|
|
|
+ return __is_pointer_value(env->allow_ptr_leaks, reg_state(env, regno));
|
|
|
}
|
|
|
|
|
|
static bool is_ctx_reg(struct bpf_verifier_env *env, int regno)
|
|
|
{
|
|
|
- const struct bpf_reg_state *reg = cur_regs(env) + regno;
|
|
|
+ const struct bpf_reg_state *reg = reg_state(env, regno);
|
|
|
|
|
|
return reg->type == PTR_TO_CTX ||
|
|
|
reg->type == PTR_TO_SOCKET;
|
|
@@ -1543,7 +1548,7 @@ static bool is_ctx_reg(struct bpf_verifier_env *env, int regno)
|
|
|
|
|
|
static bool is_pkt_reg(struct bpf_verifier_env *env, int regno)
|
|
|
{
|
|
|
- const struct bpf_reg_state *reg = cur_regs(env) + regno;
|
|
|
+ const struct bpf_reg_state *reg = reg_state(env, regno);
|
|
|
|
|
|
return type_is_pkt_pointer(reg->type);
|
|
|
}
|
|
@@ -1958,7 +1963,8 @@ static int check_xadd(struct bpf_verifier_env *env, int insn_idx, struct bpf_ins
|
|
|
if (is_ctx_reg(env, insn->dst_reg) ||
|
|
|
is_pkt_reg(env, insn->dst_reg)) {
|
|
|
verbose(env, "BPF_XADD stores into R%d %s is not allowed\n",
|
|
|
- insn->dst_reg, reg_type_str[insn->dst_reg]);
|
|
|
+ insn->dst_reg,
|
|
|
+ reg_type_str[reg_state(env, insn->dst_reg)->type]);
|
|
|
return -EACCES;
|
|
|
}
|
|
|
|
|
@@ -1983,7 +1989,7 @@ static int check_stack_boundary(struct bpf_verifier_env *env, int regno,
|
|
|
int access_size, bool zero_size_allowed,
|
|
|
struct bpf_call_arg_meta *meta)
|
|
|
{
|
|
|
- struct bpf_reg_state *reg = cur_regs(env) + regno;
|
|
|
+ struct bpf_reg_state *reg = reg_state(env, regno);
|
|
|
struct bpf_func_state *state = func(env, reg);
|
|
|
int off, i, slot, spi;
|
|
|
|
|
@@ -5264,7 +5270,8 @@ static int do_check(struct bpf_verifier_env *env)
|
|
|
|
|
|
if (is_ctx_reg(env, insn->dst_reg)) {
|
|
|
verbose(env, "BPF_ST stores into R%d %s is not allowed\n",
|
|
|
- insn->dst_reg, reg_type_str[insn->dst_reg]);
|
|
|
+ insn->dst_reg,
|
|
|
+ reg_type_str[reg_state(env, insn->dst_reg)->type]);
|
|
|
return -EACCES;
|
|
|
}
|
|
|
|