我想从Python应用程序发送IOCTL调用到我在Ubuntu 12.04中运行的假网络接口。我知道我可以打开一个套接字并将其绑定到假网络接口所控制的网络,然后使用fcntl.ioctl(socket, IOC_COMMAND_NUM, some_struct)
发送IOCTL调用。但是,这似乎使用不同的网络接口比我需要它。因此,我的问题是,如何确保使用特定的网络接口?而且,打开一个套接字只是为了发送IOCTL调用似乎很麻烦,所以有没有办法绕过这一步?下面是一些示例Python代码,其行为与上面提到的相同。
>>> sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
>>> sock.bind(("192.168.0.1",0))
>>> fcntl.ioctl(sock,IOC_COMMAND_NUM,some_struct)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IOError: [Errno 25] Inappropriate ioctl for device
# This proves that it is sending the IOCTL to a different interface because my
# interface automatically returns success for any IOCTL call.
以下是ifconfig myDummyNetInter
的输出。
myDummyNetInter0 Link encap:Ethernet HWaddr e2:44:46:d5:79:3e
inet addr:192.168.0.1 Bcast:192.168.0.255 Mask:255.255.255.0
inet6 addr: fe80::e044:46ff:fed5:793e/64 Scope:Link
UP BROADCAST RUNNING NOARP MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:24 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:0 (0.0 B) TX bytes:2682 (2.6 KB)
如果有帮助的话,我确实有另一个用c++编写的应用程序,使用这个网络接口,没有任何问题。(包括IOCTL调用)
谢谢,非常感谢大家的帮助。
虽然这并不一定能回答我所有的问题,但我能够找到一个解决方案。IOCTL调用与我预期的有点不同。我需要修复的第一件事是使用正确的IOCTL号码。与字符驱动程序不同,网络驱动程序只能为自定义ioctl使用一定范围(从0x89F0开始)。我要做的另一件事是把ifreq
结构体作为IOCTL调用的第三个参数。ifreq
结构体有一个ifr_name
成员,用于选择要与之交互的特定网络接口。