On Thu, Feb 25, 2021 at 1:35 AM Yonghong Song <yhs@xxxxxx> wrote: > > During verifier check_cfg(), all instructions are > visited to ensure verifier can handle program control flows. > This patch factored out function visit_func_call_insn() > so it can be reused in later patch to visit callback function > calls. There is no functionality change for this patch. > > Signed-off-by: Yonghong Song <yhs@xxxxxx> > --- > kernel/bpf/verifier.c | 35 +++++++++++++++++++++++------------ > 1 file changed, 23 insertions(+), 12 deletions(-) > > diff --git a/kernel/bpf/verifier.c b/kernel/bpf/verifier.c > index 1dda9d81f12c..9cb182e91162 100644 > --- a/kernel/bpf/verifier.c > +++ b/kernel/bpf/verifier.c > @@ -8592,6 +8592,27 @@ static int push_insn(int t, int w, int e, struct bpf_verifier_env *env, > return DONE_EXPLORING; > } > > +static int visit_func_call_insn(int t, int insn_cnt, > + struct bpf_insn *insns, both insns and insn_cnt seem to be derivatives of env (env->prog->insnsi and env->prog->len), so it shouldn't be necessary to pass them in. > + struct bpf_verifier_env *env, > + bool visit_callee) > +{ > + int ret; > + > + ret = push_insn(t, t + 1, FALLTHROUGH, env, false); > + if (ret) > + return ret; > + > + if (t + 1 < insn_cnt) > + init_explored_state(env, t + 1); > + if (visit_callee) { > + init_explored_state(env, t); > + ret = push_insn(t, t + insns[t].imm + 1, BRANCH, > + env, false); > + } > + return ret; > +} > + > /* Visits the instruction at index t and returns one of the following: > * < 0 - an error occurred > * DONE_EXPLORING - the instruction was fully explored > @@ -8612,18 +8633,8 @@ static int visit_insn(int t, int insn_cnt, struct bpf_verifier_env *env) similarly for visit_insn, insn_cnt is just env->prog->len, so it's signature could be simplified as well > return DONE_EXPLORING; > > case BPF_CALL: > - ret = push_insn(t, t + 1, FALLTHROUGH, env, false); > - if (ret) > - return ret; > - > - if (t + 1 < insn_cnt) > - init_explored_state(env, t + 1); > - if (insns[t].src_reg == BPF_PSEUDO_CALL) { > - init_explored_state(env, t); > - ret = push_insn(t, t + insns[t].imm + 1, BRANCH, > - env, false); > - } > - return ret; > + return visit_func_call_insn(t, insn_cnt, insns, env, > + insns[t].src_reg == BPF_PSEUDO_CALL); > > case BPF_JA: > if (BPF_SRC(insns[t].code) != BPF_K) > -- > 2.24.1 >