diff --git a/include/types/connection.h b/include/types/connection.h index 5af651ff5..72562194d 100644 --- a/include/types/connection.h +++ b/include/types/connection.h @@ -259,6 +259,7 @@ enum { enum { CO_RFL_BUF_WET = 0x0001, /* Buffer still has some output data present */ CO_RFL_BUF_FLUSH = 0x0002, /* Flush mux's buffers but don't read more data */ + CO_RFL_KEEP_RSV = 0x0004, /* Don't fill the reserved space */ }; /* flags that can be passed to xprt->snd_buf() and mux->snd_buf() */ diff --git a/src/stream_interface.c b/src/stream_interface.c index 8742a400f..3c7284f6c 100644 --- a/src/stream_interface.c +++ b/src/stream_interface.c @@ -1210,7 +1210,10 @@ int si_cs_recv(struct conn_stream *cs) * CS_FL_RCV_MORE on the CS if more space is needed. */ max = channel_recv_max(ic); - ret = cs->conn->mux->rcv_buf(cs, &ic->buf, max, flags | (co_data(ic) ? CO_RFL_BUF_WET : 0)); + ret = cs->conn->mux->rcv_buf(cs, &ic->buf, max, + flags | + (co_data(ic) ? CO_RFL_BUF_WET : 0) | + ((channel_recv_limit(ic) < b_size(&ic->buf)) ? CO_RFL_KEEP_RSV : 0)); if (cs->flags & CS_FL_RCV_MORE) si_rx_room_blk(si);