#include <types/server.h>
#include <types/task.h>
+extern struct pool_head *pool2_pendconn;
+
+int init_pendconn();
struct session *pendconn_get_next_sess(struct server *srv, struct proxy *px);
struct pendconn *pendconn_add(struct session *sess);
void pendconn_free(struct pendconn *p);
struct server *srv; /* the server we are waiting for */
};
-#define sizeof_pendconn sizeof(struct pendconn)
-extern void **pool_pendconn;
-
-
#endif /* _TYPES_QUEUE_H */
/*
localtime((time_t *)&now.tv_sec);
start_date = now;
- init_buffer();
init_task();
init_session();
+ init_buffer();
+ init_pendconn();
init_proto_http();
cfg_polling_mechanism = POLL_USE_SELECT; /* select() is always available */
pool_destroy2(pool2_task);
pool_destroy(pool_capture);
pool_destroy(pool_appsess);
+ pool_destroy2(pool2_pendconn);
if (have_appsession) {
pool_destroy(apools.serverid);
*/
#include <common/config.h>
+#include <common/memory.h>
#include <common/time.h>
#include <types/proxy.h>
#include <proto/task.h>
-void **pool_pendconn = NULL;
+struct pool_head *pool2_pendconn;
+
+/* perform minimal intializations, report 0 in case of error, 1 if OK. */
+int init_pendconn()
+{
+ pool2_pendconn = create_pool("pendconn", sizeof(struct pendconn), MEM_F_SHARED);
+ return pool2_pendconn != NULL;
+}
/* returns the effective dynamic maxconn for a server, considering the minconn
* and the proxy's usage relative to its dynamic connections limit. It is
{
struct pendconn *p;
- p = pool_alloc(pendconn);
+ p = pool_alloc2(pool2_pendconn);
if (!p)
return NULL;
else
p->sess->be->nbpend--;
p->sess->be->totpend--;
- pool_free(pendconn, p);
+ pool_free2(pool2_pendconn, p);
}