mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-05-08 10:48:03 +00:00
MEDIUM: stream_interface: call si_data_close() before releasing the si
This will ensure that the data layer releases anything previously allocated.
This commit is contained in:
parent
24208275d5
commit
4da69a91a0
@ -545,6 +545,7 @@ static int sess_update_st_con_tcp(struct session *s, struct stream_interface *si
|
|||||||
si->flags &= ~SI_FL_CAP_SPLICE;
|
si->flags &= ~SI_FL_CAP_SPLICE;
|
||||||
fd_delete(si_fd(si));
|
fd_delete(si_fd(si));
|
||||||
|
|
||||||
|
si_data_close(si);
|
||||||
if (si->release)
|
if (si->release)
|
||||||
si->release(si);
|
si->release(si);
|
||||||
|
|
||||||
|
@ -811,6 +811,7 @@ static void sock_raw_shutw(struct stream_interface *si)
|
|||||||
case SI_ST_TAR:
|
case SI_ST_TAR:
|
||||||
si->state = SI_ST_DIS;
|
si->state = SI_ST_DIS;
|
||||||
|
|
||||||
|
si_data_close(si);
|
||||||
if (si->release)
|
if (si->release)
|
||||||
si->release(si);
|
si->release(si);
|
||||||
default:
|
default:
|
||||||
@ -845,6 +846,7 @@ static void sock_raw_shutr(struct stream_interface *si)
|
|||||||
si->state = SI_ST_DIS;
|
si->state = SI_ST_DIS;
|
||||||
si->exp = TICK_ETERNITY;
|
si->exp = TICK_ETERNITY;
|
||||||
|
|
||||||
|
si_data_close(si);
|
||||||
if (si->release)
|
if (si->release)
|
||||||
si->release(si);
|
si->release(si);
|
||||||
return;
|
return;
|
||||||
|
@ -227,6 +227,7 @@ static void stream_int_shutr(struct stream_interface *si)
|
|||||||
si->state = SI_ST_DIS;
|
si->state = SI_ST_DIS;
|
||||||
si->exp = TICK_ETERNITY;
|
si->exp = TICK_ETERNITY;
|
||||||
|
|
||||||
|
si_data_close(si);
|
||||||
if (si->release)
|
if (si->release)
|
||||||
si->release(si);
|
si->release(si);
|
||||||
}
|
}
|
||||||
@ -263,6 +264,7 @@ static void stream_int_shutw(struct stream_interface *si)
|
|||||||
si->state = SI_ST_DIS;
|
si->state = SI_ST_DIS;
|
||||||
/* fall through */
|
/* fall through */
|
||||||
|
|
||||||
|
si_data_close(si);
|
||||||
if (si->release)
|
if (si->release)
|
||||||
si->release(si);
|
si->release(si);
|
||||||
default:
|
default:
|
||||||
|
Loading…
Reference in New Issue
Block a user