Lines Matching refs:cork
952 struct inet_cork *cork, in __ip_append_data() argument
962 struct ip_options *opt = cork->opt; in __ip_append_data()
972 struct rtable *rt = (struct rtable *)cork->dst; in __ip_append_data()
980 mtu = cork->gso_size ? IP_MAX_MTU : cork->fragsize; in __ip_append_data()
981 paged = !!cork->gso_size; in __ip_append_data()
983 if (cork->tx_flags & SKBTX_ANY_TSTAMP && in __ip_append_data()
993 if (cork->length + length > maxnonfragsize - fragheaderlen) { in __ip_append_data()
1006 (!(flags & MSG_MORE) || cork->gso_size) && in __ip_append_data()
1051 cork->length += length; in __ip_append_data()
1178 skb_shinfo(skb)->tx_flags = cork->tx_flags; in __ip_append_data()
1179 cork->tx_flags = 0; in __ip_append_data()
1272 cork->length -= length; in __ip_append_data()
1278 static int ip_setup_cork(struct sock *sk, struct inet_cork *cork, in ip_setup_cork() argument
1293 if (!cork->opt) { in ip_setup_cork()
1294 cork->opt = kmalloc(sizeof(struct ip_options) + 40, in ip_setup_cork()
1296 if (unlikely(!cork->opt)) in ip_setup_cork()
1299 memcpy(cork->opt, &opt->opt, sizeof(struct ip_options) + opt->opt.optlen); in ip_setup_cork()
1300 cork->flags |= IPCORK_OPT; in ip_setup_cork()
1301 cork->addr = ipc->addr; in ip_setup_cork()
1304 cork->fragsize = ip_sk_use_pmtu(sk) ? in ip_setup_cork()
1307 if (!inetdev_valid_mtu(cork->fragsize)) in ip_setup_cork()
1310 cork->gso_size = ipc->gso_size; in ip_setup_cork()
1312 cork->dst = &rt->dst; in ip_setup_cork()
1316 cork->length = 0; in ip_setup_cork()
1317 cork->ttl = ipc->ttl; in ip_setup_cork()
1318 cork->tos = ipc->tos; in ip_setup_cork()
1319 cork->mark = ipc->sockc.mark; in ip_setup_cork()
1320 cork->priority = ipc->priority; in ip_setup_cork()
1321 cork->transmit_time = ipc->sockc.transmit_time; in ip_setup_cork()
1322 cork->tx_flags = 0; in ip_setup_cork()
1323 sock_tx_timestamp(sk, ipc->sockc.tsflags, &cork->tx_flags); in ip_setup_cork()
1353 err = ip_setup_cork(sk, &inet->cork.base, ipc, rtp); in ip_append_data()
1360 return __ip_append_data(sk, fl4, &sk->sk_write_queue, &inet->cork.base, in ip_append_data()
1365 static void ip_cork_release(struct inet_cork *cork) in ip_cork_release() argument
1367 cork->flags &= ~IPCORK_OPT; in ip_cork_release()
1368 kfree(cork->opt); in ip_cork_release()
1369 cork->opt = NULL; in ip_cork_release()
1370 dst_release(cork->dst); in ip_cork_release()
1371 cork->dst = NULL; in ip_cork_release()
1381 struct inet_cork *cork) in __ip_make_skb() argument
1388 struct rtable *rt = (struct rtable *)cork->dst; in __ip_make_skb()
1427 if (cork->flags & IPCORK_OPT) in __ip_make_skb()
1428 opt = cork->opt; in __ip_make_skb()
1430 if (cork->ttl != 0) in __ip_make_skb()
1431 ttl = cork->ttl; in __ip_make_skb()
1440 iph->tos = (cork->tos != -1) ? cork->tos : inet->tos; in __ip_make_skb()
1449 ip_options_build(skb, opt, cork->addr, rt); in __ip_make_skb()
1452 skb->priority = (cork->tos != -1) ? cork->priority: sk->sk_priority; in __ip_make_skb()
1453 skb->mark = cork->mark; in __ip_make_skb()
1454 skb->tstamp = cork->transmit_time; in __ip_make_skb()
1459 cork->dst = NULL; in __ip_make_skb()
1477 ip_cork_release(cork); in __ip_make_skb()
1514 struct inet_cork *cork) in __ip_flush_pending_frames() argument
1521 ip_cork_release(cork); in __ip_flush_pending_frames()
1526 __ip_flush_pending_frames(sk, &sk->sk_write_queue, &inet_sk(sk)->cork.base); in ip_flush_pending_frames()
1535 struct inet_cork *cork, unsigned int flags) in ip_make_skb() argument
1545 cork->flags = 0; in ip_make_skb()
1546 cork->addr = 0; in ip_make_skb()
1547 cork->opt = NULL; in ip_make_skb()
1548 err = ip_setup_cork(sk, cork, ipc, rtp); in ip_make_skb()
1552 err = __ip_append_data(sk, fl4, &queue, cork, in ip_make_skb()
1556 __ip_flush_pending_frames(sk, &queue, cork); in ip_make_skb()
1560 return __ip_make_skb(sk, fl4, &queue, cork); in ip_make_skb()