diff options
author | Jiri Pirko <jpirko@redhat.com> | 2011-07-20 00:54:35 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-07-21 16:47:56 -0400 |
commit | 892ef5d85259e193505d553c10237fd5dc9a3d0d (patch) | |
tree | 9d755e3311ce8592b8b23cf5928431f107e7902c /drivers/net/cxgb3/sge.c | |
parent | dc437974af52e78f2736543dfee94cc385dae6e9 (diff) |
cxgb3: do vlan cleanup
- unify vlan and nonvlan rx path
- kill pi->vlan_grp and vlan_rx_register
- allow to turn on/off rx/tx vlan accel via ethtool (set_features)
Signed-off-by: Jiri Pirko <jpirko@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/cxgb3/sge.c')
-rw-r--r-- | drivers/net/cxgb3/sge.c | 35 |
1 files changed, 6 insertions, 29 deletions
diff --git a/drivers/net/cxgb3/sge.c b/drivers/net/cxgb3/sge.c index 76bf5892b96..d6fa1777a34 100644 --- a/drivers/net/cxgb3/sge.c +++ b/drivers/net/cxgb3/sge.c | |||
@@ -2028,28 +2028,11 @@ static void rx_eth(struct adapter *adap, struct sge_rspq *rq, | |||
2028 | skb_checksum_none_assert(skb); | 2028 | skb_checksum_none_assert(skb); |
2029 | skb_record_rx_queue(skb, qs - &adap->sge.qs[pi->first_qset]); | 2029 | skb_record_rx_queue(skb, qs - &adap->sge.qs[pi->first_qset]); |
2030 | 2030 | ||
2031 | if (unlikely(p->vlan_valid)) { | 2031 | if (p->vlan_valid) { |
2032 | struct vlan_group *grp = pi->vlan_grp; | ||
2033 | |||
2034 | qs->port_stats[SGE_PSTAT_VLANEX]++; | 2032 | qs->port_stats[SGE_PSTAT_VLANEX]++; |
2035 | if (likely(grp)) | 2033 | __vlan_hwaccel_put_tag(skb, ntohs(p->vlan)); |
2036 | if (lro) | 2034 | } |
2037 | vlan_gro_receive(&qs->napi, grp, | 2035 | if (rq->polling) { |
2038 | ntohs(p->vlan), skb); | ||
2039 | else { | ||
2040 | if (unlikely(pi->iscsic.flags)) { | ||
2041 | unsigned short vtag = ntohs(p->vlan) & | ||
2042 | VLAN_VID_MASK; | ||
2043 | skb->dev = vlan_group_get_device(grp, | ||
2044 | vtag); | ||
2045 | cxgb3_process_iscsi_prov_pack(pi, skb); | ||
2046 | } | ||
2047 | __vlan_hwaccel_rx(skb, grp, ntohs(p->vlan), | ||
2048 | rq->polling); | ||
2049 | } | ||
2050 | else | ||
2051 | dev_kfree_skb_any(skb); | ||
2052 | } else if (rq->polling) { | ||
2053 | if (lro) | 2036 | if (lro) |
2054 | napi_gro_receive(&qs->napi, skb); | 2037 | napi_gro_receive(&qs->napi, skb); |
2055 | else { | 2038 | else { |
@@ -2147,14 +2130,8 @@ static void lro_add_page(struct adapter *adap, struct sge_qset *qs, | |||
2147 | 2130 | ||
2148 | skb_record_rx_queue(skb, qs - &adap->sge.qs[pi->first_qset]); | 2131 | skb_record_rx_queue(skb, qs - &adap->sge.qs[pi->first_qset]); |
2149 | 2132 | ||
2150 | if (unlikely(cpl->vlan_valid)) { | 2133 | if (cpl->vlan_valid) |
2151 | struct vlan_group *grp = pi->vlan_grp; | 2134 | __vlan_hwaccel_put_tag(skb, ntohs(cpl->vlan)); |
2152 | |||
2153 | if (likely(grp != NULL)) { | ||
2154 | vlan_gro_frags(&qs->napi, grp, ntohs(cpl->vlan)); | ||
2155 | return; | ||
2156 | } | ||
2157 | } | ||
2158 | napi_gro_frags(&qs->napi); | 2135 | napi_gro_frags(&qs->napi); |
2159 | } | 2136 | } |
2160 | 2137 | ||