Commit dd00e06d authored by David S. Miller's avatar David S. Miller

Merge branch 'net-Use-__vlan_hwaccel_-helpers'

Michał Mirosław says:

====================
net: Use __vlan_hwaccel_*() helpers

This series removes from networking core and driver code an assumption
about how VLAN tag presence is stored in an skb. This will allow to free
up overloading of VLAN.CFI bit to incidate tag's presence.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents 49f8e832 3149a271
...@@ -3944,7 +3944,7 @@ static int rx_pkt(struct c4iw_dev *dev, struct sk_buff *skb) ...@@ -3944,7 +3944,7 @@ static int rx_pkt(struct c4iw_dev *dev, struct sk_buff *skb)
} else { } else {
vlan_eh = (struct vlan_ethhdr *)(req + 1); vlan_eh = (struct vlan_ethhdr *)(req + 1);
iph = (struct iphdr *)(vlan_eh + 1); iph = (struct iphdr *)(vlan_eh + 1);
skb->vlan_tci = ntohs(cpl->vlan); __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), ntohs(cpl->vlan));
} }
if (iph->version != 0x4) if (iph->version != 0x4)
......
...@@ -1049,30 +1049,35 @@ static struct sk_buff *be_insert_vlan_in_pkt(struct be_adapter *adapter, ...@@ -1049,30 +1049,35 @@ static struct sk_buff *be_insert_vlan_in_pkt(struct be_adapter *adapter,
struct be_wrb_params struct be_wrb_params
*wrb_params) *wrb_params)
{ {
bool insert_vlan = false;
u16 vlan_tag = 0; u16 vlan_tag = 0;
skb = skb_share_check(skb, GFP_ATOMIC); skb = skb_share_check(skb, GFP_ATOMIC);
if (unlikely(!skb)) if (unlikely(!skb))
return skb; return skb;
if (skb_vlan_tag_present(skb)) if (skb_vlan_tag_present(skb)) {
vlan_tag = be_get_tx_vlan_tag(adapter, skb); vlan_tag = be_get_tx_vlan_tag(adapter, skb);
insert_vlan = true;
}
if (qnq_async_evt_rcvd(adapter) && adapter->pvid) { if (qnq_async_evt_rcvd(adapter) && adapter->pvid) {
if (!vlan_tag) if (!insert_vlan) {
vlan_tag = adapter->pvid; vlan_tag = adapter->pvid;
insert_vlan = true;
}
/* f/w workaround to set skip_hw_vlan = 1, informs the F/W to /* f/w workaround to set skip_hw_vlan = 1, informs the F/W to
* skip VLAN insertion * skip VLAN insertion
*/ */
BE_WRB_F_SET(wrb_params->features, VLAN_SKIP_HW, 1); BE_WRB_F_SET(wrb_params->features, VLAN_SKIP_HW, 1);
} }
if (vlan_tag) { if (insert_vlan) {
skb = vlan_insert_tag_set_proto(skb, htons(ETH_P_8021Q), skb = vlan_insert_tag_set_proto(skb, htons(ETH_P_8021Q),
vlan_tag); vlan_tag);
if (unlikely(!skb)) if (unlikely(!skb))
return skb; return skb;
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
} }
/* Insert the outer VLAN, if any */ /* Insert the outer VLAN, if any */
......
...@@ -2485,13 +2485,11 @@ static struct sk_buff *receive_copy(struct sky2_port *sky2, ...@@ -2485,13 +2485,11 @@ static struct sk_buff *receive_copy(struct sky2_port *sky2,
skb->ip_summed = re->skb->ip_summed; skb->ip_summed = re->skb->ip_summed;
skb->csum = re->skb->csum; skb->csum = re->skb->csum;
skb_copy_hash(skb, re->skb); skb_copy_hash(skb, re->skb);
skb->vlan_proto = re->skb->vlan_proto; __vlan_hwaccel_copy_tag(skb, re->skb);
skb->vlan_tci = re->skb->vlan_tci;
pci_dma_sync_single_for_device(sky2->hw->pdev, re->data_addr, pci_dma_sync_single_for_device(sky2->hw->pdev, re->data_addr,
length, PCI_DMA_FROMDEVICE); length, PCI_DMA_FROMDEVICE);
re->skb->vlan_proto = 0; __vlan_hwaccel_clear_tag(re->skb);
re->skb->vlan_tci = 0;
skb_clear_hash(re->skb); skb_clear_hash(re->skb);
re->skb->ip_summed = CHECKSUM_NONE; re->skb->ip_summed = CHECKSUM_NONE;
skb_put(skb, length); skb_put(skb, length);
......
...@@ -875,7 +875,7 @@ int mlx4_en_process_rx_cq(struct net_device *dev, struct mlx4_en_cq *cq, int bud ...@@ -875,7 +875,7 @@ int mlx4_en_process_rx_cq(struct net_device *dev, struct mlx4_en_cq *cq, int bud
skb->data_len = length; skb->data_len = length;
napi_gro_frags(&cq->napi); napi_gro_frags(&cq->napi);
} else { } else {
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
skb_clear_hash(skb); skb_clear_hash(skb);
} }
next: next:
......
...@@ -57,7 +57,7 @@ bool vlan_do_receive(struct sk_buff **skbp) ...@@ -57,7 +57,7 @@ bool vlan_do_receive(struct sk_buff **skbp)
} }
skb->priority = vlan_get_ingress_priority(vlan_dev, skb->vlan_tci); skb->priority = vlan_get_ingress_priority(vlan_dev, skb->vlan_tci);
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
rx_stats = this_cpu_ptr(vlan_dev_priv(vlan_dev)->vlan_pcpu_stats); rx_stats = this_cpu_ptr(vlan_dev_priv(vlan_dev)->vlan_pcpu_stats);
......
...@@ -671,10 +671,8 @@ static int br_nf_push_frag_xmit(struct net *net, struct sock *sk, struct sk_buff ...@@ -671,10 +671,8 @@ static int br_nf_push_frag_xmit(struct net *net, struct sock *sk, struct sk_buff
return 0; return 0;
} }
if (data->vlan_tci) { if (data->vlan_proto)
skb->vlan_tci = data->vlan_tci; __vlan_hwaccel_put_tag(skb, data->vlan_proto, data->vlan_tci);
skb->vlan_proto = data->vlan_proto;
}
skb_copy_to_linear_data_offset(skb, -data->size, data->mac, data->size); skb_copy_to_linear_data_offset(skb, -data->size, data->mac, data->size);
__skb_push(skb, data->encap_size); __skb_push(skb, data->encap_size);
...@@ -740,8 +738,13 @@ static int br_nf_dev_queue_xmit(struct net *net, struct sock *sk, struct sk_buff ...@@ -740,8 +738,13 @@ static int br_nf_dev_queue_xmit(struct net *net, struct sock *sk, struct sk_buff
data = this_cpu_ptr(&brnf_frag_data_storage); data = this_cpu_ptr(&brnf_frag_data_storage);
data->vlan_tci = skb->vlan_tci; if (skb_vlan_tag_present(skb)) {
data->vlan_proto = skb->vlan_proto; data->vlan_tci = skb->vlan_tci;
data->vlan_proto = skb->vlan_proto;
} else {
data->vlan_proto = 0;
}
data->encap_size = nf_bridge_encap_header_len(skb); data->encap_size = nf_bridge_encap_header_len(skb);
data->size = ETH_HLEN + data->encap_size; data->size = ETH_HLEN + data->encap_size;
......
...@@ -905,7 +905,7 @@ static inline int br_vlan_get_tag(const struct sk_buff *skb, u16 *vid) ...@@ -905,7 +905,7 @@ static inline int br_vlan_get_tag(const struct sk_buff *skb, u16 *vid)
int err = 0; int err = 0;
if (skb_vlan_tag_present(skb)) { if (skb_vlan_tag_present(skb)) {
*vid = skb_vlan_tag_get(skb) & VLAN_VID_MASK; *vid = skb_vlan_tag_get_id(skb);
} else { } else {
*vid = 0; *vid = 0;
err = -EINVAL; err = -EINVAL;
......
...@@ -420,7 +420,7 @@ struct sk_buff *br_handle_vlan(struct net_bridge *br, ...@@ -420,7 +420,7 @@ struct sk_buff *br_handle_vlan(struct net_bridge *br,
} }
if (v->flags & BRIDGE_VLAN_INFO_UNTAGGED) if (v->flags & BRIDGE_VLAN_INFO_UNTAGGED)
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
if (p && (p->flags & BR_VLAN_TUNNEL) && if (p && (p->flags & BR_VLAN_TUNNEL) &&
br_handle_egress_vlan_tunnel(skb, v)) { br_handle_egress_vlan_tunnel(skb, v)) {
...@@ -493,8 +493,8 @@ static bool __allowed_ingress(const struct net_bridge *br, ...@@ -493,8 +493,8 @@ static bool __allowed_ingress(const struct net_bridge *br,
__vlan_hwaccel_put_tag(skb, br->vlan_proto, pvid); __vlan_hwaccel_put_tag(skb, br->vlan_proto, pvid);
else else
/* Priority-tagged Frame. /* Priority-tagged Frame.
* At this point, We know that skb->vlan_tci had * At this point, we know that skb->vlan_tci VID
* VLAN_TAG_PRESENT bit and its VID field was 0x000. * field was 0.
* We update only VID field and preserve PCP field. * We update only VID field and preserve PCP field.
*/ */
skb->vlan_tci |= pvid; skb->vlan_tci |= pvid;
......
...@@ -4889,7 +4889,7 @@ static int __netif_receive_skb_core(struct sk_buff *skb, bool pfmemalloc, ...@@ -4889,7 +4889,7 @@ static int __netif_receive_skb_core(struct sk_buff *skb, bool pfmemalloc,
* and set skb->priority like in vlan_do_receive() * and set skb->priority like in vlan_do_receive()
* For the time being, just ignore Priority Code Point * For the time being, just ignore Priority Code Point
*/ */
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
} }
type = skb->protocol; type = skb->protocol;
...@@ -5386,7 +5386,9 @@ static struct list_head *gro_list_prepare(struct napi_struct *napi, ...@@ -5386,7 +5386,9 @@ static struct list_head *gro_list_prepare(struct napi_struct *napi,
} }
diffs = (unsigned long)p->dev ^ (unsigned long)skb->dev; diffs = (unsigned long)p->dev ^ (unsigned long)skb->dev;
diffs |= p->vlan_tci ^ skb->vlan_tci; diffs |= skb_vlan_tag_present(p) ^ skb_vlan_tag_present(skb);
if (skb_vlan_tag_present(p))
diffs |= p->vlan_tci ^ skb->vlan_tci;
diffs |= skb_metadata_dst_cmp(p, skb); diffs |= skb_metadata_dst_cmp(p, skb);
diffs |= skb_metadata_differs(p, skb); diffs |= skb_metadata_differs(p, skb);
if (maclen == ETH_HLEN) if (maclen == ETH_HLEN)
...@@ -5652,7 +5654,7 @@ static void napi_reuse_skb(struct napi_struct *napi, struct sk_buff *skb) ...@@ -5652,7 +5654,7 @@ static void napi_reuse_skb(struct napi_struct *napi, struct sk_buff *skb)
__skb_pull(skb, skb_headlen(skb)); __skb_pull(skb, skb_headlen(skb));
/* restore the reserve we had after netdev_alloc_skb_ip_align() */ /* restore the reserve we had after netdev_alloc_skb_ip_align() */
skb_reserve(skb, NET_SKB_PAD + NET_IP_ALIGN - skb_headroom(skb)); skb_reserve(skb, NET_SKB_PAD + NET_IP_ALIGN - skb_headroom(skb));
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
skb->dev = napi->dev; skb->dev = napi->dev;
skb->skb_iif = 0; skb->skb_iif = 0;
skb->encapsulation = 0; skb->encapsulation = 0;
......
...@@ -5166,7 +5166,7 @@ int skb_vlan_pop(struct sk_buff *skb) ...@@ -5166,7 +5166,7 @@ int skb_vlan_pop(struct sk_buff *skb)
int err; int err;
if (likely(skb_vlan_tag_present(skb))) { if (likely(skb_vlan_tag_present(skb))) {
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
} else { } else {
if (unlikely(!eth_type_vlan(skb->protocol))) if (unlikely(!eth_type_vlan(skb->protocol)))
return 0; return 0;
......
...@@ -120,7 +120,7 @@ int __iptunnel_pull_header(struct sk_buff *skb, int hdr_len, ...@@ -120,7 +120,7 @@ int __iptunnel_pull_header(struct sk_buff *skb, int hdr_len,
} }
skb_clear_hash_if_not_l4(skb); skb_clear_hash_if_not_l4(skb);
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
skb_set_queue_mapping(skb, 0); skb_set_queue_mapping(skb, 0);
skb_scrub_packet(skb, xnet); skb_scrub_packet(skb, xnet);
......
...@@ -1148,8 +1148,9 @@ static int nfqa_parse_bridge(struct nf_queue_entry *entry, ...@@ -1148,8 +1148,9 @@ static int nfqa_parse_bridge(struct nf_queue_entry *entry,
if (!tb[NFQA_VLAN_TCI] || !tb[NFQA_VLAN_PROTO]) if (!tb[NFQA_VLAN_TCI] || !tb[NFQA_VLAN_PROTO])
return -EINVAL; return -EINVAL;
entry->skb->vlan_tci = ntohs(nla_get_be16(tb[NFQA_VLAN_TCI])); __vlan_hwaccel_put_tag(entry->skb,
entry->skb->vlan_proto = nla_get_be16(tb[NFQA_VLAN_PROTO]); nla_get_be16(tb[NFQA_VLAN_PROTO]),
ntohs(nla_get_be16(tb[NFQA_VLAN_TCI])));
} }
if (nfqa[NFQA_L2HDR]) { if (nfqa[NFQA_L2HDR]) {
......
...@@ -63,7 +63,7 @@ static int tcf_vlan_act(struct sk_buff *skb, const struct tc_action *a, ...@@ -63,7 +63,7 @@ static int tcf_vlan_act(struct sk_buff *skb, const struct tc_action *a,
/* extract existing tag (and guarantee no hw-accel tag) */ /* extract existing tag (and guarantee no hw-accel tag) */
if (skb_vlan_tag_present(skb)) { if (skb_vlan_tag_present(skb)) {
tci = skb_vlan_tag_get(skb); tci = skb_vlan_tag_get(skb);
skb->vlan_tci = 0; __vlan_hwaccel_clear_tag(skb);
} else { } else {
/* in-payload vlan tag, pop it */ /* in-payload vlan tag, pop it */
err = __skb_vlan_pop(skb, &tci); err = __skb_vlan_pop(skb, &tci);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment