From owner-p4-projects@FreeBSD.ORG Thu Jul 17 19:54:17 2008 Return-Path: Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 3C5961065678; Thu, 17 Jul 2008 19:54:17 +0000 (UTC) Delivered-To: perforce@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 00E241065675 for ; Thu, 17 Jul 2008 19:54:17 +0000 (UTC) (envelope-from gk@FreeBSD.org) Received: from repoman.freebsd.org (repoman.freebsd.org [IPv6:2001:4f8:fff6::29]) by mx1.freebsd.org (Postfix) with ESMTP id DCCC28FC23 for ; Thu, 17 Jul 2008 19:54:16 +0000 (UTC) (envelope-from gk@FreeBSD.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.14.1/8.14.1) with ESMTP id m6HJsG2A017594 for ; Thu, 17 Jul 2008 19:54:16 GMT (envelope-from gk@FreeBSD.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.14.2/8.14.1/Submit) id m6HJsGhU017592 for perforce@freebsd.org; Thu, 17 Jul 2008 19:54:16 GMT (envelope-from gk@FreeBSD.org) Date: Thu, 17 Jul 2008 19:54:16 GMT Message-Id: <200807171954.m6HJsGhU017592@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to gk@FreeBSD.org using -f From: Gleb Kurtsou To: Perforce Change Reviews Cc: Subject: PERFORCE change 145386 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: Thu, 17 Jul 2008 19:54:17 -0000 http://perforce.freebsd.org/chv.cgi?CH=145386 Change 145386 by gk@gk_h1 on 2008/07/17 19:53:19 Use mtag_ether_header in pf. support inet4 only for now Affected files ... .. //depot/projects/soc2008/gk_l2filter/sys-pf/net/pf_ioctl.c#2 edit Differences ... ==== //depot/projects/soc2008/gk_l2filter/sys-pf/net/pf_ioctl.c#2 (text+ko) ==== @@ -111,6 +111,7 @@ #ifdef __FreeBSD__ #include +#include #else #include #include @@ -3636,6 +3637,7 @@ * byte order. */ struct ip *h = NULL; + struct m_tag *tag_ether_hdr; int chk; if ((*m)->m_pkthdr.len >= (int)sizeof(struct ip)) { @@ -3644,7 +3646,10 @@ HTONS(h->ip_len); HTONS(h->ip_off); } - chk = pf_test(PF_IN, ifp, m, NULL, inp); + tag_ether_hdr = m_tag_locate(*m, MTAG_ETHER, MTAG_ETHER_HEADER, NULL); + chk = pf_test(PF_IN, ifp, m, + tag_ether_hdr ? (struct ether_header *)(tag_ether_hdr + 1) : NULL, + inp); if (chk && *m) { m_freem(*m); *m = NULL; @@ -3671,6 +3676,7 @@ * byte order. */ struct ip *h = NULL; + struct m_tag *tag_ether_hdr; int chk; /* We need a proper CSUM befor we start (s. OpenBSD ip_output) */ @@ -3684,7 +3690,10 @@ HTONS(h->ip_len); HTONS(h->ip_off); } - chk = pf_test(PF_OUT, ifp, m, NULL, inp); + tag_ether_hdr = m_tag_locate(*m, MTAG_ETHER, MTAG_ETHER_HEADER, NULL); + chk = pf_test(PF_OUT, ifp, m, + tag_ether_hdr ? (struct ether_header *)(tag_ether_hdr + 1) : NULL, + inp); if (chk && *m) { m_freem(*m); *m = NULL;