Skip to content

Commit

Permalink
Release 1.15.0
Browse files Browse the repository at this point in the history
- [API Change] Add LSCONN_ST_PEER_GOING_AWAY to the list of conn statuses
- [BUGFIX] free uncompressed headers correctly when error occurs
  • Loading branch information
Dmitri Tikhonov committed Sep 27, 2018
1 parent 3229dd1 commit 0a19f39
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 14 deletions.
5 changes: 5 additions & 0 deletions CHANGELOG
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
2018-09-27
- 1.15.0
- [API Change] Add LSCONN_ST_PEER_GOING_AWAY to the list of conn statuses
- [BUGFIX] free uncompressed headers correctly when error occurs

2018-09-12
- 1.14.3
- [BUGFIX] Do not abort conn on STREAM frame for a reset stream
Expand Down
5 changes: 3 additions & 2 deletions include/lsquic.h
Original file line number Diff line number Diff line change
Expand Up @@ -24,8 +24,8 @@ extern "C" {
#endif

#define LSQUIC_MAJOR_VERSION 1
#define LSQUIC_MINOR_VERSION 14
#define LSQUIC_PATCH_VERSION 3
#define LSQUIC_MINOR_VERSION 15
#define LSQUIC_PATCH_VERSION 0

/**
* Engine flags:
Expand Down Expand Up @@ -1052,6 +1052,7 @@ enum LSQUIC_CONN_STATUS
LSCONN_ST_USER_ABORTED,
LSCONN_ST_ERROR,
LSCONN_ST_CLOSED,
LSCONN_ST_PEER_GOING_AWAY,
};

enum LSQUIC_CONN_STATUS
Expand Down
37 changes: 25 additions & 12 deletions src/liblsquic/lsquic_full_conn.c
Original file line number Diff line number Diff line change
Expand Up @@ -3300,19 +3300,29 @@ headers_stream_on_incoming_headers (void *ctx, struct uncompressed_headers *uh)
stream = find_stream_on_non_stream_frame(conn, uh->uh_stream_id, 0,
"headers");
if (!stream)
goto free_uh;

if (lsquic_stream_is_reset(stream))
{
free(uh);
return;
LSQ_DEBUG("stream is reset: ignore headers");
goto free_uh;
}

if (0 != lsquic_stream_uh_in(stream, uh))
{
ABORT_ERROR("stream %u refused incoming headers", uh->uh_stream_id);
free(uh);
goto free_uh;
}

if (!(stream->stream_flags & STREAM_ONNEW_DONE))
lsquic_stream_call_on_new(stream);

return;

free_uh:
if (uh->uh_hset)
conn->fc_enpub->enp_hsi_if->hsi_discard_header_set(uh->uh_hset);
free(uh);
}


Expand All @@ -3332,26 +3342,23 @@ headers_stream_on_push_promise (void *ctx, struct uncompressed_headers *uh)
{
ABORT_ERROR("invalid push promise stream IDs: %u, %u",
uh->uh_oth_stream_id, uh->uh_stream_id);
free(uh);
return;
goto free_uh;
}

if (!(conn_is_stream_closed(conn, uh->uh_stream_id) ||
find_stream_by_id(conn, uh->uh_stream_id)))
{
ABORT_ERROR("invalid push promise original stream ID %u never "
"initiated", uh->uh_stream_id);
free(uh);
return;
goto free_uh;
}

if (conn_is_stream_closed(conn, uh->uh_oth_stream_id) ||
find_stream_by_id(conn, uh->uh_oth_stream_id))
{
ABORT_ERROR("invalid promised stream ID %u already used",
uh->uh_oth_stream_id);
free(uh);
return;
goto free_uh;
}

stream = new_stream_ext(conn, uh->uh_oth_stream_id, STREAM_IF_STD,
Expand All @@ -3360,12 +3367,16 @@ headers_stream_on_push_promise (void *ctx, struct uncompressed_headers *uh)
if (!stream)
{
ABORT_ERROR("cannot create stream: %s", strerror(errno));
free(uh);
return;
goto free_uh;
}
lsquic_stream_push_req(stream, uh);
lsquic_stream_call_on_new(stream);
return;

free_uh:
if (uh->uh_hset)
conn->fc_enpub->enp_hsi_if->hsi_discard_header_set(uh->uh_hset);
free(uh);
}


Expand Down Expand Up @@ -3420,7 +3431,9 @@ lsquic_conn_status (lsquic_conn_t *lconn, char *errbuf, size_t bufsz)
|FC_CLOSING
|FC_GOING_AWAY)))
{
if (lconn->cn_flags & LSCONN_HANDSHAKE_DONE)
if (lconn->cn_flags & LSCONN_PEER_GOING_AWAY)
return LSCONN_ST_PEER_GOING_AWAY;
else if (lconn->cn_flags & LSCONN_HANDSHAKE_DONE)
return LSCONN_ST_CONNECTED;
else
return LSCONN_ST_HSK_IN_PROGRESS;
Expand Down

0 comments on commit 0a19f39

Please sign in to comment.