X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=net%2Fnetfilter%2Fxt_state.c;h=a776dc36a19343ae678cf192baa7ae680c4e1478;hb=a8931ef380c92d121ae74ecfb03b2d63f72eea6f;hp=b8ec00cd51fc1d16b4c04c17dbbbed0e5b57af0b;hpb=d04cdb64212eb5ae6a98026a97dda626e40e8e9a;p=linux-2.6 diff --git a/net/netfilter/xt_state.c b/net/netfilter/xt_state.c index b8ec00cd51..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,15 +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 struct xt_match *match, - 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; @@ -36,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); @@ -44,42 +40,54 @@ match(const struct sk_buff *skb, return (sinfo->statemask & statebit); } -static struct xt_match state_match = { - .name = "state", - .match = match, - .matchsize = sizeof(struct xt_state_info), - .me = THIS_MODULE, -}; - -static struct xt_match state6_match = { - .name = "state", - .match = match, - .matchsize = sizeof(struct xt_state_info), - .me = THIS_MODULE, -}; - -static int __init init(void) +static bool +state_mt_check(const char *tablename, const void *inf, + const struct xt_match *match, void *matchinfo, + unsigned int hook_mask) { - int ret; - - need_conntrack(); + 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; +} - ret = xt_register_match(AF_INET, &state_match); - if (ret < 0) - return ret; +static void state_mt_destroy(const struct xt_match *match, void *matchinfo) +{ + nf_ct_l3proto_module_put(match->family); +} - ret = xt_register_match(AF_INET6, &state6_match); - if (ret < 0) - xt_unregister_match(AF_INET,&state_match); +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, + }, +}; - return ret; +static int __init state_mt_init(void) +{ + 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);