fib6_rule_lookup调用

时间:2012-05-08 12:14:31

标签: kernel

我有一个网络模块,如果数据包的目的地不是本地或直连网络,则封装数据包。为此,我有一个功能,可以检测此数据包是否为本地数据包。此功能用于IPv4数据包,我应该复制它以对IPv6执行相同的操作。 IPv4功能的代码是:

bool is_v4addr_local(struct iphdr *iph, const struct net_device *output_dev)
{
    struct flowi fl;
    struct rtable *rt;
    struct net_device *dev;

    if(output_dev == NULL) {
          printk(KERN_DEBUG "output_dev is NULL!");
          return 0;
    }
    memset(&fl, 0, sizeof(fl));
    fl.u.ip4.daddr = iph->daddr;
    fl.flowi_tos = RTO_ONLINK; //locally connected
    rt = ip_route_output_key(dev_net(output_dev), &fl.u.ip4);
    if (IS_ERR(rt))
        return 0;
    dev = rt->dst.dev;
    ip_rt_put(rt);
    if (!dev)
        return 0;

    // If we got anything, it's local
    return 1;
}

为了适应它,我想我应该使用函数fib6_rule_lookup,但我知道如何引入函数的最后一个参数(在某些例子中,他们只放了ip6_pol_route_lookup,但它不起作用)。

你可以帮我修改这个功能吗?我是第一次在内核空间编程。

由于

bool is_v6addr_local(struct ipv6hdr *iph, const struct net_device *output_dev)
{
    struct rt6_info *rt;
    struct net_device *dev;
    struct dst_entry *dst;
    struct flowi6 fl6;


    if(output_dev == NULL) {
          printk(KERN_DEBUG "output_dev is NULL!");
          return 0;
    }

    memset(&fl6, 0, sizeof(fl6));
    fl6.flowi6_tos = RTO_ONLINK;
    fl6.daddr = iph->daddr;


    dst = fib6_rule_lookup(dev_net(output_dev), &fl6, 0, ip6_pol_route_lookup);
    if (dst->error != 0)
        return 0;
    rt = (struct rt6_info *) dst;

    dev = rt->dst.dev;
    if (!dev)
        return 0;

    // If we got anything, it's local*/
    return 1;
}

0 个答案:

没有答案