From owner-svn-src-user@FreeBSD.ORG Sat Oct 10 19:54:45 2009 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id E4F09106566B; Sat, 10 Oct 2009 19:54:45 +0000 (UTC) (envelope-from eri@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:4f8:fff6::2c]) by mx1.freebsd.org (Postfix) with ESMTP id D2BFB8FC08; Sat, 10 Oct 2009 19:54:45 +0000 (UTC) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.3/8.14.3) with ESMTP id n9AJsjDa090809; Sat, 10 Oct 2009 19:54:45 GMT (envelope-from eri@svn.freebsd.org) Received: (from eri@localhost) by svn.freebsd.org (8.14.3/8.14.3/Submit) id n9AJsjmA090800; Sat, 10 Oct 2009 19:54:45 GMT (envelope-from eri@svn.freebsd.org) Message-Id: <200910101954.n9AJsjmA090800@svn.freebsd.org> From: Ermal Luçi Date: Sat, 10 Oct 2009 19:54:45 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r197939 - in user/eri/pf45/head/sys: contrib/pf/net modules/pflow net X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sat, 10 Oct 2009 19:54:46 -0000 Author: eri Date: Sat Oct 10 19:54:45 2009 New Revision: 197939 URL: http://svn.freebsd.org/changeset/base/197939 Log: * Make pflow(4) compile. TODO: Add locking to it. Added: user/eri/pf45/head/sys/modules/pflow/ user/eri/pf45/head/sys/modules/pflow/Makefile (contents, props changed) Modified: user/eri/pf45/head/sys/contrib/pf/net/if_pflow.c user/eri/pf45/head/sys/contrib/pf/net/if_pflow.h user/eri/pf45/head/sys/contrib/pf/net/if_pfsync.c user/eri/pf45/head/sys/contrib/pf/net/pf.c user/eri/pf45/head/sys/contrib/pf/net/pf_ioctl.c user/eri/pf45/head/sys/contrib/pf/net/pfvar.h user/eri/pf45/head/sys/net/if_types.h Modified: user/eri/pf45/head/sys/contrib/pf/net/if_pflow.c ============================================================================== --- user/eri/pf45/head/sys/contrib/pf/net/if_pflow.c Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/contrib/pf/net/if_pflow.c Sat Oct 10 19:54:45 2009 (r197939) @@ -17,17 +17,50 @@ * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ +#ifdef __FreeBSD__ +#include "opt_inet.h" +#include "opt_inet6.h" +#include "opt_bpf.h" +#include "opt_pf.h" + +#include +__FBSDID("$FreeBSD$"); + +#ifdef DEV_BPF +#define NBPFILTER DEV_BPF +#else +#define NBPFILTER 0 +#endif + +#endif /* __FreeBSD__ */ + #include +#ifdef __FreeBSD__ +#include +#endif #include #include #include #include +#ifdef __FreeBSD__ +#include +#include +#include +#include +#include +#else #include +#endif #include #include +#ifndef __FreeBSD__ #include +#endif #include +#ifdef __FreeBSD__ +#include +#endif #include #include #include @@ -49,9 +82,14 @@ #include #include +#ifndef __FreeBSD__ #include "bpfilter.h" #include "pflow.h" +#endif +#ifdef __FreeBSD__ +#include +#endif #define PFLOW_MINMTU \ (sizeof(struct pflow_header) + sizeof(struct pflow_flow)) @@ -65,11 +103,20 @@ SLIST_HEAD(, pflow_softc) pflowif_list; struct pflowstats pflowstats; void pflowattach(int); +#ifdef __FreeBSD__ +int pflow_clone_create(struct if_clone *, int, caddr_t); +void pflow_clone_destroy(struct ifnet *); +#else int pflow_clone_create(struct if_clone *, int); int pflow_clone_destroy(struct ifnet *); +#endif void pflow_setmtu(struct pflow_softc *, int); int pflowoutput(struct ifnet *, struct mbuf *, struct sockaddr *, +#ifdef __FreeBSD__ + struct route *); +#else struct rtentry *); +#endif int pflowioctl(struct ifnet *, u_long, caddr_t); void pflowstart(struct ifnet *); @@ -84,16 +131,22 @@ int pflow_get_dynport(void); int export_pflow_if(struct pf_state*, struct pflow_softc *); int copy_flow_to_m(struct pflow_flow *flow, struct pflow_softc *sc); +#ifdef __FreeBSD__ +IFC_SIMPLE_DECLARE(pflow, 1); +#else struct if_clone pflow_cloner = IF_CLONE_INITIALIZER("pflow", pflow_clone_create, pflow_clone_destroy); +#endif +#ifndef __FreeBSD__ /* from in_pcb.c */ extern int ipport_hifirstauto; extern int ipport_hilastauto; /* from kern/kern_clock.c; incremented each clock tick. */ extern int ticks; +#endif void pflowattach(int npflow) @@ -103,7 +156,11 @@ pflowattach(int npflow) } int +#ifdef __FreeBSD__ +pflow_clone_create(struct if_clone *ifc, int unit, caddr_t param) +#else pflow_clone_create(struct if_clone *ifc, int unit) +#endif { struct ifnet *ifp; struct pflow_softc *pflowif; @@ -115,16 +172,33 @@ pflow_clone_create(struct if_clone *ifc, pflowif->sc_sender_ip.s_addr = INADDR_ANY; pflowif->sc_sender_port = pflow_get_dynport(); +#ifdef __FreeBSD__ + pflowif->sc_imo.imo_membership = (struct in_multi **)malloc( + (sizeof(struct in_multi *) * IP_MIN_MEMBERSHIPS), M_DEVBUF, + M_NOWAIT | M_ZERO); + pflowif->sc_imo.imo_multicast_vif = -1; +#else pflowif->sc_imo.imo_membership = malloc( (sizeof(struct in_multi *) * IP_MIN_MEMBERSHIPS), M_IPMOPTS, M_WAITOK|M_ZERO); +#endif pflowif->sc_imo.imo_max_memberships = IP_MIN_MEMBERSHIPS; pflowif->sc_receiver_ip.s_addr = 0; pflowif->sc_receiver_port = 0; pflowif->sc_sender_ip.s_addr = INADDR_ANY; pflowif->sc_sender_port = pflow_get_dynport(); +#ifdef __FreeBSD__ + ifp = pflowif->sc_ifp = if_alloc(IFT_PFLOW); + if (ifp == NULL) { + free(pflowif->sc_imo.imo_membership, M_DEVBUF); + free(pflowif, M_DEVBUF); + return (ENOSPC); + } + if_initname(ifp, ifc->ifc_name, unit); +#else ifp = &pflowif->sc_if; snprintf(ifp->if_xname, sizeof ifp->if_xname, "pflow%d", unit); +#endif ifp->if_softc = pflowif; ifp->if_ioctl = pflowioctl; ifp->if_output = pflowoutput; @@ -133,22 +207,39 @@ pflow_clone_create(struct if_clone *ifc, ifp->if_snd.ifq_maxlen = ifqmaxlen; ifp->if_hdrlen = PFLOW_HDRLEN; ifp->if_flags = IFF_UP; +#ifdef __FreeBSD__ + ifp->if_flags &= ~IFF_DRV_RUNNING; +#else ifp->if_flags &= ~IFF_RUNNING; /* not running, need receiver */ +#endif pflow_setmtu(pflowif, ETHERMTU); +#ifdef __FreeBSD__ + callout_init(&pflowif->sc_tmo, CALLOUT_MPSAFE); +#else timeout_set(&pflowif->sc_tmo, pflow_timeout, pflowif); +#endif if_attach(ifp); +#ifndef __FreeBSD__ if_alloc_sadl(ifp); +#endif #if NBPFILTER > 0 +#ifdef __FreeBSD__ + bpfattach(ifp, DLT_RAW, 0); +#else bpfattach(&pflowif->sc_if.if_bpf, ifp, DLT_RAW, 0); #endif - +#endif /* Insert into list of pflows */ SLIST_INSERT_HEAD(&pflowif_list, pflowif, sc_next); return (0); } +#ifdef __FreeBSD__ +void +#else int +#endif pflow_clone_destroy(struct ifnet *ifp) { struct pflow_softc *sc = ifp->if_softc; @@ -161,10 +252,16 @@ pflow_clone_destroy(struct ifnet *ifp) #endif if_detach(ifp); SLIST_REMOVE(&pflowif_list, sc, pflow_softc, sc_next); +#ifdef __FreeBSD__ + free(sc->sc_imo.imo_membership, M_DEVBUF); +#else free(sc->sc_imo.imo_membership, M_IPMOPTS); +#endif free(sc, M_DEVBUF); splx(s); +#ifndef __FreeBSD__ return (0); +#endif } /* @@ -178,8 +275,17 @@ pflowstart(struct ifnet *ifp) for (;;) { s = splnet(); +#ifdef __FreeBSD__ + IF_LOCK(&ifp->if_snd); + _IF_DROP(&ifp->if_snd); + _IF_DEQUEUE(&ifp->if_snd, m); +#else IF_DROP(&ifp->if_snd); IF_DEQUEUE(&ifp->if_snd, m); +#endif +#ifdef __FreeBSD__ + IF_UNLOCK(&ifp->if_snd); +#endif splx(s); if (m == NULL) @@ -190,7 +296,11 @@ pflowstart(struct ifnet *ifp) int pflowoutput(struct ifnet *ifp, struct mbuf *m, struct sockaddr *dst, +#ifdef __FreeBSD__ + struct route *rt) +#else struct rtentry *rt) +#endif { m_freem(m); return (0); @@ -200,7 +310,9 @@ pflowoutput(struct ifnet *ifp, struct mb int pflowioctl(struct ifnet *ifp, u_long cmd, caddr_t data) { +#ifndef __FreeBSD__ struct proc *p = curproc; +#endif struct pflow_softc *sc = ifp->if_softc; struct ifreq *ifr = (struct ifreq *)data; struct pflowreq pflowr; @@ -214,10 +326,18 @@ pflowioctl(struct ifnet *ifp, u_long cmd if ((ifp->if_flags & IFF_UP) && sc->sc_receiver_ip.s_addr != 0 && sc->sc_receiver_port != 0) { +#ifdef __FreeBSD__ + ifp->if_drv_flags |= IFF_DRV_RUNNING; +#else ifp->if_flags |= IFF_RUNNING; +#endif sc->sc_gcounter=pflowstats.pflow_flows; } else +#ifdef __FreeBSD__ + ifp->if_drv_flags &= ~IFF_DRV_RUNNING; +#else ifp->if_flags &= ~IFF_RUNNING; +#endif break; case SIOCSIFMTU: if (ifr->ifr_mtu < PFLOW_MINMTU) @@ -244,7 +364,11 @@ pflowioctl(struct ifnet *ifp, u_long cmd break; case SIOCSETPFLOW: +#ifdef __FreeBSD__ + if ((error = priv_check(curthread, PRIV_NETINET_PF)) != 0) +#else if ((error = suser(p, p->p_acflag)) != 0) +#endif return (error); if ((error = copyin(ifr->ifr_data, &pflowr, sizeof(pflowr)))) @@ -264,10 +388,18 @@ pflowioctl(struct ifnet *ifp, u_long cmd if ((ifp->if_flags & IFF_UP) && sc->sc_receiver_ip.s_addr != 0 && sc->sc_receiver_port != 0) { +#ifdef __FreeBSD__ + ifp->if_drv_flags |= IFF_DRV_RUNNING; +#else ifp->if_flags |= IFF_RUNNING; +#endif sc->sc_gcounter=pflowstats.pflow_flows; } else +#ifdef __FreeBSD__ + ifp->if_drv_flags &= ~IFF_DRV_RUNNING; +#else ifp->if_flags &= ~IFF_RUNNING; +#endif break; @@ -291,7 +423,11 @@ pflow_setmtu(struct pflow_softc *sc, int sizeof (struct udpiphdr)) / sizeof(struct pflow_flow); if (sc->sc_maxcount > PFLOW_MAXFLOWS) sc->sc_maxcount = PFLOW_MAXFLOWS; +#ifdef __FreeBSD__ + sc->sc_ifp->if_mtu = sizeof(struct pflow_header) + +#else sc->sc_if.if_mtu = sizeof(struct pflow_header) + +#endif sizeof (struct udpiphdr) + sc->sc_maxcount * sizeof(struct pflow_flow); } @@ -326,10 +462,19 @@ pflow_get_mbuf(struct pflow_softc *sc) h.flow_sequence = htonl(sc->sc_gcounter); h.engine_type = PFLOW_ENGINE_TYPE; h.engine_id = PFLOW_ENGINE_ID; +#ifdef __FreeBSD__ + m_copyback(m, 0, PFLOW_HDRLEN, (caddr_t)&h); +#else m_copyback(m, 0, PFLOW_HDRLEN, &h); +#endif sc->sc_count = 0; +#ifdef __FreeBSD__ + callout_reset(&sc->sc_tmo, PFLOW_TIMEOUT * hz, + pflow_timeout, sc); +#else timeout_add_sec(&sc->sc_tmo, PFLOW_TIMEOUT); +#endif return (m); } @@ -383,11 +528,19 @@ int export_pflow_if(struct pf_state *st, struct pflow_softc *sc) { struct pf_state pfs_copy; +#ifdef __FreeBSD__ + struct ifnet *ifp = sc->sc_ifp; +#else struct ifnet *ifp = &sc->sc_if; +#endif u_int64_t bytes[2]; int ret = 0; +#ifdef __FreeBSD__ + if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) +#else if (!(ifp->if_flags & IFF_RUNNING)) +#endif return (0); if ((st->bytes[0] < (u_int64_t)PFLOW_MAXBYTES) @@ -439,7 +592,11 @@ copy_flow_to_m(struct pflow_flow *flow, } m_copyback(sc->sc_mbuf, PFLOW_HDRLEN + (sc->sc_count * sizeof (struct pflow_flow)), +#ifdef __FreeBSD__ + sizeof (struct pflow_flow), (caddr_t)flow); +#else sizeof (struct pflow_flow), flow); +#endif if (pflowstats.pflow_flows == sc->sc_gcounter) pflowstats.pflow_flows++; @@ -494,15 +651,27 @@ pflow_sendout(struct pflow_softc *sc) { struct mbuf *m = sc->sc_mbuf; struct pflow_header *h; +#ifdef __FreeBSD__ + struct ifnet *ifp = sc->sc_ifp; +#else struct ifnet *ifp = &sc->sc_if; +#endif +#ifdef __FreeBSD__ + callout_stop(&sc->sc_tmo); +#else timeout_del(&sc->sc_tmo); +#endif if (m == NULL) return (0); sc->sc_mbuf = NULL; +#ifdef __FreeBSD__ + if (!(ifp->if_drv_flags & IFF_DRV_RUNNING)) { +#else if (!(ifp->if_flags & IFF_RUNNING)) { +#endif m_freem(m); return (0); } @@ -524,7 +693,11 @@ pflow_sendout_mbuf(struct pflow_softc *s { struct udpiphdr *ui; u_int16_t len = m->m_pkthdr.len; +#ifdef __FreeBSD__ + struct ifnet *ifp = sc->sc_ifp; +#else struct ifnet *ifp = &sc->sc_if; +#endif struct ip *ip; int err; @@ -556,24 +729,40 @@ pflow_sendout_mbuf(struct pflow_softc *s * Compute the pseudo-header checksum; defer further checksumming * until ip_output() or hardware (if it exists). */ +#ifndef __FreeBSD__ + /* XXX */ m->m_pkthdr.csum_flags |= M_UDPV4_CSUM_OUT; ui->ui_sum = in_cksum_phdr(ui->ui_src.s_addr, ui->ui_dst.s_addr, htons(len + sizeof(struct udphdr) + IPPROTO_UDP)); +#endif #if NBPFILTER > 0 if (ifp->if_bpf) { ip->ip_sum = in_cksum(m, ip->ip_hl << 2); +#ifdef __FreeBSD__ + BPF_MTAP(ifp, m); +#else bpf_mtap(ifp->if_bpf, m, BPF_DIRECTION_OUT); +#endif } #endif +#ifdef __FreeBSD__ + sc->sc_ifp->if_opackets++; + sc->sc_ifp->if_obytes += m->m_pkthdr.len; +#else sc->sc_if.if_opackets++; sc->sc_if.if_obytes += m->m_pkthdr.len; +#endif if ((err = ip_output(m, NULL, NULL, IP_RAWOUTPUT, &sc->sc_imo, NULL))) { pflowstats.pflow_oerrors++; +#ifdef __FreeBSD__ + sc->sc_ifp->if_oerrors++; +#else sc->sc_if.if_oerrors++; +#endif } return (err); } @@ -581,13 +770,29 @@ pflow_sendout_mbuf(struct pflow_softc *s int pflow_get_dynport(void) { +#ifdef __FreeBSD__ + u_int16_t low, high, cut; +#else u_int16_t tmp, low, high, cut; +#endif +#ifdef __FreeBSD__ + low = V_ipport_firstauto; /* sysctl */ + high = V_ipport_lastauto; +#else low = ipport_hifirstauto; /* sysctl */ high = ipport_hilastauto; +#endif +#ifdef __FreeBSD__ + cut = low + (arc4random() % (1 + high - low)); +#else cut = arc4random_uniform(1 + high - low) + low; +#endif +#ifdef __FreeBSD__ + return (cut); +#else for (tmp = cut; tmp <= high; ++(tmp)) { if (!in_baddynamic(tmp, IPPROTO_UDP)) return (htons(tmp)); @@ -599,8 +804,10 @@ pflow_get_dynport(void) } return (htons(ipport_hilastauto)); /* XXX */ +#endif } +#ifdef notyet int pflow_sysctl(int *name, u_int namelen, void *oldp, size_t *oldlenp, void *newp, size_t newlen) @@ -619,3 +826,40 @@ pflow_sysctl(int *name, u_int namelen, v } return (0); } +#endif + +#ifdef __FreeBSD__ +static int +pflow_modevent(module_t mod, int type, void *data) +{ + int error = 0; + + switch (type) { + case MOD_LOAD: + pflowattach(0); + export_pflow_ptr = export_pflow; + break; + case MOD_UNLOAD: + if_clone_detach(&pflow_cloner); + export_pflow_ptr = NULL; + break; + default: + error = EINVAL; + break; + } + + return error; +} + +static moduledata_t pflow_mod = { + "pflow", + pflow_modevent, + 0 +}; + +#define PFLOW_MODVER 1 + +DECLARE_MODULE(pflow, pflow_mod, SI_SUB_PROTO_IFATTACHDOMAIN, SI_ORDER_ANY); +MODULE_VERSION(pflow, PFLOW_MODVER); +MODULE_DEPEND(pflow, pf, PF_MODVER, PF_MODVER, PF_MODVER); +#endif /* __FreeBSD__ */ Modified: user/eri/pf45/head/sys/contrib/pf/net/if_pflow.h ============================================================================== --- user/eri/pf45/head/sys/contrib/pf/net/if_pflow.h Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/contrib/pf/net/if_pflow.h Sat Oct 10 19:54:45 2009 (r197939) @@ -57,14 +57,22 @@ struct pflow_flow { extern int pflow_ok; struct pflow_softc { +#ifdef __FreeBSD__ + struct ifnet *sc_ifp; +#else struct ifnet sc_if; +#endif struct ifnet *sc_pflow_ifp; unsigned int sc_count; unsigned int sc_maxcount; u_int64_t sc_gcounter; struct ip_moptions sc_imo; +#ifdef __FreeBSD__ + struct callout sc_tmo; +#else struct timeout sc_tmo; +#endif struct in_addr sc_sender_ip; u_int16_t sc_sender_port; struct in_addr sc_receiver_ip; @@ -74,7 +82,6 @@ struct pflow_softc { }; extern struct pflow_softc *pflowif; - #endif /* _KERNEL */ struct pflow_header { @@ -113,6 +120,11 @@ struct pflowreq { }; #ifdef _KERNEL +#ifdef __FreeBSD__ +#define SIOCSETPFLOW _IOW('i', 249, struct ifreq) +#define SIOCGETPFLOW _IOWR('i', 250, struct ifreq) +#endif + int export_pflow(struct pf_state *); int pflow_sysctl(int *, u_int, void *, size_t *, void *, size_t); #endif /* _KERNEL */ Modified: user/eri/pf45/head/sys/contrib/pf/net/if_pfsync.c ============================================================================== --- user/eri/pf45/head/sys/contrib/pf/net/if_pfsync.c Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/contrib/pf/net/if_pfsync.c Sat Oct 10 19:54:45 2009 (r197939) @@ -104,9 +104,6 @@ __FBSDID("$FreeBSD$"); #include #endif #include -#ifdef __FreeBSD__ -#include -#endif #include #include #include @@ -3082,5 +3079,5 @@ static moduledata_t pfsync_mod = { DECLARE_MODULE(pfsync, pfsync_mod, SI_SUB_PROTO_IFATTACHDOMAIN, SI_ORDER_ANY); MODULE_VERSION(pfsync, PFSYNC_MODVER); -MODULE_DEPEND(pflog, pf, PF_MODVER, PF_MODVER, PF_MODVER); +MODULE_DEPEND(pfsync, pf, PF_MODVER, PF_MODVER, PF_MODVER); #endif /* __FreeBSD__ */ Modified: user/eri/pf45/head/sys/contrib/pf/net/pf.c ============================================================================== --- user/eri/pf45/head/sys/contrib/pf/net/pf.c Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/contrib/pf/net/pf.c Sat Oct 10 19:54:45 2009 (r197939) @@ -1338,8 +1338,13 @@ pf_unlink_state(struct pf_state *cur) RB_REMOVE(pf_state_tree_id, &tree_id, cur); #if NPFLOW > 0 if (cur->state_flags & PFSTATE_PFLOW) +#ifdef __FreeBSD__ + if (export_pflow_ptr != NULL) + export_pflow_ptr(cur); +#else export_pflow(cur); #endif +#endif #if NPFSYNC > 0 #ifdef __FreeBSD__ if (pfsync_delete_state_ptr != NULL) Modified: user/eri/pf45/head/sys/contrib/pf/net/pf_ioctl.c ============================================================================== --- user/eri/pf45/head/sys/contrib/pf/net/pf_ioctl.c Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/contrib/pf/net/pf_ioctl.c Sat Oct 10 19:54:45 2009 (r197939) @@ -246,6 +246,7 @@ static struct cdevsw pf_cdevsw = { int pf_end_threads = 0; struct mtx pf_task_mtx; #ifdef __FreeBSD__ + /* pfsync */ pfsync_state_import_t *pfsync_state_import_ptr = NULL; pfsync_up_t *pfsync_up_ptr = NULL; pfsync_insert_state_t *pfsync_insert_state_ptr = NULL; @@ -253,6 +254,8 @@ static struct cdevsw pf_cdevsw = { pfsync_delete_state_t *pfsync_delete_state_ptr = NULL; pfsync_clear_states_t *pfsync_clear_states_ptr = NULL; pfsync_defer_t *pfsync_defer_ptr = NULL; + /* pflow */ + export_pflow_t *export_pflow_ptr = NULL; #if NPFLOG >0 pflog_packet_t *pflog_packet_ptr = NULL; #endif Modified: user/eri/pf45/head/sys/contrib/pf/net/pfvar.h ============================================================================== --- user/eri/pf45/head/sys/contrib/pf/net/pfvar.h Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/contrib/pf/net/pfvar.h Sat Oct 10 19:54:45 2009 (r197939) @@ -929,6 +929,7 @@ struct pfsync_state { } __packed; #ifdef __FreeBSD__ +/* pfsync */ typedef int pfsync_state_import_t(struct pfsync_state *, u_int8_t); typedef int pfsync_up_t(void); typedef void pfsync_insert_state_t(struct pf_state *); @@ -948,6 +949,11 @@ extern pfsync_defer_t *pfsync_defer_ptr void pfsync_state_export(struct pfsync_state *, struct pf_state *); +/* pflow */ +typedef int export_pflow_t(struct pf_state *); + +extern export_pflow_t *export_pflow_ptr; + /* Macros to set/clear/test flags. */ #ifdef _KERNEL #define SET(t, f) ((t) |= (f)) Added: user/eri/pf45/head/sys/modules/pflow/Makefile ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ user/eri/pf45/head/sys/modules/pflow/Makefile Sat Oct 10 19:54:45 2009 (r197939) @@ -0,0 +1,25 @@ + +.include + +.PATH: ${.CURDIR}/../../contrib/pf/net + +KMOD= pflow +SRCS = if_pflow.c \ + opt_pf.h opt_inet.h opt_inet6.h opt_bpf.h + +CFLAGS+= -I${.CURDIR}/../../contrib/pf + +.if !defined(KERNBUILDDIR) +opt_inet.h: + echo "#define INET 1" > ${.TARGET} + +.if ${MK_INET6_SUPPORT} != "no" +opt_inet6.h: + echo "#define INET6 1" > ${.TARGET} +.endif + +opt_bpf.h: + echo "#define DEV_BPF 1" > ${.TARGET} +.endif + +.include Modified: user/eri/pf45/head/sys/net/if_types.h ============================================================================== --- user/eri/pf45/head/sys/net/if_types.h Sat Oct 10 18:24:54 2009 (r197938) +++ user/eri/pf45/head/sys/net/if_types.h Sat Oct 10 19:54:45 2009 (r197939) @@ -251,4 +251,5 @@ #define IFT_PFSYNC 0xf7 #define IFT_CARP 0xf8 /* Common Address Redundancy Protocol */ #define IFT_IPXIP 0xf9 /* IPX over IP tunneling; no longer used. */ +#define IFT_PFLOW 0xfa /* pflow */ #endif /* !_NET_IF_TYPES_H_ */