Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 9 Jan 2008 15:24:58 GMT
From:      Steve Wise <swise@FreeBSD.org>
To:        Perforce Change Reviews <perforce@FreeBSD.org>
Subject:   PERFORCE change 132891 for review
Message-ID:  <200801091524.m09FOwKG048728@repoman.freebsd.org>

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

Change 132891 by swise@swise:vic10:iwarp on 2008/01/09 15:24:37

	krping works from client side
	
		- address resolution rtalloc issues
		- address resolution tailq bug
		- cxgb_offload.c arp event fixes
		- send_mpa_req() fixes

Affected files ...

.. //depot/projects/iwarp/sys/contrib/rdma/rdma_addr.c#6 edit
.. //depot/projects/iwarp/sys/dev/cxgb/cxgb_l2t.c#5 edit
.. //depot/projects/iwarp/sys/dev/cxgb/cxgb_offload.c#10 edit
.. //depot/projects/iwarp/sys/dev/cxgb/ulp/iw_cxgb/iw_cxgb_iwch_cm.c#7 edit

Differences ...

==== //depot/projects/iwarp/sys/contrib/rdma/rdma_addr.c#6 (text+ko) ====

@@ -148,27 +148,31 @@
 		return (EADDRNOTAVAIL);
 
 	ret = rdma_copy_addr(dev_addr, iproute.ro_rt->rt_ifp, NULL);
-	rtfree(iproute.ro_rt);
+	RTFREE(iproute.ro_rt);
 	return ret;
 }
 EXPORT_SYMBOL(rdma_translate_ip);
 
 static void queue_req(struct addr_req *req)
 {
-	struct addr_req *tmp_req;
+	struct addr_req *tmp_req = NULL;
 	
 	mtx_lock(&lock);
 	TAILQ_FOREACH_REVERSE(tmp_req, &req_list, addr_req_list, entry)
 	    if (time_after_eq(req->timeout, tmp_req->timeout))
 		    break;
 	
-	TAILQ_INSERT_AFTER(&req_list, tmp_req, req, entry);
+	if (tmp_req)
+		TAILQ_INSERT_AFTER(&req_list, tmp_req, req, entry);
+	else
+		TAILQ_INSERT_TAIL(&req_list, req, entry);
 	
 	if (TAILQ_FIRST(&req_list) == req)	
 		callout_reset(&addr_ch, req->timeout - ticks, addr_timeout, NULL);
 	mtx_unlock(&lock);
 }
 
+#ifdef needed
 static void addr_send_arp(struct sockaddr_in *dst_in)
 {
 	struct route iproute;
@@ -185,8 +189,9 @@
 	arpresolve(iproute.ro_rt->rt_ifp, iproute.ro_rt, NULL, 
 		   rt_key(iproute.ro_rt), dmac);
 
-	rtfree(iproute.ro_rt);
+	RTFREE(iproute.ro_rt);
 }
+#endif
 
 static int addr_resolve_remote(struct sockaddr_in *src_in,
 			       struct sockaddr_in *dst_in,
@@ -201,8 +206,10 @@
 	*dst = *dst_in;
 
 	rtalloc(&iproute);
-	if (iproute.ro_rt == NULL);
+	if (iproute.ro_rt == NULL) {
+		ret = EHOSTUNREACH;
 		goto out;
+	}
 
 	/* If the device does ARP internally, return 'done' */
 	if (iproute.ro_rt->rt_ifp->if_flags & IFF_NOARP) {
@@ -223,7 +230,7 @@
 
 	ret = rdma_copy_addr(addr, iproute.ro_rt->rt_ifp, dmac);
 put:
-	rtfree(iproute.ro_rt);
+	RTFREE(iproute.ro_rt);
 out:
 	return ret;
 }
@@ -308,7 +315,9 @@
 	case EWOULDBLOCK:
 		req->timeout = msecs_to_ticks(timeout_ms) + ticks;
 		queue_req(req);
+#ifdef needed
 		addr_send_arp(dst_in);
+#endif
 		break;
 	default:
 		ret = req->status;

==== //depot/projects/iwarp/sys/dev/cxgb/cxgb_l2t.c#5 (text+ko) ====

@@ -170,6 +170,7 @@
 {
 	struct rtentry *rt =  e->neigh;
 	struct sockaddr_in sin;
+	int err;
 
 	bzero(&sin, sizeof(struct sockaddr_in));
 	sin.sin_family = AF_INET;
@@ -209,7 +210,8 @@
 		 * entries when there's no memory.
 		 */
 		printf("doing arpresolve2 on 0x%x \n", e->addr);
-		if (arpresolve2(rt->rt_ifp, rt, (struct sockaddr *)&sin, e->dmac) == 0) {
+		err = arpresolve2(rt->rt_ifp, rt, (struct sockaddr *)&sin, e->dmac);
+		if (!err) {
 			printf("mac=%x:%x:%x:%x:%x:%x\n",
 			    e->dmac[0], e->dmac[1], e->dmac[2], e->dmac[3], e->dmac[4], e->dmac[5]);
 			
@@ -223,7 +225,7 @@
 				m_freem(m);
 			mtx_unlock(&e->lock);
 		} else
-			printf("arpresolve2 returned non-zero\n");
+			printf("arpresolve2 returned %d\n", err);
 	}
 	return 0;
 }

==== //depot/projects/iwarp/sys/dev/cxgb/cxgb_offload.c#10 (text+ko) ====

@@ -911,7 +911,7 @@
     uint8_t *enaddr, struct sockaddr *sa)
 {
 
-	if (TOEDEV(rt0->rt_ifp) == NULL)
+	if (!is_offloading(rt0->rt_ifp))
 		return;
 
 	RT_ADDREF(rt0);
@@ -926,15 +926,22 @@
 cxgb_redirect_event(void *unused, int event, struct rtentry *rt0,
     struct rtentry *rt1, struct sockaddr *sa)
 {
-	struct toedev *tdev0, *tdev1;
 
 	/* 
 	 * ignore events on non-offloaded interfaces
 	 */
-	tdev0 = TOEDEV(rt0->rt_ifp);
-	tdev1 = TOEDEV(rt1->rt_ifp);
-	if (tdev0 == NULL && tdev1 == NULL)
+	if (!is_offloading(rt0->rt_ifp))
+		return;
+
+	/*
+	 * Cannot redirect to non-offload device.
+	 */
+	if (!is_offloading(rt1->rt_ifp)) {
+		log(LOG_WARNING, "%s: Redirect to non-offload"
+		    "device ignored.\n", __FUNCTION__);
 		return;
+	}
+
         /*
 	 * avoid LORs by dropping the route lock but keeping a reference
 	 * 
@@ -1059,13 +1066,9 @@
 void
 cxgb_neigh_update(struct rtentry *rt, uint8_t *enaddr, struct sockaddr *sa)
 {
-
-	if (is_offloading(rt->rt_ifp)) {
-		struct t3cdev *tdev = T3CDEV(rt->rt_ifp);
-
-		PANIC_IF(!tdev);
-		t3_l2t_update(tdev, rt, enaddr, sa);
-	}
+	struct t3cdev *tdev = T3CDEV(rt->rt_ifp);
+	PANIC_IF(!tdev);
+	t3_l2t_update(tdev, rt, enaddr, sa);
 }
 
 static void
@@ -1107,13 +1110,6 @@
 
 	olddev = old->rt_ifp;
 	newdev = new->rt_ifp;
-	if (!is_offloading(olddev))
-		return;
-	if (!is_offloading(newdev)) {
-		log(LOG_WARNING, "%s: Redirect to non-offload"
-		    "device ignored.\n", __FUNCTION__);
-		return;
-	}
 	tdev = T3CDEV(olddev);
 	PANIC_IF(!tdev);
 	if (tdev != T3CDEV(newdev)) {

==== //depot/projects/iwarp/sys/dev/cxgb/ulp/iw_cxgb/iw_cxgb_iwch_cm.c#7 (text+ko) ====

@@ -356,22 +356,28 @@
 	}
 }
 
+static void
+reset_mbuf(struct mbuf *m)
+{
+	m_set_sgl(m, NULL);
+	m_set_sgllen(m, 0);
+	m->m_len = 0;
+	m->m_pkthdr.len = 0;
+}
+
 /*
  * Try and reuse mbufs already allocated...
  */
 static struct mbuf *
 get_mbuf(struct mbuf *m, int len, int flags)
 {
-	if (m && ((m->m_flags & M_EXT) == 0)) {
-		m->m_len = 0;
-	} else {
+	if (!m || (m->m_flags & M_EXT)) {
 		/*
 		 * Assume len is less than MINCLBYTES :-/
 		 */
 		m = m_gethdr(MT_DATA, M_DONTWAIT);
 	}
-	m_set_sgl(m, NULL);
-	m_set_sgllen(m, 0);
+	reset_mbuf(m);
 	return (m);
 }
 
@@ -530,7 +536,6 @@
 	int mpalen;
 	struct tx_data_wr *req;
 	struct mpa_message *mpa;
-	int len;
 
 	PDBG("%s ep %p pd_len %d\n", __FUNCTION__, ep, ep->plen);
 
@@ -547,10 +552,10 @@
 			return;
 		}
 	}
+	reset_mbuf(m);
 	m_set_priority(m, CPL_PRIORITY_DATA);
 	req = (struct tx_data_wr *)mbuf_put(m, sizeof(*req));
-	len = m->m_len;
-	mpa = (struct mpa_message *) mbuf_put(m, mpalen);
+	mpa = (struct mpa_message *)mbuf_put(m, mpalen);
 	memset(mpa, 0, sizeof(*mpa));
 	memcpy(mpa->key, MPA_KEY_REQ, sizeof(mpa->key));
 	mpa->flags = (crc_enabled ? MPA_CRC : 0) |
@@ -569,7 +574,7 @@
 	set_arp_failure_handler(m, arp_failure_discard);
 	req->wr_hi = htonl(V_WR_OP(FW_WROPCODE_OFLD_TX_DATA));
 	req->wr_lo = htonl(V_WR_TID(ep->hwtid));
-	req->len = htonl(len);
+	req->len = htonl(mpalen);
 	req->param = htonl(V_TX_PORT(ep->l2t->smt_idx) |
 			   V_TX_SNDBUF(snd_win>>15));
 	req->flags = htonl(F_TX_INIT);



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