Commit fb4e3b33 authored by Eduard Zingerman's avatar Eduard Zingerman Committed by Daniel Borkmann

bpf: Fix for use-after-free bug in inline_bpf_loop

As reported by Dan Carpenter, the following statements in inline_bpf_loop()
might cause a use-after-free bug:

  struct bpf_prog *new_prog;
  // ...
  new_prog = bpf_patch_insn_data(env, position, insn_buf, *cnt);
  // ...
  env->prog->insnsi[call_insn_offset].imm = callback_offset;

The bpf_patch_insn_data() might free the memory used by env->prog.

Fixes: 1ade2371 ("bpf: Inline calls to bpf_loop when callback is known")
Reported-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarEduard Zingerman <eddyz87@gmail.com>
Signed-off-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Link: https://lore.kernel.org/bpf/20220624020613.548108-2-eddyz87@gmail.com
parent 395e942d
...@@ -14417,7 +14417,7 @@ static struct bpf_prog *inline_bpf_loop(struct bpf_verifier_env *env, ...@@ -14417,7 +14417,7 @@ static struct bpf_prog *inline_bpf_loop(struct bpf_verifier_env *env,
/* Note: insn_buf[12] is an offset of BPF_CALL_REL instruction */ /* Note: insn_buf[12] is an offset of BPF_CALL_REL instruction */
call_insn_offset = position + 12; call_insn_offset = position + 12;
callback_offset = callback_start - call_insn_offset - 1; callback_offset = callback_start - call_insn_offset - 1;
env->prog->insnsi[call_insn_offset].imm = callback_offset; new_prog->insnsi[call_insn_offset].imm = callback_offset;
return new_prog; return new_prog;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment