diff options
Diffstat (limited to 'net/ipv4/tcp_output.c')
-rw-r--r-- | net/ipv4/tcp_output.c | 75 |
1 files changed, 38 insertions, 37 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index 1a630825c45b..803cbfe82fbc 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
@@ -370,7 +370,7 @@ static void tcp_init_nondata_skb(struct sk_buff *skb, u32 seq, u8 flags) | |||
370 | TCP_SKB_CB(skb)->end_seq = seq; | 370 | TCP_SKB_CB(skb)->end_seq = seq; |
371 | } | 371 | } |
372 | 372 | ||
373 | static inline int tcp_urg_mode(const struct tcp_sock *tp) | 373 | static inline bool tcp_urg_mode(const struct tcp_sock *tp) |
374 | { | 374 | { |
375 | return tp->snd_una != tp->snd_up; | 375 | return tp->snd_una != tp->snd_up; |
376 | } | 376 | } |
@@ -1391,20 +1391,20 @@ static int tcp_init_tso_segs(const struct sock *sk, struct sk_buff *skb, | |||
1391 | } | 1391 | } |
1392 | 1392 | ||
1393 | /* Minshall's variant of the Nagle send check. */ | 1393 | /* Minshall's variant of the Nagle send check. */ |
1394 | static inline int tcp_minshall_check(const struct tcp_sock *tp) | 1394 | static inline bool tcp_minshall_check(const struct tcp_sock *tp) |
1395 | { | 1395 | { |
1396 | return after(tp->snd_sml, tp->snd_una) && | 1396 | return after(tp->snd_sml, tp->snd_una) && |
1397 | !after(tp->snd_sml, tp->snd_nxt); | 1397 | !after(tp->snd_sml, tp->snd_nxt); |
1398 | } | 1398 | } |
1399 | 1399 | ||
1400 | /* Return 0, if packet can be sent now without violation Nagle's rules: | 1400 | /* Return false, if packet can be sent now without violation Nagle's rules: |
1401 | * 1. It is full sized. | 1401 | * 1. It is full sized. |
1402 | * 2. Or it contains FIN. (already checked by caller) | 1402 | * 2. Or it contains FIN. (already checked by caller) |
1403 | * 3. Or TCP_CORK is not set, and TCP_NODELAY is set. | 1403 | * 3. Or TCP_CORK is not set, and TCP_NODELAY is set. |
1404 | * 4. Or TCP_CORK is not set, and all sent packets are ACKed. | 1404 | * 4. Or TCP_CORK is not set, and all sent packets are ACKed. |
1405 | * With Minshall's modification: all sent small packets are ACKed. | 1405 | * With Minshall's modification: all sent small packets are ACKed. |
1406 | */ | 1406 | */ |
1407 | static inline int tcp_nagle_check(const struct tcp_sock *tp, | 1407 | static inline bool tcp_nagle_check(const struct tcp_sock *tp, |
1408 | const struct sk_buff *skb, | 1408 | const struct sk_buff *skb, |
1409 | unsigned int mss_now, int nonagle) | 1409 | unsigned int mss_now, int nonagle) |
1410 | { | 1410 | { |
@@ -1413,11 +1413,11 @@ static inline int tcp_nagle_check(const struct tcp_sock *tp, | |||
1413 | (!nonagle && tp->packets_out && tcp_minshall_check(tp))); | 1413 | (!nonagle && tp->packets_out && tcp_minshall_check(tp))); |
1414 | } | 1414 | } |
1415 | 1415 | ||
1416 | /* Return non-zero if the Nagle test allows this packet to be | 1416 | /* Return true if the Nagle test allows this packet to be |
1417 | * sent now. | 1417 | * sent now. |
1418 | */ | 1418 | */ |
1419 | static inline int tcp_nagle_test(const struct tcp_sock *tp, const struct sk_buff *skb, | 1419 | static inline bool tcp_nagle_test(const struct tcp_sock *tp, const struct sk_buff *skb, |
1420 | unsigned int cur_mss, int nonagle) | 1420 | unsigned int cur_mss, int nonagle) |
1421 | { | 1421 | { |
1422 | /* Nagle rule does not apply to frames, which sit in the middle of the | 1422 | /* Nagle rule does not apply to frames, which sit in the middle of the |
1423 | * write_queue (they have no chances to get new data). | 1423 | * write_queue (they have no chances to get new data). |
@@ -1426,24 +1426,25 @@ static inline int tcp_nagle_test(const struct tcp_sock *tp, const struct sk_buff | |||
1426 | * argument based upon the location of SKB in the send queue. | 1426 | * argument based upon the location of SKB in the send queue. |
1427 | */ | 1427 | */ |
1428 | if (nonagle & TCP_NAGLE_PUSH) | 1428 | if (nonagle & TCP_NAGLE_PUSH) |
1429 | return 1; | 1429 | return true; |
1430 | 1430 | ||
1431 | /* Don't use the nagle rule for urgent data (or for the final FIN). | 1431 | /* Don't use the nagle rule for urgent data (or for the final FIN). |
1432 | * Nagle can be ignored during F-RTO too (see RFC4138). | 1432 | * Nagle can be ignored during F-RTO too (see RFC4138). |
1433 | */ | 1433 | */ |
1434 | if (tcp_urg_mode(tp) || (tp->frto_counter == 2) || | 1434 | if (tcp_urg_mode(tp) || (tp->frto_counter == 2) || |
1435 | (TCP_SKB_CB(skb)->tcp_flags & TCPHDR_FIN)) | 1435 | (TCP_SKB_CB(skb)->tcp_flags & TCPHDR_FIN)) |
1436 | return 1; | 1436 | return true; |
1437 | 1437 | ||
1438 | if (!tcp_nagle_check(tp, skb, cur_mss, nonagle)) | 1438 | if (!tcp_nagle_check(tp, skb, cur_mss, nonagle)) |
1439 | return 1; | 1439 | return true; |
1440 | 1440 | ||
1441 | return 0; | 1441 | return false; |
1442 | } | 1442 | } |
1443 | 1443 | ||
1444 | /* Does at least the first segment of SKB fit into the send window? */ | 1444 | /* Does at least the first segment of SKB fit into the send window? */ |
1445 | static inline int tcp_snd_wnd_test(const struct tcp_sock *tp, const struct sk_buff *skb, | 1445 | static bool tcp_snd_wnd_test(const struct tcp_sock *tp, |
1446 | unsigned int cur_mss) | 1446 | const struct sk_buff *skb, |
1447 | unsigned int cur_mss) | ||
1447 | { | 1448 | { |
1448 | u32 end_seq = TCP_SKB_CB(skb)->end_seq; | 1449 | u32 end_seq = TCP_SKB_CB(skb)->end_seq; |
1449 | 1450 | ||
@@ -1476,7 +1477,7 @@ static unsigned int tcp_snd_test(const struct sock *sk, struct sk_buff *skb, | |||
1476 | } | 1477 | } |
1477 | 1478 | ||
1478 | /* Test if sending is allowed right now. */ | 1479 | /* Test if sending is allowed right now. */ |
1479 | int tcp_may_send_now(struct sock *sk) | 1480 | bool tcp_may_send_now(struct sock *sk) |
1480 | { | 1481 | { |
1481 | const struct tcp_sock *tp = tcp_sk(sk); | 1482 | const struct tcp_sock *tp = tcp_sk(sk); |
1482 | struct sk_buff *skb = tcp_send_head(sk); | 1483 | struct sk_buff *skb = tcp_send_head(sk); |
@@ -1546,7 +1547,7 @@ static int tso_fragment(struct sock *sk, struct sk_buff *skb, unsigned int len, | |||
1546 | * | 1547 | * |
1547 | * This algorithm is from John Heffner. | 1548 | * This algorithm is from John Heffner. |
1548 | */ | 1549 | */ |
1549 | static int tcp_tso_should_defer(struct sock *sk, struct sk_buff *skb) | 1550 | static bool tcp_tso_should_defer(struct sock *sk, struct sk_buff *skb) |
1550 | { | 1551 | { |
1551 | struct tcp_sock *tp = tcp_sk(sk); | 1552 | struct tcp_sock *tp = tcp_sk(sk); |
1552 | const struct inet_connection_sock *icsk = inet_csk(sk); | 1553 | const struct inet_connection_sock *icsk = inet_csk(sk); |
@@ -1606,11 +1607,11 @@ static int tcp_tso_should_defer(struct sock *sk, struct sk_buff *skb) | |||
1606 | /* Ok, it looks like it is advisable to defer. */ | 1607 | /* Ok, it looks like it is advisable to defer. */ |
1607 | tp->tso_deferred = 1 | (jiffies << 1); | 1608 | tp->tso_deferred = 1 | (jiffies << 1); |
1608 | 1609 | ||
1609 | return 1; | 1610 | return true; |
1610 | 1611 | ||
1611 | send_now: | 1612 | send_now: |
1612 | tp->tso_deferred = 0; | 1613 | tp->tso_deferred = 0; |
1613 | return 0; | 1614 | return false; |
1614 | } | 1615 | } |
1615 | 1616 | ||
1616 | /* Create a new MTU probe if we are ready. | 1617 | /* Create a new MTU probe if we are ready. |
@@ -1752,11 +1753,11 @@ static int tcp_mtu_probe(struct sock *sk) | |||
1752 | * snd_up-64k-mss .. snd_up cannot be large. However, taking into | 1753 | * snd_up-64k-mss .. snd_up cannot be large. However, taking into |
1753 | * account rare use of URG, this is not a big flaw. | 1754 | * account rare use of URG, this is not a big flaw. |
1754 | * | 1755 | * |
1755 | * Returns 1, if no segments are in flight and we have queued segments, but | 1756 | * Returns true, if no segments are in flight and we have queued segments, |
1756 | * cannot send anything now because of SWS or another problem. | 1757 | * but cannot send anything now because of SWS or another problem. |
1757 | */ | 1758 | */ |
1758 | static int tcp_write_xmit(struct sock *sk, unsigned int mss_now, int nonagle, | 1759 | static bool tcp_write_xmit(struct sock *sk, unsigned int mss_now, int nonagle, |
1759 | int push_one, gfp_t gfp) | 1760 | int push_one, gfp_t gfp) |
1760 | { | 1761 | { |
1761 | struct tcp_sock *tp = tcp_sk(sk); | 1762 | struct tcp_sock *tp = tcp_sk(sk); |
1762 | struct sk_buff *skb; | 1763 | struct sk_buff *skb; |
@@ -1770,7 +1771,7 @@ static int tcp_write_xmit(struct sock *sk, unsigned int mss_now, int nonagle, | |||
1770 | /* Do MTU probing. */ | 1771 | /* Do MTU probing. */ |
1771 | result = tcp_mtu_probe(sk); | 1772 | result = tcp_mtu_probe(sk); |
1772 | if (!result) { | 1773 | if (!result) { |
1773 | return 0; | 1774 | return false; |
1774 | } else if (result > 0) { | 1775 | } else if (result > 0) { |
1775 | sent_pkts = 1; | 1776 | sent_pkts = 1; |
1776 | } | 1777 | } |
@@ -1829,7 +1830,7 @@ static int tcp_write_xmit(struct sock *sk, unsigned int mss_now, int nonagle, | |||
1829 | 1830 | ||
1830 | if (likely(sent_pkts)) { | 1831 | if (likely(sent_pkts)) { |
1831 | tcp_cwnd_validate(sk); | 1832 | tcp_cwnd_validate(sk); |
1832 | return 0; | 1833 | return false; |
1833 | } | 1834 | } |
1834 | return !tp->packets_out && tcp_send_head(sk); | 1835 | return !tp->packets_out && tcp_send_head(sk); |
1835 | } | 1836 | } |
@@ -2028,22 +2029,22 @@ static void tcp_collapse_retrans(struct sock *sk, struct sk_buff *skb) | |||
2028 | } | 2029 | } |
2029 | 2030 | ||
2030 | /* Check if coalescing SKBs is legal. */ | 2031 | /* Check if coalescing SKBs is legal. */ |
2031 | static int tcp_can_collapse(const struct sock *sk, const struct sk_buff *skb) | 2032 | static bool tcp_can_collapse(const struct sock *sk, const struct sk_buff *skb) |
2032 | { | 2033 | { |
2033 | if (tcp_skb_pcount(skb) > 1) | 2034 | if (tcp_skb_pcount(skb) > 1) |
2034 | return 0; | 2035 | return false; |
2035 | /* TODO: SACK collapsing could be used to remove this condition */ | 2036 | /* TODO: SACK collapsing could be used to remove this condition */ |
2036 | if (skb_shinfo(skb)->nr_frags != 0) | 2037 | if (skb_shinfo(skb)->nr_frags != 0) |
2037 | return 0; | 2038 | return false; |
2038 | if (skb_cloned(skb)) | 2039 | if (skb_cloned(skb)) |
2039 | return 0; | 2040 | return false; |
2040 | if (skb == tcp_send_head(sk)) | 2041 | if (skb == tcp_send_head(sk)) |
2041 | return 0; | 2042 | return false; |
2042 | /* Some heurestics for collapsing over SACK'd could be invented */ | 2043 | /* Some heurestics for collapsing over SACK'd could be invented */ |
2043 | if (TCP_SKB_CB(skb)->sacked & TCPCB_SACKED_ACKED) | 2044 | if (TCP_SKB_CB(skb)->sacked & TCPCB_SACKED_ACKED) |
2044 | return 0; | 2045 | return false; |
2045 | 2046 | ||
2046 | return 1; | 2047 | return true; |
2047 | } | 2048 | } |
2048 | 2049 | ||
2049 | /* Collapse packets in the retransmit queue to make to create | 2050 | /* Collapse packets in the retransmit queue to make to create |
@@ -2054,7 +2055,7 @@ static void tcp_retrans_try_collapse(struct sock *sk, struct sk_buff *to, | |||
2054 | { | 2055 | { |
2055 | struct tcp_sock *tp = tcp_sk(sk); | 2056 | struct tcp_sock *tp = tcp_sk(sk); |
2056 | struct sk_buff *skb = to, *tmp; | 2057 | struct sk_buff *skb = to, *tmp; |
2057 | int first = 1; | 2058 | bool first = true; |
2058 | 2059 | ||
2059 | if (!sysctl_tcp_retrans_collapse) | 2060 | if (!sysctl_tcp_retrans_collapse) |
2060 | return; | 2061 | return; |
@@ -2068,7 +2069,7 @@ static void tcp_retrans_try_collapse(struct sock *sk, struct sk_buff *to, | |||
2068 | space -= skb->len; | 2069 | space -= skb->len; |
2069 | 2070 | ||
2070 | if (first) { | 2071 | if (first) { |
2071 | first = 0; | 2072 | first = false; |
2072 | continue; | 2073 | continue; |
2073 | } | 2074 | } |
2074 | 2075 | ||
@@ -2208,18 +2209,18 @@ int tcp_retransmit_skb(struct sock *sk, struct sk_buff *skb) | |||
2208 | /* Check if we forward retransmits are possible in the current | 2209 | /* Check if we forward retransmits are possible in the current |
2209 | * window/congestion state. | 2210 | * window/congestion state. |
2210 | */ | 2211 | */ |
2211 | static int tcp_can_forward_retransmit(struct sock *sk) | 2212 | static bool tcp_can_forward_retransmit(struct sock *sk) |
2212 | { | 2213 | { |
2213 | const struct inet_connection_sock *icsk = inet_csk(sk); | 2214 | const struct inet_connection_sock *icsk = inet_csk(sk); |
2214 | const struct tcp_sock *tp = tcp_sk(sk); | 2215 | const struct tcp_sock *tp = tcp_sk(sk); |
2215 | 2216 | ||
2216 | /* Forward retransmissions are possible only during Recovery. */ | 2217 | /* Forward retransmissions are possible only during Recovery. */ |
2217 | if (icsk->icsk_ca_state != TCP_CA_Recovery) | 2218 | if (icsk->icsk_ca_state != TCP_CA_Recovery) |
2218 | return 0; | 2219 | return false; |
2219 | 2220 | ||
2220 | /* No forward retransmissions in Reno are possible. */ | 2221 | /* No forward retransmissions in Reno are possible. */ |
2221 | if (tcp_is_reno(tp)) | 2222 | if (tcp_is_reno(tp)) |
2222 | return 0; | 2223 | return false; |
2223 | 2224 | ||
2224 | /* Yeah, we have to make difficult choice between forward transmission | 2225 | /* Yeah, we have to make difficult choice between forward transmission |
2225 | * and retransmission... Both ways have their merits... | 2226 | * and retransmission... Both ways have their merits... |
@@ -2230,9 +2231,9 @@ static int tcp_can_forward_retransmit(struct sock *sk) | |||
2230 | */ | 2231 | */ |
2231 | 2232 | ||
2232 | if (tcp_may_send_now(sk)) | 2233 | if (tcp_may_send_now(sk)) |
2233 | return 0; | 2234 | return false; |
2234 | 2235 | ||
2235 | return 1; | 2236 | return true; |
2236 | } | 2237 | } |
2237 | 2238 | ||
2238 | /* This gets called after a retransmit timeout, and the initially | 2239 | /* This gets called after a retransmit timeout, and the initially |