[master] 4c4d6f6 Make sure that all sessions, requests and busyobj's have a unique transaction id 'vxid'

Poul-Henning Kamp phk at varnish-cache.org
Mon Jul 2 12:38:04 CEST 2012


commit 4c4d6f652d0b96aba584575e692a913172146168
Author: Poul-Henning Kamp <phk at FreeBSD.org>
Date:   Mon Jul 2 10:37:36 2012 +0000

    Make sure that all sessions, requests and busyobj's have a
    unique transaction id 'vxid'

diff --git a/bin/varnishd/cache/cache.h b/bin/varnishd/cache/cache.h
index d19dc32..ae42dd0 100644
--- a/bin/varnishd/cache/cache.h
+++ b/bin/varnishd/cache/cache.h
@@ -259,7 +259,7 @@ struct vsl_log {
 
 /*--------------------------------------------------------------------*/
 
-struct vxid {
+struct vxid_pool {
 	uint32_t		next;
 	uint32_t		count;
 };
@@ -275,7 +275,6 @@ struct wrk_accept {
 	socklen_t		acceptaddrlen;
 	int			acceptsock;
 	struct listen_sock	*acceptlsock;
-	uint32_t		vxid;
 };
 
 /* Worker pool stuff -------------------------------------------------*/
@@ -319,6 +318,7 @@ struct worker {
 
 	struct ws		aws[1];
 
+	struct vxid_pool	vxid_pool;
 
 	/* Temporary accounting */
 	struct acct		acct_tmp;
@@ -472,6 +472,7 @@ struct busyobj {
 	 * is recycled.
 	 */
 	unsigned		refcount;
+	uint32_t		vxid;
 
 	uint8_t			*vary;
 	unsigned		is_gzip;
@@ -560,6 +561,7 @@ struct req {
 	unsigned		magic;
 #define REQ_MAGIC		0x2751aaa1
 
+	uint32_t		vxid;
 	unsigned		xid;
 	int			restarts;
 	int			esi_level;
@@ -655,7 +657,6 @@ struct sess {
 	int			fd;
 	unsigned		vsl_id;
 	uint32_t		vxid;
-	uint32_t		vseq;
 
 	/* Cross references ------------------------------------------*/
 
@@ -857,7 +858,7 @@ int HTC_Complete(struct http_conn *htc);
 #undef HTTPH
 
 /* cache_main.c */
-uint32_t VXID_Get(struct vxid *v);
+uint32_t VXID_Get(struct vxid_pool *v);
 extern volatile struct params * cache_param;
 void THR_SetName(const char *name);
 const char* THR_GetName(void);
diff --git a/bin/varnishd/cache/cache_acceptor.c b/bin/varnishd/cache/cache_acceptor.c
index 5e71d00..bbec54f 100644
--- a/bin/varnishd/cache/cache_acceptor.c
+++ b/bin/varnishd/cache/cache_acceptor.c
@@ -248,8 +248,6 @@ VCA_SetupSess(struct worker *wrk, struct sess *sp)
 	CHECK_OBJ_NOTNULL(wrk, WORKER_MAGIC);
 	CHECK_OBJ_NOTNULL(sp, SESS_MAGIC);
 	CAST_OBJ_NOTNULL(wa, (void*)wrk->aws->f, WRK_ACCEPT_MAGIC);
-	sp->vxid = wa->vxid;
-	sp->vseq = 0;
 	sp->fd = wa->acceptsock;
 	sp->vsl_id = wa->acceptsock | VSL_CLIENTMARKER ;
 	wa->acceptsock = -1;
diff --git a/bin/varnishd/cache/cache_busyobj.c b/bin/varnishd/cache/cache_busyobj.c
index 48efe08..8f0cc50 100644
--- a/bin/varnishd/cache/cache_busyobj.c
+++ b/bin/varnishd/cache/cache_busyobj.c
@@ -108,6 +108,7 @@ VBO_GetBusyObj(struct worker *wrk)
 	AZ(bo->refcount);
 
 	bo->refcount = 1;
+	bo->vxid = VXID_Get(&wrk->vxid_pool);
 
 	p = (void*)(bo + 1);
 	p = (void*)PRNDUP(p);
diff --git a/bin/varnishd/cache/cache_center.c b/bin/varnishd/cache/cache_center.c
index 84fc3ea..c50d503 100644
--- a/bin/varnishd/cache/cache_center.c
+++ b/bin/varnishd/cache/cache_center.c
@@ -277,6 +277,7 @@ cnt_sess_done(struct sess *sp, struct worker *wrk, struct req *req)
 
 	WS_Reset(req->ws, NULL);
 	WS_Reset(wrk->aws, NULL);
+	req->vxid = VXID_Get(&wrk->vxid_pool);
 
 	i = HTC_Reinit(req->htc);
 	if (i == 1) {
diff --git a/bin/varnishd/cache/cache_main.c b/bin/varnishd/cache/cache_main.c
index dcb3cb1..94f2c8f 100644
--- a/bin/varnishd/cache/cache_main.c
+++ b/bin/varnishd/cache/cache_main.c
@@ -85,13 +85,15 @@ THR_GetName(void)
 }
 
 /*--------------------------------------------------------------------
+ * VXID's are unique transaction numbers allocated with a minimum of
+ * locking overhead via pools in the worker threads.
  */
 
 static uint32_t vxid_base;
 static struct lock vxid_lock;
 
 static void
-vxid_More(struct vxid *v)
+vxid_More(struct vxid_pool *v)
 {
 
 	Lck_Lock(&vxid_lock);
@@ -102,7 +104,7 @@ vxid_More(struct vxid *v)
 }
 
 uint32_t
-VXID_Get(struct vxid *v)
+VXID_Get(struct vxid_pool *v)
 {
 	if (v->count == 0)
 		vxid_More(v);
diff --git a/bin/varnishd/cache/cache_pool.c b/bin/varnishd/cache/cache_pool.c
index fa1f401..21a8a31 100644
--- a/bin/varnishd/cache/cache_pool.c
+++ b/bin/varnishd/cache/cache_pool.c
@@ -62,8 +62,6 @@ struct pool {
 	pthread_cond_t			herder_cond;
 	pthread_t			herder_thr;
 
-	struct vxid			vxid;
-
 	struct lock			mtx;
 	struct taskhead			idle_queue;
 	struct taskhead			front_queue;
@@ -148,7 +146,6 @@ pool_accept(struct worker *wrk, void *arg)
 		}
 
 		Lck_Lock(&pp->mtx);
-		wa->vxid = VXID_Get(&pp->vxid);
 		wrk2 = pool_getidleworker(pp);
 		if (wrk2 == NULL) {
 			/* No idle threads, do it ourselves */
diff --git a/bin/varnishd/cache/cache_session.c b/bin/varnishd/cache/cache_session.c
index 3ed251d..64ee6f5 100644
--- a/bin/varnishd/cache/cache_session.c
+++ b/bin/varnishd/cache/cache_session.c
@@ -207,12 +207,15 @@ SES_pool_accept_task(struct worker *wrk, void *arg)
 	sp->t_open = VTIM_real();
 	sp->t_rx = sp->t_open;
 	sp->t_idle = sp->t_open;
+	sp->vxid = VXID_Get(&wrk->vxid_pool);
 
 	lsockname = VCA_SetupSess(wrk, sp);
 
 	req = ses_GetReq(sp);
 	CHECK_OBJ_NOTNULL(req, REQ_MAGIC);
 
+	req->vxid = VXID_Get(&wrk->vxid_pool);
+
 	ses_vsl_socket(req, lsockname);
 
 	wrk->acct_tmp.sess++;
@@ -262,12 +265,16 @@ SES_Handle(struct sess *sp, double now)
 	struct req *req;
 	struct sesspool *pp;
 
+	/* NB: This only works with single-threaded waiters */
+	static struct vxid_pool vxid_pool;
+
 	CHECK_OBJ_NOTNULL(sp, SESS_MAGIC);
 	pp = sp->sesspool;
 	CHECK_OBJ_NOTNULL(pp, SESSPOOL_MAGIC);
 	AN(pp->pool);
 	req = ses_GetReq(sp);
 	CHECK_OBJ_NOTNULL(req, REQ_MAGIC);
+	req->vxid = VXID_Get(&vxid_pool);
 	sp->task.func = ses_pool_task;
 	sp->task.priv = req;
 	sp->sess_step = S_STP_NEWREQ;



More information about the varnish-commit mailing list