内核中网络上/下的问题

时间:2015-03-09 21:11:47

标签: kernel linux-kernel

我正在尝试用正确的命令编写一个Linux内核模块,将网络接口(假设wlan0)更改为指定的IP地址,然后重新启动接口。在评论开始之前,是的,我知道你可以使用ifconfig,是的我知道你也可以编写用户代码来执行此操作,但是对于我的研究项目,我正在尝试学习如何在Linux内核中执行此操作。

在研究之后,我找到了net_device _ops结构,其中包含我需要为此调用的方法(ndo_stopndo_open)。但是我很难找到用法示例,因此尝试了:

dev->netdev_ops->ndo_stop(dev);

编译得很好,但是当模块运行时,设备没有被关闭。

任何人都可以提供正确的使用示例或让我知道我做错了什么吗?

void targeted(int index, __u32 key){
    unsigned short cur_if;
    struct in_device *in_dev;
    struct in_ifaddr *if_info;
    struct net_device *dev;
    //struct net_device_ops ops;
    __be32 n_key;
    __u32 test2;
    test2 = 0x00FFFFFF;
    //test2 = test2 | key;
    n_key = cpu_to_be32(key);
    cur_if = 0;
    dev = first_net_device(&init_net);
    while (dev && cur_if < IFMAX) {
        in_dev = (struct in_device *)dev->ip_ptr;
        for (if_info = in_dev->ifa_list; if_info != NULL; if_info=if_info->ifa_next){
            if (cur_if == index){
                dev->netdev_ops->ndo_stop(dev);
                if_info->ifa_address = if_info->ifa_address & test2;
                if_info->ifa_local = if_info->ifa_local & test2;
                if_info->ifa_address = if_info->ifa_address | n_key;
                if_info->ifa_local = if_info->ifa_local | n_key;
                printk(KERN_DEBUG "New Test::: %pI4", &if_info->ifa_local);
                //dev->netdev_ops->ndo_open(dev);
            }   
        }
        cur_if++;
        dev = next_net_device(dev);
    }
    return;
}

1 个答案:

答案 0 :(得分:0)

这类似于我正在尝试的,实际上我尝试实现某种隐身模式,应该这样做(root是先决条件)。但它不是通过内核模块完成的。我仍然试着帮忙。我的步骤应该在这里执行:

  1. 停止所有REAL(无环回等)网络设备

  2. 收集他们的广告

  3. 将他们的Mac更改为唯一的随机

  4. 收集旧主机名并将主机名更改为唯一随机

  5. 重新激活网站

  6. 设置一些iptables,

  7. 所有这些作为守护进程,等待特殊的keycomobo撤消所有更改。

  8. 让我们回答一下,或者某种方式: 问题是,你肯定会运行一些应用程序,它们可以通过udev或其他方式控制你的nics。我的例子是WICD-daemon,它正在运行,当我关闭我的代码中的nic时,它立即被wicd(IIRC)打开。 我在谷歌搜索并找到了一些关于卸载驱动程序的信息.....但这也意味着,我们不能再改变mac或ip了。 所以在内核中我们需要识别哪个userland-process占用了nic。 杀死这些进程可能很方便。 顺便说一句,您可以使用上面提到的命令,并提供ptrace,然后您将看到,涉及哪些系统调用。