Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 15 Dec 2007 04:29:44 GMT
From:      Kip Macy <kmacy@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 130940 for review
Message-ID:  <200712150429.lBF4TiEn015118@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=130940

Change 130940 by kmacy@kmacy:storage:toestack on 2007/12/15 04:29:02

	add synq to listen_ctx
	add support for sending reset in SYN_RCVD state
	style fixes to inline functions

Affected files ...

.. //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_cpl_io.c#34 edit
.. //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_defs.h#13 edit
.. //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_listen.c#7 edit
.. //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_toepcb.h#4 edit
.. //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_tom.h#16 edit

Differences ...

==== //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_cpl_io.c#34 (text+ko) ====

@@ -140,7 +140,7 @@
 extern int tcp_autorcvbuf_max;
 extern int tcp_autosndbuf_max;
 
-static void t3_send_reset(struct socket *so);
+static void t3_send_reset(struct toepcb *toep);
 static void send_abort_rpl(struct mbuf *m, struct toedev *tdev, int rst_status);
 static inline void free_atid(struct t3cdev *cdev, unsigned int tid);
 static void handle_syncache_event(int event, void *arg);
@@ -550,17 +550,15 @@
 static int
 cxgb_toe_abort(struct tcpcb *tp)
 {
-	struct socket *so;
-	struct toepcb *toep;
+	struct toepcb *toep = tp->t_toe;
+       
 	
-	so = tp->t_inpcb->inp_socket;
-	t3_send_reset(so);
+	t3_send_reset(toep);
 
 	/*
 	 * unhook from socket
 	 */
 	tp->t_flags &= ~TF_TOE;
-	toep = tp->t_toe;
 	toep->tp_tp = NULL;
 	tp->t_toe = NULL;
 	return (0);
@@ -1301,24 +1299,31 @@
  * an ABORT_REQ wasn't generated after all, 0 otherwise.
  */
 static void
-t3_send_reset(struct socket *so)
+t3_send_reset(struct toepcb *toep)
 {
 	
 	struct cpl_abort_req *req;
-	struct tcpcb *tp = sototcpcb(so);
-	struct toepcb *toep = tp->t_toe;
 	unsigned int tid = toep->tp_tid;
 	int mode = CPL_ABORT_SEND_RST;
+	struct tcpcb *tp = toep->tp_tp;
+	struct toedev *tdev = toep->tp_toedev;
+	struct socket *so = NULL;
 	struct mbuf *m;
 	
-	INP_LOCK_ASSERT(tp->t_inpcb);
-	if (__predict_false((toep->tp_flags & TP_ABORT_SHUTDOWN) || !TOE_DEV(so)))
+	if (tp) {
+		INP_LOCK_ASSERT(tp->t_inpcb);
+		so = toeptoso(toep);
+	}
+	
+	if (__predict_false((toep->tp_flags & TP_ABORT_SHUTDOWN) ||
+		tdev == NULL))
 		return;
 	toep->tp_flags |= (TP_ABORT_RPL_PENDING|TP_ABORT_SHUTDOWN);
 	
 	/* Purge the send queue so we don't send anything after an abort. */
-	sbflush(&so->so_snd);
-	if ((toep->tp_flags & TP_CLOSE_CON_REQUESTED) && is_t3a(TOE_DEV(so)))
+	if (so)
+		sbflush(&so->so_snd);
+	if ((toep->tp_flags & TP_CLOSE_CON_REQUESTED) && is_t3a(tdev))
 		mode |= CPL_ABORT_POST_CLOSE_REQ;
 
 	m = m_gethdr_nofail(sizeof(*req));
@@ -1329,14 +1334,13 @@
 	req->wr.wr_hi = htonl(V_WR_OP(FW_WROPCODE_OFLD_HOST_ABORT_CON_REQ));
 	req->wr.wr_lo = htonl(V_WR_TID(tid));
 	OPCODE_TID(req) = htonl(MK_OPCODE_TID(CPL_ABORT_REQ, tid));
-	req->rsvd0 = htonl(tp->snd_nxt);
+	req->rsvd0 = tp ? htonl(tp->snd_nxt) : 0;
 	req->rsvd1 = !(toep->tp_flags & TP_DATASENT);
 	req->cmd = mode;
-	INP_LOCK_ASSERT(tp->t_inpcb);
-	if (tp->t_state == TCPS_SYN_SENT)
+	if (tp && (tp->t_state == TCPS_SYN_SENT))
 		mbufq_tail(&toep->out_of_order_queue, m);	// defer
 	else
-		l2t_send(T3C_DEV(so), m, toep->tp_l2t);
+		l2t_send(TOEP_T3C_DEV(toep), m, toep->tp_l2t);
 }
 
 static int
@@ -2633,7 +2637,11 @@
 	
 	printf("inserting tid=%d\n", tid);
 	cxgb_insert_tid(cdev, d->client, newtoep, tid);
-
+	SOCK_LOCK(so);
+	LIST_INSERT_HEAD(&lctx->synq_head, newtoep, synq_entry);
+	SOCK_UNLOCK(so);
+	
+	
 	if (lctx->ulp_mode) {
 		ddp_mbuf = m_gethdr(M_NOWAIT, MT_DATA);
 		
@@ -2653,6 +2661,8 @@
 	toepcb_hold(newtoep);
 	syncache_add_accept_req(req, so, newtoep);
 
+	
+	
 	rpl = cplhdr(reply_mbuf);
 	reply_mbuf->m_pkthdr.len = reply_mbuf->m_len = sizeof(*rpl);
 	rpl->wr.wr_hi = htonl(V_WR_OP(FW_WROPCODE_FORWARD));
@@ -2892,8 +2902,11 @@
 
 	so = lso = toeptoso(toep);
 	tdev = toep->tp_toedev;
+
+	SOCK_LOCK(so);
+	LIST_REMOVE(toep, synq_entry);
+	SOCK_UNLOCK(so);
 	
-
 	INP_INFO_WLOCK(&tcbinfo);
 	if (!syncache_expand_establish_req(req, &so, toep)) {
 		/*
@@ -3235,7 +3248,9 @@
 static void
 t3_reset_listen_child(struct socket *child)
 {
-	t3_send_reset(child);
+	struct tcpcb *tp = sototcpcb(child);
+	
+	t3_send_reset(tp->t_toe);
 }
 
 /*
@@ -3267,17 +3282,20 @@
  */
 
 void
-t3_reset_synq(struct socket *listen_so)
+t3_reset_synq(struct listen_ctx *lctx)
 {
-	struct socket *so;
-	struct tcpcb *tp;
+	struct toepcb *toep;
 
-	TAILQ_FOREACH(so, &listen_so->so_incomp, so_list) {
-		tp = sototcpcb(so);
-		
-		if (tp->t_flags & TF_TOE)
-			t3_reset_listen_child(so);
+	SOCK_LOCK(lctx->lso);
+	while (!LIST_EMPTY(&lctx->synq_head)) {
+		toep = LIST_FIRST(&lctx->synq_head);
+		LIST_REMOVE(toep, synq_entry);
+		toep->tp_tp = NULL;
+		t3_send_reset(toep);
+		cxgb_remove_tid(TOEP_T3C_DEV(toep), toep, toep->tp_tid);
+		toepcb_release(toep);
 	}
+	SOCK_UNLOCK(lctx->lso);
 }
 
 void

==== //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_defs.h#13 (text+ko) ====

@@ -40,6 +40,8 @@
 #define toeptoso(toep) ((toep)->tp_tp->t_inpcb->inp_socket)
 #define sototoep(so) (sototcpcb((so))->t_toe)
 
+struct listen_ctx;
+
 typedef void (*defer_handler_t)(struct toedev *dev, struct mbuf *m);
 
 void t3tom_register_cpl_handler(unsigned int opcode, cxgb_cpl_handler_func h);
@@ -59,7 +61,7 @@
 
 
 void t3_disconnect_acceptq(struct socket *listen_so);
-void t3_reset_synq(struct socket *listen_so);
+void t3_reset_synq(struct listen_ctx *ctx);
 void t3_defer_reply(struct mbuf *m, struct toedev *dev, defer_handler_t handler);
 
 struct toepcb *toepcb_alloc(void);

==== //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_listen.c#7 (text+ko) ====

@@ -70,7 +70,10 @@
 #include <dev/cxgb/ulp/toecore/cxgb_toedev.h>
 #include <dev/cxgb/ulp/tom/cxgb_defs.h>
 #include <dev/cxgb/ulp/tom/cxgb_tom.h>
+#include <dev/cxgb/ulp/tom/cxgb_t3_ddp.h>
+#include <dev/cxgb/ulp/tom/cxgb_toepcb.h>
 
+
 static struct listen_info *listen_hash_add(struct tom_data *d, struct socket *so, unsigned int stid);
 static int listen_hash_del(struct tom_data *d, struct socket *so);
 
@@ -91,10 +94,7 @@
 		struct listen_ctx *listen_ctx = (struct listen_ctx *)ctx;
 
 		cxgb_free_stid(cdev, stid);
-#if 0		
-		sock_put(listen_ctx->lsk);
-#endif		
-		free(listen_ctx, M_DEVBUF);
+		free(listen_ctx, M_CXGB);
 	}
 
 	return (CPL_RET_BUF_DONE);
@@ -139,7 +139,7 @@
 		 */
 		sock_put(lso);
 #endif
-		free(listen_ctx, M_DEVBUF);
+		free(listen_ctx, M_CXGB);
 	}
 	return CPL_RET_BUF_DONE;
 }
@@ -166,7 +166,7 @@
 {
 	struct listen_info *p;
 
-	p = malloc(sizeof(*p), M_DEVBUF, M_NOWAIT|M_ZERO);
+	p = malloc(sizeof(*p), M_CXGB, M_NOWAIT|M_ZERO);
 	if (p) {
 		int bucket = listen_hashfn(so);
 
@@ -220,7 +220,7 @@
 		if (p->so == so) {
 			stid = p->stid;
 			*prev = p->next;
-			free(p, M_DEVBUF);
+			free(p, M_CXGB);
 			break;
 		}
 	mtx_unlock(&d->listen_lock);
@@ -246,14 +246,15 @@
 
 	printf("start listen\n");
 	
-	ctx = malloc(sizeof(*ctx), M_DEVBUF, M_NOWAIT);
-	
+	ctx = malloc(sizeof(*ctx), M_CXGB, M_NOWAIT);
+
 	if (!ctx)
 		return;
 
 	ctx->tom_data = d;
 	ctx->lso = so;
 	ctx->ulp_mode = 0; /* DDP if the default */
+	LIST_INIT(&ctx->synq_head);
 	
 	stid = cxgb_alloc_stid(d->cdev, d->client, ctx);
 	if (stid < 0)
@@ -297,7 +298,7 @@
 	sock_put(sk);
 #endif	
 free_ctx:
-	free(ctx, M_DEVBUF);
+	free(ctx, M_CXGB);
 }
 
 /*
@@ -309,18 +310,20 @@
 {
 	struct mbuf *m;
 	struct cpl_close_listserv_req *req;
+	struct listen_ctx *lctx;
 	int stid = listen_hash_del(TOM_DATA(dev), so);
 	
 	if (stid < 0)
 		return;
 
+	lctx = cxgb_get_lctx(cdev, stid);
 	/*
 	 * Do this early so embryonic connections are marked as being aborted
 	 * while the stid is still open.  This ensures pass_establish messages
 	 * that arrive while we are closing the server will be able to locate
 	 * the listening socket.
 	 */
-	t3_reset_synq(so);
+	t3_reset_synq(lctx);
 
 	/* Send the close ASAP to stop further passive opens */
 	m = m_gethdr(M_NOWAIT, MT_DATA);

==== //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_toepcb.h#4 (text+ko) ====

@@ -35,18 +35,22 @@
 	struct mbuf  *tp_m_last;
 	bus_dma_tag_t	tp_tx_dmat;
 	bus_dmamap_t	tp_dmamap;
-	
+
+	LIST_ENTRY(toepcb) synq_entry;
 	struct mbuf_head wr_list;
 	struct mbuf_head out_of_order_queue;
 	struct ddp_state tp_ddp_state;
 };
 
-static inline void reset_wr_list(struct toepcb *toep)
+static inline void
+reset_wr_list(struct toepcb *toep)
 {
+
 	mbufq_init(&toep->wr_list);
 }
 
-static inline void purge_wr_queue(struct toepcb *toep)
+static inline void
+purge_wr_queue(struct toepcb *toep)
 {
 	struct mbuf *m;
 	
@@ -54,20 +58,25 @@
 		m_freem(m);
 }
 
-static inline void enqueue_wr(struct toepcb *toep, struct mbuf *m)
+static inline void
+enqueue_wr(struct toepcb *toep, struct mbuf *m)
 {
+
 	mbufq_tail(&toep->wr_list, m);
 }
 
+static inline struct mbuf *
+peek_wr(struct toepcb *toep)
+{
 
-static inline struct mbuf *peek_wr(struct toepcb *toep)
-{
-	return mbufq_peek(&toep->wr_list);
+	return (mbufq_peek(&toep->wr_list));
 }
 
-static inline struct mbuf *dequeue_wr(struct toepcb *toep)
+static inline struct mbuf *
+dequeue_wr(struct toepcb *toep)
 {
-	return mbufq_dequeue(&toep->wr_list);
+
+	return (mbufq_dequeue(&toep->wr_list));
 }
 
 #endif

==== //depot/projects/toestack/sys/dev/cxgb/ulp/tom/cxgb_tom.h#16 (text+ko) ====

@@ -108,8 +108,6 @@
         struct mtx ppod_map_lock;
 	
         struct adap_ports *ports;
-
-
 	struct taskqueue *tq;
 };
 
@@ -118,6 +116,8 @@
 	struct socket *lso;
 	struct tom_data *tom_data;
 	int ulp_mode;
+	LIST_HEAD(, toepcb) synq_head;
+	
 };
 
 #define TOM_DATA(dev) (*(struct tom_data **)&(dev)->tod_l4opt)



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200712150429.lBF4TiEn015118>