diff options
author | Eric Dumazet <edumazet@google.com> | 2012-10-26 22:26:22 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-10-31 14:00:15 -0400 |
commit | 855ddb56d81fcdc76ab60b80062359ea09a1515d (patch) | |
tree | 37766d2211c962a6e0300a62105851e5e112822a /arch | |
parent | f3335031b9452baebfe49b8b5e55d3fe0c4677d1 (diff) |
x86: bpf_jit_comp: add vlan tag support
This patch is a follow-up for patch "net: filter: add vlan tag access"
to support the new VLAN_TAG/VLAN_TAG_PRESENT accessors in BPF JIT.
Signed-off-by: Eric Dumazet <edumazet@google.com>
Cc: Ani Sinha <ani@aristanetworks.com>
Cc: Daniel Borkmann <danborkmann@iogearbox.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/x86/net/bpf_jit_comp.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/arch/x86/net/bpf_jit_comp.c b/arch/x86/net/bpf_jit_comp.c index 520d2bd0b9c5..d11a47099d33 100644 --- a/arch/x86/net/bpf_jit_comp.c +++ b/arch/x86/net/bpf_jit_comp.c | |||
@@ -11,6 +11,7 @@ | |||
11 | #include <asm/cacheflush.h> | 11 | #include <asm/cacheflush.h> |
12 | #include <linux/netdevice.h> | 12 | #include <linux/netdevice.h> |
13 | #include <linux/filter.h> | 13 | #include <linux/filter.h> |
14 | #include <linux/if_vlan.h> | ||
14 | 15 | ||
15 | /* | 16 | /* |
16 | * Conventions : | 17 | * Conventions : |
@@ -212,6 +213,8 @@ void bpf_jit_compile(struct sk_filter *fp) | |||
212 | case BPF_S_ANC_MARK: | 213 | case BPF_S_ANC_MARK: |
213 | case BPF_S_ANC_RXHASH: | 214 | case BPF_S_ANC_RXHASH: |
214 | case BPF_S_ANC_CPU: | 215 | case BPF_S_ANC_CPU: |
216 | case BPF_S_ANC_VLAN_TAG: | ||
217 | case BPF_S_ANC_VLAN_TAG_PRESENT: | ||
215 | case BPF_S_ANC_QUEUE: | 218 | case BPF_S_ANC_QUEUE: |
216 | case BPF_S_LD_W_ABS: | 219 | case BPF_S_LD_W_ABS: |
217 | case BPF_S_LD_H_ABS: | 220 | case BPF_S_LD_H_ABS: |
@@ -515,6 +518,24 @@ void bpf_jit_compile(struct sk_filter *fp) | |||
515 | CLEAR_A(); | 518 | CLEAR_A(); |
516 | #endif | 519 | #endif |
517 | break; | 520 | break; |
521 | case BPF_S_ANC_VLAN_TAG: | ||
522 | case BPF_S_ANC_VLAN_TAG_PRESENT: | ||
523 | BUILD_BUG_ON(FIELD_SIZEOF(struct sk_buff, vlan_tci) != 2); | ||
524 | if (is_imm8(offsetof(struct sk_buff, vlan_tci))) { | ||
525 | /* movzwl off8(%rdi),%eax */ | ||
526 | EMIT4(0x0f, 0xb7, 0x47, offsetof(struct sk_buff, vlan_tci)); | ||
527 | } else { | ||
528 | EMIT3(0x0f, 0xb7, 0x87); /* movzwl off32(%rdi),%eax */ | ||
529 | EMIT(offsetof(struct sk_buff, vlan_tci), 4); | ||
530 | } | ||
531 | BUILD_BUG_ON(VLAN_TAG_PRESENT != 0x1000); | ||
532 | if (filter[i].code == BPF_S_ANC_VLAN_TAG) { | ||
533 | EMIT3(0x80, 0xe4, 0xef); /* and $0xef,%ah */ | ||
534 | } else { | ||
535 | EMIT3(0xc1, 0xe8, 0x0c); /* shr $0xc,%eax */ | ||
536 | EMIT3(0x83, 0xe0, 0x01); /* and $0x1,%eax */ | ||
537 | } | ||
538 | break; | ||
518 | case BPF_S_LD_W_ABS: | 539 | case BPF_S_LD_W_ABS: |
519 | func = CHOOSE_LOAD_FUNC(K, sk_load_word); | 540 | func = CHOOSE_LOAD_FUNC(K, sk_load_word); |
520 | common_load: seen |= SEEN_DATAREF; | 541 | common_load: seen |= SEEN_DATAREF; |