Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 6 Dec 2006 15:31:27 GMT
From:      Marko Zec <zec@FreeBSD.org>
To:        Perforce Change Reviews <perforce@FreeBSD.org>
Subject:   PERFORCE change 111198 for review
Message-ID:  <200612061531.kB6FVR67021263@repoman.freebsd.org>

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

Change 111198 by zec@zec_tpx32 on 2006/12/06 15:31:22

	Store a pointer back to the owner vnet in struct inpcbinfo,
	so that whenever an inpcb is directly or indirectly available
	as an argument to a function, the function-local vnet ptr can
	be fetched from there, and not via the curvnetb macro.

Affected files ...

.. //depot/projects/vimage/src/sys/kern/kern_vimage.c#6 edit
.. //depot/projects/vimage/src/sys/net/bpf.c#4 edit
.. //depot/projects/vimage/src/sys/net/if.c#6 edit
.. //depot/projects/vimage/src/sys/net/if_loop.c#5 edit
.. //depot/projects/vimage/src/sys/net/if_stf.c#4 edit
.. //depot/projects/vimage/src/sys/net/if_var.h#4 edit
.. //depot/projects/vimage/src/sys/net/rtsock.c#5 edit
.. //depot/projects/vimage/src/sys/netgraph/ng_ether.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/if_ether.c#5 edit
.. //depot/projects/vimage/src/sys/netinet/igmp.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/in.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/in_pcb.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/in_pcb.h#2 edit
.. //depot/projects/vimage/src/sys/netinet/ip_fastfwd.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/ip_input.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/ip_output.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/raw_ip.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_input.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_output.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_sack.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_subr.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_syncache.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_timer.c#3 edit
.. //depot/projects/vimage/src/sys/netinet/tcp_usrreq.c#4 edit
.. //depot/projects/vimage/src/sys/netinet/udp_usrreq.c#4 edit
.. //depot/projects/vimage/src/sys/netinet6/in6_ifattach.c#4 edit
.. //depot/projects/vimage/src/sys/netinet6/in6_pcb.c#4 edit
.. //depot/projects/vimage/src/sys/netinet6/ip6_input.c#3 edit
.. //depot/projects/vimage/src/sys/netinet6/nd6.c#5 edit
.. //depot/projects/vimage/src/sys/netinet6/raw_ip6.c#4 edit
.. //depot/projects/vimage/src/sys/netinet6/scope6.c#4 edit
.. //depot/projects/vimage/src/sys/netinet6/udp6_output.c#3 edit
.. //depot/projects/vimage/src/sys/netinet6/udp6_usrreq.c#4 edit
.. //depot/projects/vimage/src/sys/sys/vimage.h#5 edit

Differences ...

==== //depot/projects/vimage/src/sys/kern/kern_vimage.c#6 (text+ko) ====


==== //depot/projects/vimage/src/sys/net/bpf.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/net/if.c#6 (text+ko) ====


==== //depot/projects/vimage/src/sys/net/if_loop.c#5 (text+ko) ====


==== //depot/projects/vimage/src/sys/net/if_stf.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/net/if_var.h#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/net/rtsock.c#5 (text+ko) ====


==== //depot/projects/vimage/src/sys/netgraph/ng_ether.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet/if_ether.c#5 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet/igmp.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet/in.c#4 (text+ko) ====

@@ -230,7 +230,7 @@
 	register struct ifnet *ifp;
 	struct thread *td;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(curvnetb);	/* so and ifp can be 0 ! */
 	register struct ifreq *ifr = (struct ifreq *)data;
 	register struct in_ifaddr *ia = 0, *iap;
 	register struct ifaddr *ifa;

==== //depot/projects/vimage/src/sys/netinet/in_pcb.c#4 (text+ko) ====

@@ -270,6 +270,7 @@
 in_pcbbind_setup(struct inpcb *inp, struct sockaddr *nam, in_addr_t *laddrp,
     u_short *lportp, struct ucred *cred)
 {
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct socket *so = inp->inp_socket;
 	unsigned short *lastport;
 	struct sockaddr_in *sin;
@@ -279,7 +280,6 @@
 	int wild = 0, reuseport = (so->so_options & SO_REUSEPORT);
 	int error, prison = 0;
 	int dorandom;
-	INIT_VNET_INET(so->so_vnetb);
 
 	INP_INFO_WLOCK_ASSERT(pcbinfo);
 	INP_LOCK_ASSERT(inp);
@@ -561,7 +561,7 @@
     in_addr_t *laddrp, u_short *lportp, in_addr_t *faddrp, u_short *fportp,
     struct inpcb **oinpp, struct ucred *cred)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct sockaddr_in *sin = (struct sockaddr_in *)nam;
 	struct in_ifaddr *ia;
 	struct sockaddr_in sa;

==== //depot/projects/vimage/src/sys/netinet/in_pcb.h#2 (text+ko) ====

@@ -119,6 +119,7 @@
 
 	void	*inp_ppcb;		/* pointer to per-protocol pcb */
 	struct	inpcbinfo *inp_pcbinfo;	/* PCB list info */
+#define inp_vnetb inp_pcbinfo->vnetb
 	struct	socket *inp_socket;	/* back pointer to socket */
 					/* list for this PCB's local port */
 	struct	label *inp_label;	/* MAC label */
@@ -235,6 +236,7 @@
 	u_int	ipi_count;	/* number of pcbs in this list */
 	u_quad_t ipi_gencnt;	/* current generation count */
 	struct	mtx ipi_mtx;
+	struct	vnet_base *vnetb;
 };
 
 /*

==== //depot/projects/vimage/src/sys/netinet/ip_fastfwd.c#3 (text+ko) ====

@@ -115,7 +115,7 @@
 static struct sockaddr_in *
 ip_findroute(struct route *ro, struct in_addr dest, struct mbuf *m)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(curvnetb); /* XXX perhaps ro->...so_vnetb ? revisit */
 	struct sockaddr_in *dst;
 	struct rtentry *rt;
 

==== //depot/projects/vimage/src/sys/netinet/ip_input.c#4 (text+ko) ====

@@ -1501,7 +1501,7 @@
 	register struct ip *ip;
 	register struct mbuf *m;
 {
-	INIT_VNET_NET(curvnetb);
+	INIT_VNET_NET(inp->inp_vnetb);
 
 	if (inp->inp_socket->so_options & (SO_BINTIME | SO_TIMESTAMP)) {
 		struct bintime bt;

==== //depot/projects/vimage/src/sys/netinet/ip_output.c#3 (text+ko) ====

@@ -1536,7 +1536,7 @@
 static int
 ip_getmoptions(struct inpcb *inp, struct sockopt *sopt)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct ip_moptions *imo;
 	struct in_addr addr;
 	struct in_ifaddr *ia;

==== //depot/projects/vimage/src/sys/netinet/raw_ip.c#4 (text+ko) ====

@@ -158,8 +158,10 @@
 	V_ripcbinfo.hashbase = hashinit(1, M_PCB, &V_ripcbinfo.hashmask);
 	V_ripcbinfo.porthashbase =
 	    hashinit(1, M_PCB, &V_ripcbinfo.porthashmask);
+/* XXX Marko we don't need a full zone for each stack - revisit this! */
 	V_ripcbinfo.ipi_zone = uma_zcreate("ripcb", sizeof(struct inpcb),
 	    NULL, NULL, rip_inpcb_init, NULL, UMA_ALIGN_PTR, UMA_ZONE_NOFREE);
+	V_ripcbinfo.vnetb = curvnetb;
 	uma_zone_set_max(V_ripcbinfo.ipi_zone, maxsockets);
 	EVENTHANDLER_REGISTER(maxsockets_change, rip_zone_change,
 		NULL, EVENTHANDLER_PRI_ANY);

==== //depot/projects/vimage/src/sys/netinet/tcp_input.c#3 (text+ko) ====

@@ -240,7 +240,7 @@
 	int *tlenp;
 	struct mbuf *m;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	struct tseg_qent *q;
 	struct tseg_qent *p = NULL;
 	struct tseg_qent *nq;
@@ -2762,7 +2762,7 @@
 	register struct tcpcb *tp;
 	int rtt;
 {
-	INIT_VNET_INET(curvnetb); /* XXX should be tp->pcb->so->so_vnetb */
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	register int delta;
 
 	INP_LOCK_ASSERT(tp->t_inpcb);
@@ -2871,7 +2871,7 @@
 	struct tcpcb *tp;
 	int offer;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	int rtt, mss;
 	u_long bufsize;
 	u_long maxmtu;
@@ -3200,7 +3200,7 @@
 	struct mbuf *m;
 	int tlen;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct tcptw *tw;
 	int thflags;
 	tcp_seq seq;

==== //depot/projects/vimage/src/sys/netinet/tcp_output.c#4 (text+ko) ====

@@ -120,8 +120,8 @@
 int
 tcp_output(struct tcpcb *tp)
 {
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	struct socket *so = tp->t_inpcb->inp_socket;
-	INIT_VNET_INET(so->so_vnetb);
 	long len, recwin, sendwin;
 	int off, flags, error;
 #ifdef TCP_SIGNATURE

==== //depot/projects/vimage/src/sys/netinet/tcp_sack.c#3 (text+ko) ====

@@ -282,7 +282,7 @@
 static struct sackhole *
 tcp_sackhole_alloc(struct tcpcb *tp, tcp_seq start, tcp_seq end)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	struct sackhole *hole;
 
 	if (tp->snd_numholes >= tcp_sack_maxholes ||

==== //depot/projects/vimage/src/sys/netinet/tcp_subr.c#3 (text+ko) ====

@@ -374,6 +374,7 @@
 	V_tcbinfo.porthashbase = hashinit(hashsize, M_PCB,
 					&V_tcbinfo.porthashmask);
 	V_tcbinfo.ipi_zone = tcp_ipi_zone;
+	V_tcbinfo.vnetb = curvnetb;
 #ifdef INET6
 #define TCP_MINPROTOHDR (sizeof(struct ip6_hdr) + sizeof(struct tcphdr))
 #else /* INET6 */
@@ -734,7 +735,7 @@
 struct tcpcb *
 tcp_drop(struct tcpcb *tp, int errno)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	struct socket *so = tp->t_inpcb->inp_socket;
 
 	INP_INFO_WLOCK_ASSERT(&V_tcbinfo);
@@ -853,7 +854,7 @@
 struct tcpcb *
 tcp_close(struct tcpcb *tp)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	struct inpcb *inp = tp->t_inpcb;
 	struct socket *so;
 
@@ -930,7 +931,7 @@
 static struct inpcb *
 tcp_notify(struct inpcb *inp, int error)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct tcpcb *tp;
 
 	INP_INFO_WLOCK_ASSERT(&V_tcbinfo);
@@ -1536,7 +1537,7 @@
 struct inpcb *
 tcp_drop_syn_sent(struct inpcb *inp, int errno)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct tcpcb *tp;
 
 	INP_INFO_WLOCK_ASSERT(&V_tcbinfo);
@@ -1566,7 +1567,7 @@
 struct inpcb *
 tcp_mtudisc(struct inpcb *inp, int errno)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct tcpcb *tp;
 	struct socket *so = inp->inp_socket;
 	u_int maxmtu;
@@ -1793,7 +1794,7 @@
 void
 tcp_twstart(struct tcpcb *tp)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 	struct tcptw *tw;
 	struct inpcb *inp = tp->t_inpcb;
 	int acknow;
@@ -1923,7 +1924,7 @@
 void
 tcp_twclose(struct tcptw *tw, int reuse)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tw->tw_inpcb->inp_vnetb);
 	struct socket *so;
 	struct inpcb *inp;
 
@@ -1991,7 +1992,7 @@
 int
 tcp_twrespond(struct tcptw *tw, int flags)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tw->tw_inpcb->inp_vnetb);
 	struct inpcb *inp = tw->tw_inpcb;
 	struct tcphdr *th;
 	struct mbuf *m;

==== //depot/projects/vimage/src/sys/netinet/tcp_syncache.c#3 (text+ko) ====

@@ -374,7 +374,7 @@
 static void
 syncache_timer(void *xsch)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(curvnetb);	/* XXX this can't work !!! */
 	struct syncache_head *sch = (struct syncache_head *)xsch;
 	struct syncache *sc, *nsc;
 	int tick = ticks;
@@ -553,7 +553,7 @@
 static struct socket *
 syncache_socket(struct syncache *sc, struct socket *lso, struct mbuf *m)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(lso->so_vnetb);
 	struct inpcb *inp = NULL;
 	struct socket *so;
 	struct tcpcb *tp;
@@ -851,7 +851,7 @@
 syncache_add(struct in_conninfo *inc, struct tcpopt *to, struct tcphdr *th,
     struct inpcb *inp, struct socket **lsop, struct mbuf *m)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct tcpcb *tp;
 	struct socket *so;
 	struct syncache *sc = NULL;

==== //depot/projects/vimage/src/sys/netinet/tcp_timer.c#3 (text+ko) ====

@@ -146,7 +146,7 @@
 	struct tcpcb *tp = xtp;
 	struct inpcb *inp;
 	CURVNETB_SET(vnetb_tbl[tp->vnet_id]);
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(vnetb_tbl[tp->vnet_id]);
 
 	INP_INFO_RLOCK(&V_tcbinfo);
 	inp = tp->t_inpcb;
@@ -188,7 +188,7 @@
 	struct tcpcb *tp = xtp;
 	struct inpcb *inp;
 	CURVNETB_SET(vnetb_tbl[tp->vnet_id]);
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(vnetb_tbl[tp->vnet_id]);
 #ifdef TCPDEBUG
 	int ostate;
 
@@ -268,7 +268,7 @@
 void
 tcp_timer_2msl_reset(struct tcptw *tw, int rearm)
 {
-	INIT_VNET_INET(curvnetb);	/* XXX Is this safe? */
+	INIT_VNET_INET(tw->tw_inpcb->inp_vnetb);
 
 	INP_INFO_WLOCK_ASSERT(&V_tcbinfo);
 	INP_LOCK_ASSERT(tw->tw_inpcb);
@@ -281,7 +281,7 @@
 void
 tcp_timer_2msl_stop(struct tcptw *tw)
 {
-	INIT_VNET_INET(curvnetb);	/* XXX is this safe? */
+	INIT_VNET_INET(tw->tw_inpcb->inp_vnetb);
 
 	INP_INFO_WLOCK_ASSERT(&V_tcbinfo);
 	TAILQ_REMOVE(&V_twq_2msl, tw, tw_2msl);
@@ -314,7 +314,7 @@
 	struct tcptemp *t_template;
 	struct inpcb *inp;
 	CURVNETB_SET(vnetb_tbl[tp->vnet_id]);
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(vnetb_tbl[tp->vnet_id]);
 #ifdef TCPDEBUG
 	int ostate;
 
@@ -412,7 +412,7 @@
 	struct tcpcb *tp = xtp;
 	struct inpcb *inp;
 	CURVNETB_SET(vnetb_tbl[tp->vnet_id]);
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(vnetb_tbl[tp->vnet_id]);
 #ifdef TCPDEBUG
 	int ostate;
 
@@ -487,7 +487,7 @@
 	int headlocked;
 	struct inpcb *inp;
 	CURVNETB_SET(vnetb_tbl[tp->vnet_id]);
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(vnetb_tbl[tp->vnet_id]);
 #ifdef TCPDEBUG
 	int ostate;
 

==== //depot/projects/vimage/src/sys/netinet/tcp_usrreq.c#4 (text+ko) ====

@@ -1556,7 +1556,7 @@
 tcp_usrclosed(tp)
 	register struct tcpcb *tp;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(tp->t_inpcb->inp_vnetb);
 
 	INP_INFO_WLOCK_ASSERT(&V_tcbinfo);
 	INP_LOCK_ASSERT(tp->t_inpcb);

==== //depot/projects/vimage/src/sys/netinet/udp_usrreq.c#4 (text+ko) ====

@@ -180,6 +180,7 @@
 	V_udbinfo.porthashbase = hashinit(UDBHASHSIZE, M_PCB,
 					&V_udbinfo.porthashmask);
 	V_udbinfo.ipi_zone = udp_ipi_zone;
+	V_udbinfo.vnetb = curvnetb;
 }
 
 void
@@ -476,7 +477,7 @@
 	int off;
 	struct sockaddr_in *udp_in;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	struct sockaddr *append_sa;
 	struct socket *so;
 	struct mbuf *opts = 0;
@@ -749,7 +750,7 @@
 	struct mbuf *control;
 	struct thread *td;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(inp->inp_vnetb);
 	register struct udpiphdr *ui;
 	register int len = m->m_pkthdr.len;
 	struct in_addr faddr, laddr;

==== //depot/projects/vimage/src/sys/netinet6/in6_ifattach.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet6/in6_pcb.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet6/ip6_input.c#3 (text+ko) ====

@@ -190,9 +190,7 @@
         }
         curvnetb->mod_data[vnet_inet6_modinfo.id] = vnet_inet6;
         vnet_inet6->parent_vnetb = curvnetb;
-#endif
 
-#ifdef VIMAGE
 	/*
 	 * Skip global initialization stuff 
 	 * for non-default instances.

==== //depot/projects/vimage/src/sys/netinet6/nd6.c#5 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet6/raw_ip6.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet6/scope6.c#4 (text+ko) ====


==== //depot/projects/vimage/src/sys/netinet6/udp6_output.c#3 (text+ko) ====

@@ -126,7 +126,7 @@
 	struct sockaddr *addr6;
 	struct thread *td;
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(in6p->inp_vnetb);
 	u_int32_t ulen = m->m_pkthdr.len;
 	u_int32_t plen = sizeof(struct udphdr) + ulen;
 	struct ip6_hdr *ip6;

==== //depot/projects/vimage/src/sys/netinet6/udp6_usrreq.c#4 (text+ko) ====

@@ -128,7 +128,7 @@
 udp6_append(struct inpcb *in6p, struct mbuf *n, int off,
     struct sockaddr_in6 *fromsa)
 {
-	INIT_VNET_INET(curvnetb);
+	INIT_VNET_INET(in6p->inp_vnetb);
 	struct socket *so;
 	struct mbuf *opts;
 

==== //depot/projects/vimage/src/sys/sys/vimage.h#5 (text+ko) ====




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