BUG/MINOR: quic: fix crash on quic_conn alloc failure
If there is an alloc failure during qc_new_conn(), cleaning is done via quic_conn_release(). However, since the below commit, an unchecked dereferencing of <qc.path> is performed in the latter. e841164a4402118bd7b2e2dc2b5068f21de5d9d2 MINOR: quic: account for global congestion window To fix this, simply check <qc.path> before dereferencing it in quic_conn_release(). This is safe as it is properly initialized to NULL on qc_new_conn() first stage. This does not need to be backported.
This commit is contained in:
parent
099c1b2442
commit
d358da4d83
@ -1448,8 +1448,10 @@ int quic_conn_release(struct quic_conn *qc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Substract last congestion window from global memory counter. */
|
/* Substract last congestion window from global memory counter. */
|
||||||
cshared_add(&quic_mem_diff, -qc->path->cwnd);
|
if (qc->path) {
|
||||||
qc->path->cwnd = 0;
|
cshared_add(&quic_mem_diff, -qc->path->cwnd);
|
||||||
|
qc->path->cwnd = 0;
|
||||||
|
}
|
||||||
|
|
||||||
/* free remaining stream descriptors */
|
/* free remaining stream descriptors */
|
||||||
node = eb64_first(&qc->streams_by_id);
|
node = eb64_first(&qc->streams_by_id);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user