mirror of
http://git.haproxy.org/git/haproxy.git
synced 2026-02-12 13:03:02 +02:00
BUG/MINOR: mux-h2: make sure the h2c task exists before refreshing it
When detaching a stream, if it's the last one and the mbuf is blocked, we leave without freeing the stream yet. We also refresh the h2c task's timeout, except that it's possible that there's no such task in case there is no client timeout, causing a crash. The fix just consists in doing this when the task exists. This bug has always been there and is extremely hard to meet even without a client timeout. This fix has to be backported to all branches, but it's unlikely anyone has ever met it anyay.
This commit is contained in:
@@ -4312,7 +4312,7 @@ static void h2_detach(struct sedesc *sd)
|
||||
/* refresh the timeout if none was active, so that the last
|
||||
* leaving stream may arm it.
|
||||
*/
|
||||
if (!tick_isset(h2c->task->expire))
|
||||
if (h2c->task && !tick_isset(h2c->task->expire))
|
||||
h2c_update_timeout(h2c);
|
||||
return;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user