[SK_BUFF]: Introduce skb_reset_mac_header(skb)
For the common, open coded 'skb->mac.raw = skb->data' operation, so that we can later turn skb->mac.raw into a offset, reducing the size of struct sk_buff in 64bit land while possibly keeping it as a pointer on 32bit. This one touches just the most simple case, next will handle the slightly more "complex" cases. Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
4c13eb6657
commit
459a98ed88
@@ -167,7 +167,7 @@ hdr->f.status = s; hdr->f.len = l; hdr->f.data = d
|
||||
|
||||
ret = skb->len - phdrlen;
|
||||
skb->dev = dev;
|
||||
skb->mac.raw = skb->data;
|
||||
skb_reset_mac_header(skb);
|
||||
skb_pull(skb, hdrlen);
|
||||
if (prism_header)
|
||||
skb_pull(skb, phdrlen);
|
||||
@@ -1073,10 +1073,11 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb,
|
||||
|
||||
if (skb2 != NULL) {
|
||||
/* send to wireless media */
|
||||
skb2->protocol = __constant_htons(ETH_P_802_3);
|
||||
skb2->mac.raw = skb2->nh.raw = skb2->data;
|
||||
/* skb2->nh.raw = skb2->data + ETH_HLEN; */
|
||||
skb2->dev = dev;
|
||||
skb2->protocol = __constant_htons(ETH_P_802_3);
|
||||
skb_reset_mac_header(skb2);
|
||||
skb2->nh.raw = skb2->data;
|
||||
/* skb2->nh.raw = skb2->data + ETH_HLEN; */
|
||||
dev_queue_xmit(skb2);
|
||||
}
|
||||
|
||||
|
@@ -237,7 +237,7 @@ int hostap_data_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
iface->stats.tx_packets++;
|
||||
iface->stats.tx_bytes += skb->len;
|
||||
|
||||
skb->mac.raw = skb->data;
|
||||
skb_reset_mac_header(skb);
|
||||
meta = (struct hostap_skb_tx_data *) skb->cb;
|
||||
memset(meta, 0, sizeof(*meta));
|
||||
meta->magic = HOSTAP_SKB_TX_DATA_MAGIC;
|
||||
|
@@ -982,7 +982,8 @@ static void prism2_send_mgmt(struct net_device *dev,
|
||||
meta->tx_cb_idx = tx_cb_idx;
|
||||
|
||||
skb->dev = dev;
|
||||
skb->mac.raw = skb->nh.raw = skb->data;
|
||||
skb_reset_mac_header(skb);
|
||||
skb->nh.raw = skb->data;
|
||||
dev_queue_xmit(skb);
|
||||
}
|
||||
#endif /* PRISM2_NO_KERNEL_IEEE80211_MGMT */
|
||||
|
@@ -2217,7 +2217,7 @@ static void hostap_tx_callback(local_info_t *local,
|
||||
memcpy(skb_put(skb, len), payload, len);
|
||||
|
||||
skb->dev = local->dev;
|
||||
skb->mac.raw = skb->data;
|
||||
skb_reset_mac_header(skb);
|
||||
|
||||
cb->func(skb, ok, cb->data);
|
||||
}
|
||||
|
@@ -1063,7 +1063,8 @@ int prism2_sta_send_mgmt(local_info_t *local, u8 *dst, u16 stype,
|
||||
meta->iface = netdev_priv(dev);
|
||||
|
||||
skb->dev = dev;
|
||||
skb->mac.raw = skb->nh.raw = skb->data;
|
||||
skb_reset_mac_header(skb);
|
||||
skb->nh.raw = skb->data;
|
||||
dev_queue_xmit(skb);
|
||||
|
||||
return 0;
|
||||
|
Reference in New Issue
Block a user