Netfilter笔记-03

本文探讨了Netfilter框架在内核中的工作原理。当硬件接收到帧并通知CPU后,内核通过do_IRQ处理中断事件,将帧复制到sk_buff。接着,IP数据包接收流程启动,调用ip_rcv函数,进一步触发NF_HOOK。在nf_hook_slow函数中,通过nf_iterate调用钩子函数,最终执行nf_hook_ops中的hook_func,如ip_rcv_finish,对数据包进行接收或丢弃操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当我们使用nf_register_hook在内核中注册好hook之后,内核是如何来引用的呢?

当设备的硬件接收帧以后,会使用中断事件通知CPU,该帧已经可用了,CPU接收到终端事件之后,会执行do_IRQ函数,IRQ编号会引发正确的处理函数被启用,在该过程中,内核会把帧拷贝到sk_buff数据结构中进行处理。按照IP数据包接收流程

内核会调用ip_rcv函数,此函数内会调用NF_HOOK

 return NF_HOOK(NFPROTO_IPV4, NF_INET_PRE_ROUTING, skb, dev, NULL,ip_rcv_finish);

在NF_HOOK函数中会调用到nf_hook_slow函数,在nf_hook_slow函数中调用了nf_iterate,代码如下:

unsigned int nf_iterate(struct list_head *head,
                        struct sk_buff *skb,
                        unsigned int hook,
                        const struct net_device *indev,
                        const struct net_device *outdev,
                        struct nf_hook_ops **elemp,
                        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_entry_continue_rcu((*elemp), head, list) {
                if (hook_thresh > (*elemp)->priority)
                        continue;

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

如上代码中verdict = (*elemp)->hook(hook, skb, indev, outdev, okfn);会调用nf_hook_ops中的hook func。也就是NF_HOOK传过来的ip_rcv_finish。在ip_rcv_finish函数中,内核会对packet进行处理,如果内核不接受此数据包,内核会drop packet,并且free sk_buff。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值