aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorPatrick McHardy <kaber@trash.net>2011-02-02 17:50:01 -0500
committerPatrick McHardy <kaber@trash.net>2011-02-02 17:50:01 -0500
commit724bab476bcac9f7d0b5204cb06e346216d42166 (patch)
treeac4aa027d85a801ca2e3eb75678124434e1ba30d /net
parent316ed388802533bcfd3dffb38d2ba29ac5428456 (diff)
netfilter: ipset: fix linking with CONFIG_IPV6=n
Add a dummy ip_set_get_ip6_port function that unconditionally returns false for CONFIG_IPV6=n and convert the real function to ipv6_skip_exthdr() to avoid pulling in the ip6_tables module when loading ipset. Signed-off-by: Patrick McHardy <kaber@trash.net>
Diffstat (limited to 'net')
-rw-r--r--net/netfilter/ipset/ip_set_getport.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/net/netfilter/ipset/ip_set_getport.c b/net/netfilter/ipset/ip_set_getport.c
index 4dd2785a5c72..8d5227212686 100644
--- a/net/netfilter/ipset/ip_set_getport.c
+++ b/net/netfilter/ipset/ip_set_getport.c
@@ -13,6 +13,7 @@
13#include <linux/icmpv6.h> 13#include <linux/icmpv6.h>
14#include <linux/netfilter_ipv6/ip6_tables.h> 14#include <linux/netfilter_ipv6/ip6_tables.h>
15#include <net/ip.h> 15#include <net/ip.h>
16#include <net/ipv6.h>
16 17
17#include <linux/netfilter/ipset/ip_set_getport.h> 18#include <linux/netfilter/ipset/ip_set_getport.h>
18 19
@@ -93,21 +94,23 @@ ip_set_get_ip4_port(const struct sk_buff *skb, bool src,
93} 94}
94EXPORT_SYMBOL_GPL(ip_set_get_ip4_port); 95EXPORT_SYMBOL_GPL(ip_set_get_ip4_port);
95 96
97#if defined(CONFIG_IP6_NF_IPTABLES) || defined(CONFIG_IP6_NF_IPTABLES_MODULE)
96bool 98bool
97ip_set_get_ip6_port(const struct sk_buff *skb, bool src, 99ip_set_get_ip6_port(const struct sk_buff *skb, bool src,
98 __be16 *port, u8 *proto) 100 __be16 *port, u8 *proto)
99{ 101{
100 unsigned int protooff = 0; 102 int protoff;
101 int protocol; 103 u8 nexthdr;
102 unsigned short fragoff;
103 104
104 protocol = ipv6_find_hdr(skb, &protooff, -1, &fragoff); 105 nexthdr = ipv6_hdr(skb)->nexthdr;
105 if (protocol <= 0 || fragoff) 106 protoff = ipv6_skip_exthdr(skb, sizeof(struct ipv6hdr), &nexthdr);
107 if (protoff < 0)
106 return false; 108 return false;
107 109
108 return get_port(skb, protocol, protooff, src, port, proto); 110 return get_port(skb, nexthdr, protoff, src, port, proto);
109} 111}
110EXPORT_SYMBOL_GPL(ip_set_get_ip6_port); 112EXPORT_SYMBOL_GPL(ip_set_get_ip6_port);
113#endif
111 114
112bool 115bool
113ip_set_get_ip_port(const struct sk_buff *skb, u8 pf, bool src, __be16 *port) 116ip_set_get_ip_port(const struct sk_buff *skb, u8 pf, bool src, __be16 *port)