From 4fdeb0f3612b0ac7c4e06f4695b1ecc45aa8ac89 Mon Sep 17 00:00:00 2001 From: Heiko Carstens Date: Sat, 1 Dec 2012 12:29:08 +0100 Subject: [PATCH] --- yaml --- r: 343409 b: refs/heads/master c: 3247274536729b6cc23208cc087e50fdef3de6ba h: refs/heads/master i: 343407: 40c477564d2baab38cf37173ecf8b5fc8e4e19c8 v: v3 --- [refs] | 2 +- trunk/arch/s390/net/bpf_jit_comp.c | 21 +++++++++++++++++++++ 2 files changed, 22 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 8f8bfd11f3c8..968a422c3fb2 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: d99e79ec5574fc556c988f613ed6175f6de66f4a +refs/heads/master: 3247274536729b6cc23208cc087e50fdef3de6ba diff --git a/trunk/arch/s390/net/bpf_jit_comp.c b/trunk/arch/s390/net/bpf_jit_comp.c index 9b355b406afa..1ff930167348 100644 --- a/trunk/arch/s390/net/bpf_jit_comp.c +++ b/trunk/arch/s390/net/bpf_jit_comp.c @@ -341,6 +341,27 @@ static int bpf_jit_insn(struct bpf_jit *jit, struct sock_filter *filter, /* lr %r5,%r4 */ EMIT2(0x1854); break; + case BPF_S_ALU_MOD_X: /* A %= X */ + jit->seen |= SEEN_XREG | SEEN_RET0; + /* ltr %r12,%r12 */ + EMIT2(0x12cc); + /* jz */ + EMIT4_PCREL(0xa7840000, (jit->ret0_ip - jit->prg)); + /* lhi %r4,0 */ + EMIT4(0xa7480000); + /* dr %r4,%r12 */ + EMIT2(0x1d4c); + /* lr %r5,%r4 */ + EMIT2(0x1854); + break; + case BPF_S_ALU_MOD_K: /* A %= K */ + /* lhi %r4,0 */ + EMIT4(0xa7480000); + /* d %r4,(%r13) */ + EMIT4_DISP(0x5d40d000, EMIT_CONST(K)); + /* lr %r5,%r4 */ + EMIT2(0x1854); + break; case BPF_S_ALU_AND_X: /* A &= X */ jit->seen |= SEEN_XREG; /* nr %r5,%r12 */