From 991cac06b2d891ebde34c4b51d803ed45f041e38 Mon Sep 17 00:00:00 2001 From: "/C=DE/ST=Berlin/L=Berlin/O=Netfilter Project/OU=Development/CN=laforge/emailAddress=laforge@netfilter.org" Date: Fri, 22 Jul 2005 06:39:45 +0000 Subject: Fix NAT of ICMP ID ranges (Patrick McHardy) --- extensions/libipt_DNAT.c | 3 ++- extensions/libipt_MASQUERADE.c | 3 ++- extensions/libipt_REDIRECT.c | 3 ++- extensions/libipt_SNAT.c | 3 ++- 4 files changed, 8 insertions(+), 4 deletions(-) (limited to 'extensions') diff --git a/extensions/libipt_DNAT.c b/extensions/libipt_DNAT.c index 9e4f525..3b0d146 100644 --- a/extensions/libipt_DNAT.c +++ b/extensions/libipt_DNAT.c @@ -143,7 +143,8 @@ parse(int c, char **argv, int invert, unsigned int *flags, int portok; if (entry->ip.proto == IPPROTO_TCP - || entry->ip.proto == IPPROTO_UDP) + || entry->ip.proto == IPPROTO_UDP + || entry->ip.proto == IPPROTO_ICMP) portok = 1; else portok = 0; diff --git a/extensions/libipt_MASQUERADE.c b/extensions/libipt_MASQUERADE.c index b661012..7eddcc0 100644 --- a/extensions/libipt_MASQUERADE.c +++ b/extensions/libipt_MASQUERADE.c @@ -81,7 +81,8 @@ parse(int c, char **argv, int invert, unsigned int *flags, = (struct ip_nat_multi_range *)(*target)->data; if (entry->ip.proto == IPPROTO_TCP - || entry->ip.proto == IPPROTO_UDP) + || entry->ip.proto == IPPROTO_UDP + || entry->ip.proto == IPPROTO_ICMP) portok = 1; else portok = 0; diff --git a/extensions/libipt_REDIRECT.c b/extensions/libipt_REDIRECT.c index 1395f62..e29bf2f 100644 --- a/extensions/libipt_REDIRECT.c +++ b/extensions/libipt_REDIRECT.c @@ -81,7 +81,8 @@ parse(int c, char **argv, int invert, unsigned int *flags, int portok; if (entry->ip.proto == IPPROTO_TCP - || entry->ip.proto == IPPROTO_UDP) + || entry->ip.proto == IPPROTO_UDP + || entry->ip.proto == IPPROTO_ICMP) portok = 1; else portok = 0; diff --git a/extensions/libipt_SNAT.c b/extensions/libipt_SNAT.c index a893a47..7460760 100644 --- a/extensions/libipt_SNAT.c +++ b/extensions/libipt_SNAT.c @@ -143,7 +143,8 @@ parse(int c, char **argv, int invert, unsigned int *flags, int portok; if (entry->ip.proto == IPPROTO_TCP - || entry->ip.proto == IPPROTO_UDP) + || entry->ip.proto == IPPROTO_UDP + || entry->ip.proto == IPPROTO_ICMP) portok = 1; else portok = 0; -- cgit v1.2.3