[SK_BUFF]: Introduce skb_network_header()
For the places where we need a pointer to the network header, it is still legal to touch skb->nh.raw directly if just adding to, subtracting from or setting it to another layer header. 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
bbe735e424
commit
d56f90a7c9
@@ -120,7 +120,7 @@ extern int cipso_v4_rbm_strictvalid;
|
||||
*/
|
||||
|
||||
#define CIPSO_V4_OPTEXIST(x) (IPCB(x)->opt.cipso != 0)
|
||||
#define CIPSO_V4_OPTPTR(x) ((x)->nh.raw + IPCB(x)->opt.cipso)
|
||||
#define CIPSO_V4_OPTPTR(x) (skb_network_header(x) + IPCB(x)->opt.cipso)
|
||||
|
||||
/*
|
||||
* DOI List Functions
|
||||
|
||||
@@ -114,12 +114,14 @@ static inline int INET_ECN_set_ce(struct sk_buff *skb)
|
||||
{
|
||||
switch (skb->protocol) {
|
||||
case __constant_htons(ETH_P_IP):
|
||||
if (skb->nh.raw + sizeof(struct iphdr) <= skb->tail)
|
||||
if (skb_network_header(skb) + sizeof(struct iphdr) <=
|
||||
skb->tail)
|
||||
return IP_ECN_set_ce(skb->nh.iph);
|
||||
break;
|
||||
|
||||
case __constant_htons(ETH_P_IPV6):
|
||||
if (skb->nh.raw + sizeof(struct ipv6hdr) <= skb->tail)
|
||||
if (skb_network_header(skb) + sizeof(struct ipv6hdr) <=
|
||||
skb->tail)
|
||||
return IP6_ECN_set_ce(skb->nh.ipv6h);
|
||||
break;
|
||||
}
|
||||
|
||||
@@ -203,7 +203,7 @@ struct llc_pdu_sn {
|
||||
|
||||
static inline struct llc_pdu_sn *llc_pdu_sn_hdr(struct sk_buff *skb)
|
||||
{
|
||||
return (struct llc_pdu_sn *)skb->nh.raw;
|
||||
return (struct llc_pdu_sn *)skb_network_header(skb);
|
||||
}
|
||||
|
||||
/* Un-numbered PDU format (3 bytes in length) */
|
||||
@@ -215,7 +215,7 @@ struct llc_pdu_un {
|
||||
|
||||
static inline struct llc_pdu_un *llc_pdu_un_hdr(struct sk_buff *skb)
|
||||
{
|
||||
return (struct llc_pdu_un *)skb->nh.raw;
|
||||
return (struct llc_pdu_un *)skb_network_header(skb);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -326,7 +326,7 @@ static inline unsigned char * tcf_get_base_ptr(struct sk_buff *skb, int layer)
|
||||
case TCF_LAYER_LINK:
|
||||
return skb->data;
|
||||
case TCF_LAYER_NETWORK:
|
||||
return skb->nh.raw;
|
||||
return skb_network_header(skb);
|
||||
case TCF_LAYER_TRANSPORT:
|
||||
return skb->h.raw;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user