mirror of
https://github.com/cuberite/libevent.git
synced 2025-09-11 05:14:46 -04:00
Fix subtle recursion in evhttp_connection_cb_cleanup().
This commit is contained in:
parent
272823f8b0
commit
218cf19743
17
http.c
17
http.c
@ -1230,6 +1230,8 @@ evhttp_connection_retry(evutil_socket_t fd, short what, void *arg)
|
|||||||
static void
|
static void
|
||||||
evhttp_connection_cb_cleanup(struct evhttp_connection *evcon)
|
evhttp_connection_cb_cleanup(struct evhttp_connection *evcon)
|
||||||
{
|
{
|
||||||
|
struct evcon_requestq requests;
|
||||||
|
|
||||||
if (evcon->retry_max < 0 || evcon->retry_cnt < evcon->retry_max) {
|
if (evcon->retry_max < 0 || evcon->retry_cnt < evcon->retry_max) {
|
||||||
evtimer_assign(&evcon->retry_ev, evcon->base, evhttp_connection_retry, evcon);
|
evtimer_assign(&evcon->retry_ev, evcon->base, evhttp_connection_retry, evcon);
|
||||||
/* XXXX handle failure from evhttp_add_event */
|
/* XXXX handle failure from evhttp_add_event */
|
||||||
@ -1241,10 +1243,23 @@ evhttp_connection_cb_cleanup(struct evhttp_connection *evcon)
|
|||||||
}
|
}
|
||||||
evhttp_connection_reset(evcon);
|
evhttp_connection_reset(evcon);
|
||||||
|
|
||||||
/* for now, we just signal all requests by executing their callbacks */
|
/*
|
||||||
|
* User callback can do evhttp_make_request() on the same
|
||||||
|
* evcon so new request will be added to evcon->requests. To
|
||||||
|
* avoid freeing it prematurely we iterate over the copy of
|
||||||
|
* the queue.
|
||||||
|
*/
|
||||||
|
TAILQ_INIT(&requests);
|
||||||
while (TAILQ_FIRST(&evcon->requests) != NULL) {
|
while (TAILQ_FIRST(&evcon->requests) != NULL) {
|
||||||
struct evhttp_request *request = TAILQ_FIRST(&evcon->requests);
|
struct evhttp_request *request = TAILQ_FIRST(&evcon->requests);
|
||||||
TAILQ_REMOVE(&evcon->requests, request, next);
|
TAILQ_REMOVE(&evcon->requests, request, next);
|
||||||
|
TAILQ_INSERT_TAIL(&requests, request, next);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* for now, we just signal all requests by executing their callbacks */
|
||||||
|
while (TAILQ_FIRST(&requests) != NULL) {
|
||||||
|
struct evhttp_request *request = TAILQ_FIRST(&requests);
|
||||||
|
TAILQ_REMOVE(&requests, request, next);
|
||||||
request->evcon = NULL;
|
request->evcon = NULL;
|
||||||
|
|
||||||
/* we might want to set an error here */
|
/* we might want to set an error here */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user