X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=net%2Fnetfilter%2Fxt_state.c;h=a776dc36a19343ae678cf192baa7ae680c4e1478;hb=a8931ef380c92d121ae74ecfb03b2d63f72eea6f;hp=39ce808d40ef7b834daeb598e3a9935d23e55f12;hpb=21e2379b9ef705fcb3ba3be738decd3397fc30b7;p=linux-2.6 diff --git a/net/netfilter/xt_state.c b/net/netfilter/xt_state.c index 39ce808d40..a776dc36a1 100644 --- a/net/netfilter/xt_state.c +++ b/net/netfilter/xt_state.c @@ -10,7 +10,7 @@ #include #include -#include +#include #include #include @@ -20,14 +20,11 @@ MODULE_DESCRIPTION("ip[6]_tables connection tracking state match module"); MODULE_ALIAS("ipt_state"); MODULE_ALIAS("ip6t_state"); -static int -match(const struct sk_buff *skb, - const struct net_device *in, - const struct net_device *out, - const void *matchinfo, - int offset, - unsigned int protoff, - int *hotdrop) +static bool +state_mt(const struct sk_buff *skb, const struct net_device *in, + const struct net_device *out, const struct xt_match *match, + const void *matchinfo, int offset, unsigned int protoff, + bool *hotdrop) { const struct xt_state_info *sinfo = matchinfo; enum ip_conntrack_info ctinfo; @@ -35,7 +32,7 @@ match(const struct sk_buff *skb, if (nf_ct_is_untracked(skb)) statebit = XT_STATE_UNTRACKED; - else if (!nf_ct_get_ctinfo(skb, &ctinfo)) + else if (!nf_ct_get(skb, &ctinfo)) statebit = XT_STATE_INVALID; else statebit = XT_STATE_BIT(ctinfo); @@ -43,54 +40,54 @@ match(const struct sk_buff *skb, return (sinfo->statemask & statebit); } -static int check(const char *tablename, - const void *ip, - void *matchinfo, - unsigned int matchsize, - unsigned int hook_mask) +static bool +state_mt_check(const char *tablename, const void *inf, + const struct xt_match *match, void *matchinfo, + unsigned int hook_mask) { - if (matchsize != XT_ALIGN(sizeof(struct xt_state_info))) - return 0; - - return 1; + if (nf_ct_l3proto_try_module_get(match->family) < 0) { + printk(KERN_WARNING "can't load conntrack support for " + "proto=%u\n", match->family); + return false; + } + return true; } -static struct xt_match state_match = { - .name = "state", - .match = &match, - .checkentry = &check, - .me = THIS_MODULE, -}; +static void state_mt_destroy(const struct xt_match *match, void *matchinfo) +{ + nf_ct_l3proto_module_put(match->family); +} -static struct xt_match state6_match = { - .name = "state", - .match = &match, - .checkentry = &check, - .me = THIS_MODULE, +static struct xt_match state_mt_reg[] __read_mostly = { + { + .name = "state", + .family = AF_INET, + .checkentry = state_mt_check, + .match = state_mt, + .destroy = state_mt_destroy, + .matchsize = sizeof(struct xt_state_info), + .me = THIS_MODULE, + }, + { + .name = "state", + .family = AF_INET6, + .checkentry = state_mt_check, + .match = state_mt, + .destroy = state_mt_destroy, + .matchsize = sizeof(struct xt_state_info), + .me = THIS_MODULE, + }, }; -static int __init init(void) +static int __init state_mt_init(void) { - int ret; - - need_conntrack(); - - ret = xt_register_match(AF_INET, &state_match); - if (ret < 0) - return ret; - - ret = xt_register_match(AF_INET6, &state6_match); - if (ret < 0) - xt_unregister_match(AF_INET,&state_match); - - return ret; + return xt_register_matches(state_mt_reg, ARRAY_SIZE(state_mt_reg)); } -static void __exit fini(void) +static void __exit state_mt_exit(void) { - xt_unregister_match(AF_INET, &state_match); - xt_unregister_match(AF_INET6, &state6_match); + xt_unregister_matches(state_mt_reg, ARRAY_SIZE(state_mt_reg)); } -module_init(init); -module_exit(fini); +module_init(state_mt_init); +module_exit(state_mt_exit);