diff options
author | Bart De Schuymer <bdschuym@pandora.be> | 2002-08-20 17:06:14 +0000 |
---|---|---|
committer | Bart De Schuymer <bdschuym@pandora.be> | 2002-08-20 17:06:14 +0000 |
commit | f382b8eae1527e8abab106436bb8ff54d137d6c6 (patch) | |
tree | 5ec242ea28ab74d3bd0064adcef9158fb453fc93 /kernel/linux/net/bridge/netfilter/ebt_redirect.c | |
parent | 831873ee9b24b205f74640e89b01fb137e32bf5c (diff) |
cleanups
Diffstat (limited to 'kernel/linux/net/bridge/netfilter/ebt_redirect.c')
-rw-r--r-- | kernel/linux/net/bridge/netfilter/ebt_redirect.c | 19 |
1 files changed, 8 insertions, 11 deletions
diff --git a/kernel/linux/net/bridge/netfilter/ebt_redirect.c b/kernel/linux/net/bridge/netfilter/ebt_redirect.c index d7c51ba..0512fa2 100644 --- a/kernel/linux/net/bridge/netfilter/ebt_redirect.c +++ b/kernel/linux/net/bridge/netfilter/ebt_redirect.c @@ -10,8 +10,6 @@ #include <linux/netfilter_bridge/ebtables.h> #include <linux/netfilter_bridge/ebt_redirect.h> -#include <linux/netfilter_bridge.h> -#include <linux/skbuff.h> #include <linux/module.h> #include <net/sock.h> #include "../br_private.h" @@ -20,7 +18,7 @@ static int ebt_target_redirect(struct sk_buff **pskb, unsigned int hooknr, const struct net_device *in, const struct net_device *out, const void *data, unsigned int datalen) { - struct ebt_redirect_info *infostuff = (struct ebt_redirect_info *) data; + struct ebt_redirect_info *info = (struct ebt_redirect_info *)data; if (hooknr != NF_BR_BROUTING) memcpy((**pskb).mac.ethernet->h_dest, @@ -30,24 +28,23 @@ static int ebt_target_redirect(struct sk_buff **pskb, unsigned int hooknr, in->dev_addr, ETH_ALEN); (*pskb)->pkt_type = PACKET_HOST; } - return infostuff->target; + return info->target; } static int ebt_target_redirect_check(const char *tablename, unsigned int hookmask, const struct ebt_entry *e, void *data, unsigned int datalen) { - struct ebt_redirect_info *infostuff = (struct ebt_redirect_info *) data; + struct ebt_redirect_info *info = (struct ebt_redirect_info *)data; - if ((hookmask & (1 << NF_BR_NUMHOOKS)) && - infostuff->target == EBT_RETURN) + if (datalen != sizeof(struct ebt_redirect_info)) + return -EINVAL; + if (BASE_CHAIN && info->target == EBT_RETURN) return -EINVAL; - hookmask &= ~(1 << NF_BR_NUMHOOKS); + CLEAR_BASE_CHAIN_BIT; if ( (strcmp(tablename, "nat") || hookmask & ~(1 << NF_BR_PRE_ROUTING)) && (strcmp(tablename, "broute") || hookmask & ~(1 << NF_BR_BROUTING)) ) return -EINVAL; - if (datalen != sizeof(struct ebt_redirect_info)) - return -EINVAL; - if (infostuff->target < -NUM_STANDARD_TARGETS || infostuff->target >= 0) + if (INVALID_TARGET) return -EINVAL; return 0; } |