From owner-p4-projects@FreeBSD.ORG Fri Dec 15 19:49:25 2006 Return-Path: X-Original-To: p4-projects@freebsd.org Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 4052516A412; Fri, 15 Dec 2006 19:49:25 +0000 (UTC) X-Original-To: perforce@FreeBSD.org Delivered-To: perforce@FreeBSD.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id E9BBA16A40F for ; Fri, 15 Dec 2006 19:49:24 +0000 (UTC) (envelope-from zec@FreeBSD.org) Received: from repoman.freebsd.org (repoman.freebsd.org [69.147.83.41]) by mx1.FreeBSD.org (Postfix) with ESMTP id E1CCA43CAC for ; Fri, 15 Dec 2006 19:47:33 +0000 (GMT) (envelope-from zec@FreeBSD.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.13.6/8.13.6) with ESMTP id kBFJnGIa016853 for ; Fri, 15 Dec 2006 19:49:16 GMT (envelope-from zec@FreeBSD.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.13.6/8.13.4/Submit) id kBFJnGBW016848 for perforce@freebsd.org; Fri, 15 Dec 2006 19:49:16 GMT (envelope-from zec@FreeBSD.org) Date: Fri, 15 Dec 2006 19:49:16 GMT Message-Id: <200612151949.kBFJnGBW016848@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to zec@FreeBSD.org using -f From: Marko Zec To: Perforce Change Reviews Cc: Subject: PERFORCE change 111749 for review X-BeenThere: p4-projects@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: p4 projects tree changes List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 15 Dec 2006 19:49:25 -0000 http://perforce.freebsd.org/chv.cgi?CH=111749 Change 111749 by zec@zec_tpx32 on 2006/12/15 19:48:49 Add virtualization support for ppp(4). Affected files ... .. //depot/projects/vimage/src/sys/kern/tty.c#3 edit .. //depot/projects/vimage/src/sys/net/if_ppp.c#3 edit Differences ... ==== //depot/projects/vimage/src/sys/kern/tty.c#3 (text+ko) ==== @@ -75,6 +75,7 @@ #include "opt_compat.h" #include "opt_tty.h" +#include "opt_vimage.h" #include #include @@ -104,6 +105,7 @@ #include #include #include +#include #include @@ -1139,6 +1141,7 @@ if (t == tp->t_line) return (0); s = spltty(); + CURVNETB_SET(curthread->td_vimage->v_vnetb); /* XXX */ ttyld_close(tp, flag); tp->t_line = t; /* XXX: we should use the correct cdev here */ @@ -1154,6 +1157,7 @@ tp->t_line = TTYDISC; (void)ttyld_open(tp, tp->t_dev); } + CURVNETB_RESTORE(); splx(s); return (error); break; @@ -3127,7 +3131,9 @@ goto out; goto open_top; } + CURVNETB_SET(curthread->td_vimage->v_vnetb); /* XXX */ error = ttyld_open(tp, dev); + CURVNETB_RESTORE(); ttyldoptim(tp); if (tp->t_state & TS_ISOPEN && ISCALLOUT(dev)) tp->t_actout = TRUE; @@ -3144,7 +3150,9 @@ struct tty *tp; tp = dev->si_tty; + CURVNETB_SET(curthread->td_vimage->v_vnetb); /* XXX */ ttyld_close(tp, flag); + CURVNETB_RESTORE(); ttyldoptim(tp); tt_close(tp); tp->t_do_timestamp = 0; ==== //depot/projects/vimage/src/sys/net/if_ppp.c#3 (text+ko) ==== @@ -80,6 +80,7 @@ #include "opt_ipx.h" #include "opt_mac.h" #include "opt_ppp.h" +#include "opt_vimage.h" #ifdef INET #define VJC @@ -98,6 +99,7 @@ #include #include #include +#include #include #include @@ -1395,6 +1397,7 @@ struct mbuf *mp, *dmp = NULL; u_char *iphdr; u_int hlen; + CURVNETB_SET(ifp->if_vnetb); sc->sc_stats.ppp_ipackets++; @@ -1429,7 +1432,7 @@ m_freem(m); if (dmp == NULL) { /* no error, but no decompressed packet produced */ - return; + goto done; } m = dmp; cp = mtod(m, u_char *); @@ -1586,7 +1589,7 @@ ilen, 0) == 0) { /* drop this packet */ m_freem(m); - return; + goto done; } if (sc->sc_active_filt.bf_insns == 0 || bpf_filter(sc->sc_active_filt.bf_insns, (u_char *) m, ilen, 0)) @@ -1615,13 +1618,13 @@ || sc->sc_npmode[NP_IP] != NPMODE_PASS) { /* interface is down - drop the packet. */ m_freem(m); - return; + goto done; } m->m_pkthdr.len -= PPP_HDRLEN; m->m_data += PPP_HDRLEN; m->m_len -= PPP_HDRLEN; if ((m = ip_fastforward(m)) == NULL) - return; + goto done; isr = NETISR_IP; break; #endif @@ -1634,7 +1637,7 @@ || sc->sc_npmode[NP_IPV6] != NPMODE_PASS) { /* interface is down - drop the packet. */ m_freem(m); - return; + goto done; } m->m_pkthdr.len -= PPP_HDRLEN; m->m_data += PPP_HDRLEN; @@ -1651,7 +1654,7 @@ /* XXX: || sc->sc_npmode[NP_IPX] != NPMODE_PASS*/) { /* interface is down - drop the packet. */ m_freem(m); - return; + goto done; } m->m_pkthdr.len -= PPP_HDRLEN; m->m_data += PPP_HDRLEN; @@ -1686,6 +1689,8 @@ if (isr == -1) (*sc->sc_ctlp)(sc); + done: + CURVNETB_RESTORE(); return; bad: @@ -1693,6 +1698,7 @@ m_freem(m); PPP2IFP(sc)->if_ierrors++; sc->sc_stats.ppp_ierrors++; + CURVNETB_RESTORE(); } #define MAX_DUMP_BYTES 128