mirror of
https://gitea.invidious.io/iv-org/litespeed-quic.git
synced 2024-08-15 00:53:43 +00:00
Release 3.1.1
This commit is contained in:
parent
a74702c630
commit
0a4f8953dc
6 changed files with 20 additions and 16 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
2022-05-13
|
||||||
|
- 3.1.1
|
||||||
|
- Fix memory leak in processing stream frames (isse #368)
|
||||||
|
|
||||||
2022-05-06
|
2022-05-06
|
||||||
- 3.1.0
|
- 3.1.0
|
||||||
- Better handling of transport parameter max_table_capcity < 32
|
- Better handling of transport parameter max_table_capcity < 32
|
||||||
|
|
|
@ -26,7 +26,7 @@ author = u'LiteSpeed Technologies'
|
||||||
# The short X.Y version
|
# The short X.Y version
|
||||||
version = u'3.1'
|
version = u'3.1'
|
||||||
# The full version, including alpha/beta/rc tags
|
# The full version, including alpha/beta/rc tags
|
||||||
release = u'3.1.0'
|
release = u'3.1.1'
|
||||||
|
|
||||||
|
|
||||||
# -- General configuration ---------------------------------------------------
|
# -- General configuration ---------------------------------------------------
|
||||||
|
|
|
@ -25,7 +25,7 @@ extern "C" {
|
||||||
|
|
||||||
#define LSQUIC_MAJOR_VERSION 3
|
#define LSQUIC_MAJOR_VERSION 3
|
||||||
#define LSQUIC_MINOR_VERSION 1
|
#define LSQUIC_MINOR_VERSION 1
|
||||||
#define LSQUIC_PATCH_VERSION 0
|
#define LSQUIC_PATCH_VERSION 1
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Engine flags:
|
* Engine flags:
|
||||||
|
|
|
@ -438,9 +438,13 @@ hash_di_insert_frame (struct data_in *data_in,
|
||||||
ins = lsquic_data_in_hash_insert_data_frame(data_in, data_frame,
|
ins = lsquic_data_in_hash_insert_data_frame(data_in, data_frame,
|
||||||
read_offset);
|
read_offset);
|
||||||
assert(ins != INS_FRAME_OVERLAP);
|
assert(ins != INS_FRAME_OVERLAP);
|
||||||
|
/* NOTE: Only release packet and frame for INS_FRAME_OK,
|
||||||
|
* other cases are handled by caller */
|
||||||
|
if (ins == INS_FRAME_OK)
|
||||||
|
{
|
||||||
lsquic_packet_in_put(hdi->hdi_conn_pub->mm, new_frame->packet_in);
|
lsquic_packet_in_put(hdi->hdi_conn_pub->mm, new_frame->packet_in);
|
||||||
if (ins != INS_FRAME_OK)
|
|
||||||
lsquic_malo_put(new_frame);
|
lsquic_malo_put(new_frame);
|
||||||
|
}
|
||||||
return ins;
|
return ins;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -395,8 +395,6 @@ nocopy_di_insert_frame (struct data_in *data_in,
|
||||||
break;
|
break;
|
||||||
case INS_FRAME_DUP:
|
case INS_FRAME_DUP:
|
||||||
case INS_FRAME_ERR:
|
case INS_FRAME_ERR:
|
||||||
lsquic_packet_in_put(ncdi->ncdi_conn_pub->mm, new_frame->packet_in);
|
|
||||||
lsquic_malo_put(new_frame);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -1095,12 +1095,11 @@ lsquic_stream_frame_in (lsquic_stream_t *stream, stream_frame_t *frame)
|
||||||
LSQ_DEBUG("received stream frame, offset %"PRIu64", len %u; "
|
LSQ_DEBUG("received stream frame, offset %"PRIu64", len %u; "
|
||||||
"fin: %d", frame->data_frame.df_offset, frame->data_frame.df_size, !!frame->data_frame.df_fin);
|
"fin: %d", frame->data_frame.df_offset, frame->data_frame.df_size, !!frame->data_frame.df_fin);
|
||||||
|
|
||||||
|
rv = -1;
|
||||||
if ((stream->sm_bflags & SMBF_USE_HEADERS)
|
if ((stream->sm_bflags & SMBF_USE_HEADERS)
|
||||||
&& (stream->stream_flags & STREAM_HEAD_IN_FIN))
|
&& (stream->stream_flags & STREAM_HEAD_IN_FIN))
|
||||||
{
|
{
|
||||||
lsquic_packet_in_put(stream->conn_pub->mm, frame->packet_in);
|
goto release_packet_frame;
|
||||||
lsquic_malo_put(frame);
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (frame->data_frame.df_fin && (stream->sm_bflags & SMBF_IETF)
|
if (frame->data_frame.df_fin && (stream->sm_bflags & SMBF_IETF)
|
||||||
|
@ -1112,7 +1111,7 @@ lsquic_stream_frame_in (lsquic_stream_t *stream, stream_frame_t *frame)
|
||||||
"new final size %"PRIu64" from STREAM frame (id: %"PRIu64") does "
|
"new final size %"PRIu64" from STREAM frame (id: %"PRIu64") does "
|
||||||
"not match previous final size %"PRIu64, DF_END(frame),
|
"not match previous final size %"PRIu64, DF_END(frame),
|
||||||
stream->id, stream->sm_fin_off);
|
stream->id, stream->sm_fin_off);
|
||||||
return -1;
|
goto release_packet_frame;
|
||||||
}
|
}
|
||||||
|
|
||||||
got_next_offset = frame->data_frame.df_offset == stream->read_offset;
|
got_next_offset = frame->data_frame.df_offset == stream->read_offset;
|
||||||
|
@ -1123,7 +1122,6 @@ lsquic_stream_frame_in (lsquic_stream_t *stream, stream_frame_t *frame)
|
||||||
/* Update maximum offset in the flow controller and check for flow
|
/* Update maximum offset in the flow controller and check for flow
|
||||||
* control violation:
|
* control violation:
|
||||||
*/
|
*/
|
||||||
rv = -1;
|
|
||||||
free_frame = !stream->data_in->di_if->di_own_on_ok;
|
free_frame = !stream->data_in->di_if->di_own_on_ok;
|
||||||
max_off = frame->data_frame.df_offset + frame->data_frame.df_size;
|
max_off = frame->data_frame.df_offset + frame->data_frame.df_size;
|
||||||
if (0 != lsquic_stream_update_sfcw(stream, max_off))
|
if (0 != lsquic_stream_update_sfcw(stream, max_off))
|
||||||
|
@ -1150,7 +1148,7 @@ lsquic_stream_frame_in (lsquic_stream_t *stream, stream_frame_t *frame)
|
||||||
}
|
}
|
||||||
else if (INS_FRAME_DUP == ins_frame)
|
else if (INS_FRAME_DUP == ins_frame)
|
||||||
{
|
{
|
||||||
return 0;
|
rv = 0;
|
||||||
}
|
}
|
||||||
else if (INS_FRAME_OVERLAP == ins_frame)
|
else if (INS_FRAME_OVERLAP == ins_frame)
|
||||||
{
|
{
|
||||||
|
@ -1160,15 +1158,15 @@ lsquic_stream_frame_in (lsquic_stream_t *stream, stream_frame_t *frame)
|
||||||
if (stream->data_in)
|
if (stream->data_in)
|
||||||
goto insert_frame;
|
goto insert_frame;
|
||||||
stream->data_in = lsquic_data_in_error_new();
|
stream->data_in = lsquic_data_in_error_new();
|
||||||
lsquic_packet_in_put(stream->conn_pub->mm, frame->packet_in);
|
|
||||||
lsquic_malo_put(frame);
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
assert(INS_FRAME_ERR == ins_frame);
|
assert(INS_FRAME_ERR == ins_frame);
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
release_packet_frame:
|
||||||
|
lsquic_packet_in_put(stream->conn_pub->mm, frame->packet_in);
|
||||||
|
lsquic_malo_put(frame);
|
||||||
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue