Lines Matching refs:frag

702 	iter->frag = skb_shinfo(skb)->frag_list;  in ip6_fraglist_init()
733 struct sk_buff *frag = iter->frag; in ip6_fraglist_prepare() local
737 frag->ip_summed = CHECKSUM_NONE; in ip6_fraglist_prepare()
738 skb_reset_transport_header(frag); in ip6_fraglist_prepare()
739 fh = __skb_push(frag, sizeof(struct frag_hdr)); in ip6_fraglist_prepare()
740 __skb_push(frag, hlen); in ip6_fraglist_prepare()
741 skb_reset_network_header(frag); in ip6_fraglist_prepare()
742 memcpy(skb_network_header(frag), iter->tmp_hdr, hlen); in ip6_fraglist_prepare()
747 if (frag->next) in ip6_fraglist_prepare()
750 ipv6_hdr(frag)->payload_len = htons(frag->len - sizeof(struct ipv6hdr)); in ip6_fraglist_prepare()
751 ip6_copy_metadata(frag, skb); in ip6_fraglist_prepare()
779 struct sk_buff *frag; in ip6_frag_next() local
793 frag = alloc_skb(len + state->hlen + sizeof(struct frag_hdr) + in ip6_frag_next()
795 if (!frag) in ip6_frag_next()
802 ip6_copy_metadata(frag, skb); in ip6_frag_next()
803 skb_reserve(frag, state->hroom); in ip6_frag_next()
804 skb_put(frag, len + state->hlen + sizeof(struct frag_hdr)); in ip6_frag_next()
805 skb_reset_network_header(frag); in ip6_frag_next()
806 fh = (struct frag_hdr *)(skb_network_header(frag) + state->hlen); in ip6_frag_next()
807 frag->transport_header = (frag->network_header + state->hlen + in ip6_frag_next()
815 skb_set_owner_w(frag, skb->sk); in ip6_frag_next()
820 skb_copy_from_linear_data(skb, skb_network_header(frag), state->hlen); in ip6_frag_next()
822 fragnexthdr_offset = skb_network_header(frag); in ip6_frag_next()
836 BUG_ON(skb_copy_bits(skb, state->ptr, skb_transport_header(frag), in ip6_frag_next()
843 ipv6_hdr(frag)->payload_len = htons(frag->len - sizeof(struct ipv6hdr)); in ip6_frag_next()
848 return frag; in ip6_frag_next()
855 struct sk_buff *frag; in ip6_fragment() local
920 skb_walk_frags(skb, frag) { in ip6_fragment()
922 if (frag->len > mtu || in ip6_fragment()
923 ((frag->len & 7) && frag->next) || in ip6_fragment()
924 skb_headroom(frag) < (hlen + hroom + sizeof(struct frag_hdr))) in ip6_fragment()
928 if (skb_shared(frag)) in ip6_fragment()
931 BUG_ON(frag->sk); in ip6_fragment()
933 frag->sk = skb->sk; in ip6_fragment()
934 frag->destructor = sock_wfree; in ip6_fragment()
936 skb->truesize -= frag->truesize; in ip6_fragment()
950 if (iter.frag) in ip6_fragment()
959 if (err || !iter.frag) in ip6_fragment()
974 kfree_skb_list(iter.frag); in ip6_fragment()
983 if (frag2 == frag) in ip6_fragment()
1005 frag = ip6_frag_next(skb, &state); in ip6_fragment()
1006 if (IS_ERR(frag)) { in ip6_fragment()
1007 err = PTR_ERR(frag); in ip6_fragment()
1014 skb_set_delivery_time(frag, tstamp, mono_delivery_time); in ip6_fragment()
1015 err = output(net, sk, frag); in ip6_fragment()