我正在尝试用正确的命令编写一个Linux内核模块,将网络接口(假设wlan0)更改为指定的IP地址,然后重新启动接口。在评论开始之前,是的,我知道你可以使用ifconfig,是的我知道你也可以编写用户代码来执行此操作,但是对于我的研究项目,我正在尝试学习如何在Linux内核中执行此操作。
在研究之后,我找到了net_device
_ops结构,其中包含我需要为此调用的方法(ndo_stop
和ndo_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;
}
答案 0 :(得分:0)
这类似于我正在尝试的,实际上我尝试实现某种隐身模式,应该这样做(root是先决条件)。但它不是通过内核模块完成的。我仍然试着帮忙。我的步骤应该在这里执行:
停止所有REAL(无环回等)网络设备
收集他们的广告
将他们的Mac更改为唯一的随机
收集旧主机名并将主机名更改为唯一随机
重新激活网站
设置一些iptables,
所有这些作为守护进程,等待特殊的keycomobo撤消所有更改。
让我们回答一下,或者某种方式: 问题是,你肯定会运行一些应用程序,它们可以通过udev或其他方式控制你的nics。我的例子是WICD-daemon,它正在运行,当我关闭我的代码中的nic时,它立即被wicd(IIRC)打开。 我在谷歌搜索并找到了一些关于卸载驱动程序的信息.....但这也意味着,我们不能再改变mac或ip了。 所以在内核中我们需要识别哪个userland-process占用了nic。 杀死这些进程可能很方便。 顺便说一句,您可以使用上面提到的命令,并提供ptrace,然后您将看到,涉及哪些系统调用。