aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/cxgb3/sge.c
diff options
context:
space:
mode:
authorJiri Pirko <jpirko@redhat.com>2011-07-20 00:54:35 -0400
committerDavid S. Miller <davem@davemloft.net>2011-07-21 16:47:56 -0400
commit892ef5d85259e193505d553c10237fd5dc9a3d0d (patch)
tree9d755e3311ce8592b8b23cf5928431f107e7902c /drivers/net/cxgb3/sge.c
parentdc437974af52e78f2736543dfee94cc385dae6e9 (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.c35
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