From c08a6bf430b381c31e0152c640a030cbcc9858c8 Mon Sep 17 00:00:00 2001 From: "V.G. Bulavintsev" Date: Wed, 7 Mar 2018 16:44:35 +0100 Subject: [PATCH] Make SACK header to be able to take up the whole packet. Rename m_in_buf_size to m_receive_buffer_capacity --- src/utp_stream.cpp | 48 +++++++++++++++++++++++++--------------------- 1 file changed, 26 insertions(+), 22 deletions(-) diff --git a/src/utp_stream.cpp b/src/utp_stream.cpp index 6bc1b1aea..d68edff14 100644 --- a/src/utp_stream.cpp +++ b/src/utp_stream.cpp @@ -136,7 +136,6 @@ enum { ACK_MASK = 0xffff, - // if a packet receives more than this number of // duplicate acks, we'll trigger a fast re-send dup_ack_limit = 3, @@ -279,7 +278,7 @@ struct utp_socket_impl , m_written(0) , m_receive_buffer_size(0) , m_read_buffer_size(0) - , m_in_buf_size(1024 * 1024) + , m_receive_buffer_capacity(1024 * 1024) , m_in_packets(0) , m_out_packets(0) , m_send_delay(0) @@ -530,7 +529,7 @@ public: boost::int32_t m_read_buffer_size; // max number of bytes to allocate for receive buffer - boost::int32_t m_in_buf_size; + boost::int32_t m_receive_buffer_capacity; // this holds the 3 last delay measurements, // these are the actual corrected delay measurements. @@ -1790,16 +1789,6 @@ bool utp_socket_impl::send_pkt(int const flags) m_fast_resend_seq_nr = (m_fast_resend_seq_nr + 1) & ACK_MASK; } - int sack = 0; - if (m_inbuf.size()) - { - // the SACK bitfield should ideally fit all - // the pieces we have successfully received - sack = (m_inbuf.span() + 7) / 8; - if (sack > 32) sack = 32; - } - - boost::uint32_t const close_reason = m_close_reason; // MTU DISCOVERY @@ -1813,13 +1802,29 @@ bool utp_socket_impl::send_pkt(int const flags) && m_write_buffer_size >= m_mtu_floor * 3 && m_seq_nr != 0 && (m_cwnd >> 16) > m_mtu_floor * 3); + // for non MTU-probes, use the conservative packet size + int const effective_mtu = mtu_probe ? m_mtu : m_mtu_floor; + + boost::uint32_t const close_reason = m_close_reason; + + int sack = 0; + if (m_inbuf.size()) + { + const int max_sack_size = effective_mtu + - sizeof(utp_header) + - 2 // for sack padding/header + - (close_reason ? 6 : 0); + + // the SACK bitfield should ideally fit all + // the pieces we have successfully received + sack = (m_inbuf.span() + 7) / 8; + if (sack > max_sack_size) sack = max_sack_size; + } int const header_size = sizeof(utp_header) + (sack ? sack + 2 : 0) + (close_reason ? 6 : 0); - // for non MTU-probes, use the conservative packet size - int const effective_mtu = mtu_probe ? m_mtu : m_mtu_floor; int payload_size = (std::min)(m_write_buffer_size , effective_mtu - header_size); TORRENT_ASSERT(payload_size >= 0); @@ -2046,7 +2051,7 @@ bool utp_socket_impl::send_pkt(int const flags) } h->timestamp_difference_microseconds = m_reply_micro; - h->wnd_size = (std::max)(m_in_buf_size - m_buffered_incoming_bytes + h->wnd_size = (std::max)(m_receive_buffer_capacity - m_buffered_incoming_bytes - m_receive_buffer_size, boost::int32_t(0)); h->ack_nr = m_ack_nr; @@ -2547,7 +2552,7 @@ bool utp_socket_impl::consume_incoming_data( } if (m_read_buffer_size == 0 - && m_receive_buffer_size >= m_in_buf_size - m_buffered_incoming_bytes) + && m_receive_buffer_size >= m_receive_buffer_capacity - m_buffered_incoming_bytes) { // if we don't have a buffer from the upper layer, and the // number of queued up bytes, waiting for the upper layer, @@ -2555,7 +2560,7 @@ bool utp_socket_impl::consume_incoming_data( // more data packets UTP_LOG("%8p: ERROR: our advertized window is not honored. " "recv_buf: %d buffered_in: %d max_size: %d\n" - , static_cast(this), m_receive_buffer_size, m_buffered_incoming_bytes, m_in_buf_size); + , static_cast(this), m_receive_buffer_size, m_buffered_incoming_bytes, m_receive_buffer_capacity); return false; } @@ -2563,7 +2568,7 @@ bool utp_socket_impl::consume_incoming_data( { TORRENT_ASSERT(m_inbuf.at(m_ack_nr) == 0); - if (m_buffered_incoming_bytes + m_receive_buffer_size + payload_size > m_in_buf_size) + if (m_buffered_incoming_bytes + m_receive_buffer_size + payload_size > m_receive_buffer_capacity) { UTP_LOGV("%8p: other end is not honoring our advertised window, dropping packet\n" , static_cast(this)); @@ -2620,7 +2625,7 @@ bool utp_socket_impl::consume_incoming_data( return true; } - if (m_buffered_incoming_bytes + m_receive_buffer_size + payload_size > m_in_buf_size) + if (m_buffered_incoming_bytes + m_receive_buffer_size + payload_size > m_receive_buffer_capacity) { UTP_LOGV("%8p: other end is not honoring our advertised window, dropping packet %d\n" , static_cast(this), int(ph->seq_nr)); @@ -2861,8 +2866,7 @@ bool utp_socket_impl::incoming_packet(boost::uint8_t const* buf, int size m_sm->inc_stats_counter(counters::utp_payload_pkts_in); // the number of packets that'll fit in the reorder buffer - // incoming MTU of 1100 and minimal size of 16 packets are chosen arbitrarly - const boost::uint32_t max_packets_reorder = std::max(16, m_in_buf_size / 1100); + const boost::uint32_t max_packets_reorder = std::max(16, m_receive_buffer_capacity / 1100); if (m_state != UTP_STATE_NONE && m_state != UTP_STATE_SYN_SENT