aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm64/net
diff options
context:
space:
mode:
authorDaniel Borkmann <dborkman@redhat.com>2014-09-11 05:36:48 -0400
committerCatalin Marinas <catalin.marinas@arm.com>2014-09-12 11:33:14 -0400
commit60ef0494f197d4705b17132ee7d496283b5604b3 (patch)
tree71351c6dbc12734b66b6239187928c8c4664b475 /arch/arm64/net
parentc2eb6b6139183af632a5be8f7c33006d7b03702d (diff)
net: bpf: arm64: fix module memory leak when JIT image build fails
On ARM64, when the BPF JIT compiler fills the JIT image body with opcodes during translation of eBPF into ARM64 opcodes, we may fail for several reasons during that phase: one being that we jump to the notyet label for not yet supported eBPF instructions such as BPF_ST. In that case we only free offsets, but not the actual allocated target image where opcodes are being stored. Fix it by calling module_free() on dismantle time in case of errors. Signed-off-by: Daniel Borkmann <dborkman@redhat.com> Acked-by: Zi Shen Lim <zlim.lnx@gmail.com> Acked-by: Will Deacon <will.deacon@arm.com> Cc: Alexei Starovoitov <ast@plumgrid.com> Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
Diffstat (limited to 'arch/arm64/net')
-rw-r--r--arch/arm64/net/bpf_jit_comp.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/arch/arm64/net/bpf_jit_comp.c b/arch/arm64/net/bpf_jit_comp.c
index 38c42965382d..7ae33545535b 100644
--- a/arch/arm64/net/bpf_jit_comp.c
+++ b/arch/arm64/net/bpf_jit_comp.c
@@ -651,8 +651,10 @@ void bpf_int_jit_compile(struct bpf_prog *prog)
651 build_prologue(&ctx); 651 build_prologue(&ctx);
652 652
653 ctx.body_offset = ctx.idx; 653 ctx.body_offset = ctx.idx;
654 if (build_body(&ctx)) 654 if (build_body(&ctx)) {
655 module_free(NULL, ctx.image);
655 goto out; 656 goto out;
657 }
656 658
657 build_epilogue(&ctx); 659 build_epilogue(&ctx);
658 660