Lines Matching refs:skb
14 static struct sk_buff *gre_gso_segment(struct sk_buff *skb, in gre_gso_segment() argument
17 int tnl_hlen = skb_inner_mac_header(skb) - skb_transport_header(skb); in gre_gso_segment()
19 u16 mac_offset = skb->mac_header; in gre_gso_segment()
20 __be16 protocol = skb->protocol; in gre_gso_segment()
21 u16 mac_len = skb->mac_len; in gre_gso_segment()
25 if (!skb->encapsulation) in gre_gso_segment()
31 if (unlikely(!pskb_may_pull(skb, tnl_hlen))) in gre_gso_segment()
35 skb->encapsulation = 0; in gre_gso_segment()
36 SKB_GSO_CB(skb)->encap_level = 0; in gre_gso_segment()
37 __skb_pull(skb, tnl_hlen); in gre_gso_segment()
38 skb_reset_mac_header(skb); in gre_gso_segment()
39 skb_set_network_header(skb, skb_inner_network_offset(skb)); in gre_gso_segment()
40 skb->mac_len = skb_inner_network_offset(skb); in gre_gso_segment()
41 skb->protocol = skb->inner_protocol; in gre_gso_segment()
43 need_csum = !!(skb_shinfo(skb)->gso_type & SKB_GSO_GRE_CSUM); in gre_gso_segment()
44 skb->encap_hdr_csum = need_csum; in gre_gso_segment()
46 features &= skb->dev->hw_enc_features; in gre_gso_segment()
49 segs = skb_mac_gso_segment(skb, features); in gre_gso_segment()
51 skb_gso_error_unwind(skb, protocol, tnl_hlen, mac_offset, in gre_gso_segment()
58 outer_hlen = skb_tnl_header_len(skb); in gre_gso_segment()
60 skb = segs; in gre_gso_segment()
66 if (skb->ip_summed == CHECKSUM_PARTIAL) { in gre_gso_segment()
67 skb_reset_inner_headers(skb); in gre_gso_segment()
68 skb->encapsulation = 1; in gre_gso_segment()
71 skb->mac_len = mac_len; in gre_gso_segment()
72 skb->protocol = protocol; in gre_gso_segment()
74 __skb_push(skb, outer_hlen); in gre_gso_segment()
75 skb_reset_mac_header(skb); in gre_gso_segment()
76 skb_set_network_header(skb, mac_len); in gre_gso_segment()
77 skb_set_transport_header(skb, gre_offset); in gre_gso_segment()
82 greh = (struct gre_base_hdr *)skb_transport_header(skb); in gre_gso_segment()
85 if (gso_partial && skb_is_gso(skb)) { in gre_gso_segment()
92 partial_adj = skb->len + skb_headroom(skb) - in gre_gso_segment()
93 SKB_GSO_CB(skb)->data_offset - in gre_gso_segment()
94 skb_shinfo(skb)->gso_size; in gre_gso_segment()
101 *pcsum = gso_make_checksum(skb, 0); in gre_gso_segment()
102 } while ((skb = skb->next)); in gre_gso_segment()
108 struct sk_buff *skb) in gre_gro_receive() argument
119 if (NAPI_GRO_CB(skb)->encap_mark) in gre_gro_receive()
122 NAPI_GRO_CB(skb)->encap_mark = 1; in gre_gro_receive()
124 off = skb_gro_offset(skb); in gre_gro_receive()
126 greh = skb_gro_header_fast(skb, off); in gre_gro_receive()
127 if (skb_gro_header_hard(skb, hlen)) { in gre_gro_receive()
128 greh = skb_gro_header_slow(skb, hlen, off); in gre_gro_receive()
147 if ((greh->flags & GRE_CSUM) && NAPI_GRO_CB(skb)->is_fou) in gre_gro_receive()
166 if (skb_gro_header_hard(skb, hlen)) { in gre_gro_receive()
167 greh = skb_gro_header_slow(skb, hlen, off); in gre_gro_receive()
173 if ((greh->flags & GRE_CSUM) && !NAPI_GRO_CB(skb)->flush) { in gre_gro_receive()
174 if (skb_gro_checksum_simple_validate(skb)) in gre_gro_receive()
177 skb_gro_checksum_try_convert(skb, IPPROTO_GRE, 0, in gre_gro_receive()
211 skb_gro_pull(skb, grehlen); in gre_gro_receive()
214 skb_gro_postpull_rcsum(skb, greh, grehlen); in gre_gro_receive()
216 pp = call_gro_receive(ptype->callbacks.gro_receive, head, skb); in gre_gro_receive()
222 skb_gro_flush_final(skb, pp, flush); in gre_gro_receive()
227 static int gre_gro_complete(struct sk_buff *skb, int nhoff) in gre_gro_complete() argument
229 struct gre_base_hdr *greh = (struct gre_base_hdr *)(skb->data + nhoff); in gre_gro_complete()
235 skb->encapsulation = 1; in gre_gro_complete()
236 skb_shinfo(skb)->gso_type = SKB_GSO_GRE; in gre_gro_complete()
248 err = ptype->callbacks.gro_complete(skb, nhoff + grehlen); in gre_gro_complete()
252 skb_set_inner_mac_header(skb, nhoff + grehlen); in gre_gro_complete()