aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Langer <alex@FreeBSD.org>1996-06-25 00:22:20 +0000
committerAlexander Langer <alex@FreeBSD.org>1996-06-25 00:22:20 +0000
commit830b0d30391000c96e6525f53169b1fe62c81945 (patch)
tree9d228a687997e18968a4ed4603a28547af166da7
parent545f9f440b645450b91d181d553ace1316f4c7b6 (diff)
downloadsrc-830b0d30391000c96e6525f53169b1fe62c81945.tar.gz
src-830b0d30391000c96e6525f53169b1fe62c81945.zip
Notes
-rw-r--r--sys/netinet/ip_fw.c42
1 files changed, 26 insertions, 16 deletions
diff --git a/sys/netinet/ip_fw.c b/sys/netinet/ip_fw.c
index 5cff936eabd9..d18bd48cff40 100644
--- a/sys/netinet/ip_fw.c
+++ b/sys/netinet/ip_fw.c
@@ -12,7 +12,7 @@
*
* This software is provided ``AS IS'' without any warranties of any kind.
*
- * $Id: ip_fw.c,v 1.40 1996/06/17 00:00:35 alex Exp $
+ * $Id: ip_fw.c,v 1.41 1996/06/23 14:28:02 bde Exp $
*/
/*
@@ -413,23 +413,22 @@ ip_fw_chk(struct ip **pip, int hlen, struct ifnet *rif, int dir, struct mbuf **m
goto got_match;
}
- /* Fragments can't match past this point */
- if (ip->ip_off & IP_OFFMASK)
- continue;
-
- /* TCP, a little more checking */
- if (prt == IP_FW_F_TCP &&
- (f->fw_tcpf != f->fw_tcpnf) &&
- (!tcpflg_match(tcp, f)))
- continue;
+ /* Check TCP flags and TCP/UDP ports only if packet is not fragment */
+ if (!(ip->ip_off & IP_OFFMASK)) {
+ /* TCP, a little more checking */
+ if (prt == IP_FW_F_TCP &&
+ (f->fw_tcpf != f->fw_tcpnf) &&
+ (!tcpflg_match(tcp, f)))
+ continue;
- if (!port_match(&f->fw_pts[0], f->fw_nsp,
- src_port, f->fw_flg & IP_FW_F_SRNG))
- continue;
+ if (!port_match(&f->fw_pts[0], f->fw_nsp,
+ src_port, f->fw_flg & IP_FW_F_SRNG))
+ continue;
- if (!port_match(&f->fw_pts[f->fw_nsp], f->fw_ndp,
- dst_port, f->fw_flg & IP_FW_F_DRNG))
- continue;
+ if (!port_match(&f->fw_pts[f->fw_nsp], f->fw_ndp,
+ dst_port, f->fw_flg & IP_FW_F_DRNG))
+ continue;
+ }
got_match:
f->fw_pcnt++;
@@ -633,6 +632,17 @@ check_ipfw_struct(struct mbuf *m)
frwl->fw_nsp, frwl->fw_ndp));
return (NULL);
}
+
+ /*
+ * Rather than modify the entry to make such entries work,
+ * we reject this rule and require user level utilities
+ * to enforce whatever policy they deem appropriate.
+ */
+ if ((frwl->fw_src.s_addr & (~frwl->fw_smsk.s_addr)) ||
+ (frwl->fw_dst.s_addr & (~frwl->fw_dmsk.s_addr))) {
+ dprintf(("ip_fw_ctl: rule never matches\n"));
+ return(NULL);
+ }
return frwl;
}