diff options
author | Patrick McHardy <kaber@trash.net> | 2005-08-22 02:31:43 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2005-08-29 19:04:18 -0400 |
commit | 05465343bf74e00c8c2c5a310740157de3149f27 (patch) | |
tree | 393fc1fb09668faf3968726f6e8e5039109224a9 /net | |
parent | 764d8a9f240729534a1d8a0ffd39e722cf5cc5af (diff) |
[NETFILTER]: Add goto target
Originally written by Henrik Nordstrom <hno@marasystems.com>, taken
from netfilter patch-o-matic and added ip6_tables support.
Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r-- | net/ipv4/netfilter/ip_tables.c | 4 | ||||
-rw-r--r-- | net/ipv6/netfilter/ip6_tables.c | 4 |
2 files changed, 4 insertions, 4 deletions
diff --git a/net/ipv4/netfilter/ip_tables.c b/net/ipv4/netfilter/ip_tables.c index ff8d85d2070d..eef99a1b5de6 100644 --- a/net/ipv4/netfilter/ip_tables.c +++ b/net/ipv4/netfilter/ip_tables.c | |||
@@ -340,8 +340,8 @@ ipt_do_table(struct sk_buff **pskb, | |||
340 | back->comefrom); | 340 | back->comefrom); |
341 | continue; | 341 | continue; |
342 | } | 342 | } |
343 | if (table_base + v | 343 | if (table_base + v != (void *)e + e->next_offset |
344 | != (void *)e + e->next_offset) { | 344 | && !(e->ip.flags & IPT_F_GOTO)) { |
345 | /* Save old back ptr in next entry */ | 345 | /* Save old back ptr in next entry */ |
346 | struct ipt_entry *next | 346 | struct ipt_entry *next |
347 | = (void *)e + e->next_offset; | 347 | = (void *)e + e->next_offset; |
diff --git a/net/ipv6/netfilter/ip6_tables.c b/net/ipv6/netfilter/ip6_tables.c index 41a67cf6e33a..1cb8adb2787f 100644 --- a/net/ipv6/netfilter/ip6_tables.c +++ b/net/ipv6/netfilter/ip6_tables.c | |||
@@ -433,8 +433,8 @@ ip6t_do_table(struct sk_buff **pskb, | |||
433 | back->comefrom); | 433 | back->comefrom); |
434 | continue; | 434 | continue; |
435 | } | 435 | } |
436 | if (table_base + v | 436 | if (table_base + v != (void *)e + e->next_offset |
437 | != (void *)e + e->next_offset) { | 437 | && !(e->ipv6.flags & IP6T_F_GOTO)) { |
438 | /* Save old back ptr in next entry */ | 438 | /* Save old back ptr in next entry */ |
439 | struct ip6t_entry *next | 439 | struct ip6t_entry *next |
440 | = (void *)e + e->next_offset; | 440 | = (void *)e + e->next_offset; |