免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2534 | 回复: 6
打印 上一主题 下一主题

[网络子系统] HOOK函数的调用过程求解! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-05-05 23:32 |只看该作者 |倒序浏览
HOOK函数的调用过程应该是:
#define NF_HOOK--->#define NF_HOOK_THRESH--->nf_hook_thresh--->nf_hook_slow--->nf_iterate--->elem->hook ---->ipt_hook---->ipt_do_table

我一直没搞清楚的是:nf_iterate中的elem->hook怎么跳转到函数ipt_hook ? 求大神!谢谢!

下附nf_iterate()代码:

unsigned int nf_iterate(struct list_head *head,
                        struct sk_buff **skb,
                        int hook,
                        const struct net_device *indev,
                        const struct net_device *outdev,
                        struct list_head **i,
                        int (*okfn)(struct sk_buff *),
                        int hook_thresh)
{
        unsigned int verdict;

        /*
         * The caller must not block between calls to this
         * function because of risk of continuing from deleted element.
         */
        list_for_each_continue_rcu(*i, head) {
                struct nf_hook_ops *elem = (struct nf_hook_ops *)*i;

                if (hook_thresh > elem->priority)
                        continue;

                /* Optimization: we don't need to hold module
                   reference here, since function can't sleep. --RR */
                verdict = elem->hook(hook, skb, indev, outdev, okfn);
                if (verdict != NF_ACCEPT) {
#ifdef CONFIG_NETFILTER_DEBUG
                        if (unlikely((verdict & NF_VERDICT_MASK)
                                                        > NF_MAX_VERDICT)) {
                                NFDEBUG("Evil return from %p(%u).\n",
                                        elem->hook, hook);
                                continue;
                        }
#endif
                        if (verdict != NF_REPEAT)
                                return verdict;
                        *i = (*i)->prev;
                }
        }
        return NF_ACCEPT;
}

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:13:29
2 [报告]
发表于 2015-05-06 22:15 |只看该作者
可以看一下net/ipv4/netfilter/iptable_filter.c中的init函数

static int __init iptable_filter_init(void)
{
        int ret;

        ret = register_pernet_subsys(&iptable_filter_net_ops);
        if (ret < 0)
                return ret;

        /* Register hooks */
        filter_ops = xt_hook_link(&packet_filter, iptable_filter_hook);
/*filter_ops应该就是elem,iptables_filter_hook就是你上面说ipt_hook,elem的hook就是iptables_filter_hook,在iptables_filter_hook中会返回ipt_do_table*/

        if (IS_ERR(filter_ops)) {
                ret = PTR_ERR(filter_ops);
                unregister_pernet_subsys(&iptable_filter_net_ops);
        }

        return ret;
}

论坛徽章:
0
3 [报告]
发表于 2015-05-06 23:29 |只看该作者
多谢!我学习下看!回复 2# philarlala


   

论坛徽章:
0
4 [报告]
发表于 2015-05-07 00:19 |只看该作者
请问下,我的iptable_filter的init函数怎么和你的不一样?我用的内核是2.6.20的!

static int __init iptable_filter_init(void)
{
        int ret;

        if (forward < 0 || forward > NF_MAX_VERDICT) {
                printk("iptables forward must be 0 or 1\n");
                return -EINVAL;
        }

        /* Entry 1 is the FORWARD hook */
        initial_table.entries[1].target.verdict = -forward - 1;

        /* Register table */
        ret = ipt_register_table(&packet_filter, &initial_table.repl);
        if (ret < 0)
                return ret;

        /* Register hooks */
        ret = nf_register_hooks(ipt_ops, ARRAY_SIZE(ipt_ops));
        if (ret < 0)
                goto cleanup_table;

        return ret;

cleanup_table:
        ipt_unregister_table(&packet_filter);
        return ret;
}
回复 2# philarlala


   

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:13:29
5 [报告]
发表于 2015-05-07 08:40 |只看该作者
内核版本不一样,我的是3.14的,这个应该不影响理解xt_hook_link中封装的就是nf_register_hooks回复 4# cvgcv


   

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
6 [报告]
发表于 2015-05-07 09:29 |只看该作者
楼上说的对,不管内核版本的细节怎么调整,基本关系是不变的:
*   nf_iterater: 遍历链表中的回调函数(netfilter hooks);
*   nf_registers_hook:在链表中添加回调函数

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
7 [报告]
发表于 2015-05-07 14:42 |只看该作者
回复 1# cvgcv

内核中大量使用register 的机制,一个函数指针,指向一个 hook 或者 handler 之类的。HOOK 就是如此。

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP