s390/bpf: fix bpf frame pointer setup
Currently the bpf frame pointer is set to the old r15. This is
wrong because of packed stack. Fix this and adjust the frame pointer
to respect packed stack. This now generates a prolog like the following:
3ff8001c3fa: eb67f0480024 stmg %r6,%r7,72(%r15)
3ff8001c400: ebcff0780024 stmg %r12,%r15,120(%r15)
3ff8001c406: b904001f lgr %r1,%r15 <- load backchain
3ff8001c40a: 41d0f048 la %r13,72(%r15) <- load adjusted bfp
3ff8001c40e: a7fbfd98 aghi %r15,-616
3ff8001c412: e310f0980024 stg %r1,152(%r15) <- save backchain
Fixes: 0546231057
("s390/bpf: Add s390x eBPF JIT compiler backend")
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
Acked-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Alexei Starovoitov <ast@plumgrid.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Родитель
bbac1c9488
Коммит
88aeca15d6
|
@ -384,13 +384,16 @@ static void bpf_jit_prologue(struct bpf_jit *jit)
|
||||||
}
|
}
|
||||||
/* Setup stack and backchain */
|
/* Setup stack and backchain */
|
||||||
if (jit->seen & SEEN_STACK) {
|
if (jit->seen & SEEN_STACK) {
|
||||||
/* lgr %bfp,%r15 (BPF frame pointer) */
|
if (jit->seen & SEEN_FUNC)
|
||||||
EMIT4(0xb9040000, BPF_REG_FP, REG_15);
|
/* lgr %w1,%r15 (backchain) */
|
||||||
|
EMIT4(0xb9040000, REG_W1, REG_15);
|
||||||
|
/* la %bfp,STK_160_UNUSED(%r15) (BPF frame pointer) */
|
||||||
|
EMIT4_DISP(0x41000000, BPF_REG_FP, REG_15, STK_160_UNUSED);
|
||||||
/* aghi %r15,-STK_OFF */
|
/* aghi %r15,-STK_OFF */
|
||||||
EMIT4_IMM(0xa70b0000, REG_15, -STK_OFF);
|
EMIT4_IMM(0xa70b0000, REG_15, -STK_OFF);
|
||||||
if (jit->seen & SEEN_FUNC)
|
if (jit->seen & SEEN_FUNC)
|
||||||
/* stg %bfp,152(%r15) (backchain) */
|
/* stg %w1,152(%r15) (backchain) */
|
||||||
EMIT6_DISP_LH(0xe3000000, 0x0024, BPF_REG_FP, REG_0,
|
EMIT6_DISP_LH(0xe3000000, 0x0024, REG_W1, REG_0,
|
||||||
REG_15, 152);
|
REG_15, 152);
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
|
Загрузка…
Ссылка в новой задаче