- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在我的 Python (2.7.3) 代码中,我尝试使用 ioctl 调用,接受一个 long int(64 位)作为参数。我在 64 位系统上,因此 64 位 int 与指针的大小相同。
我的问题是 Python 似乎不接受 64 位 int 作为 fcntl.ioctl() 调用的参数。 它很乐意接受 32 位 int 或 64-位指针 - 但我需要传递一个 64 位整数。
这是我的 ioctl 处理程序:
static long trivial_driver_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
{
long err = 0;
switch (cmd)
{
case 1234:
printk("=== (%u) Driver got arg %lx; arg<<32 is %lx\n", cmd, arg, arg<<32);
break;
case 5678:
printk("=== (%u) Driver got arg %lx\n", cmd, arg);
break;
default:
printk("=== OH NOES!!! %u %lu\n", cmd, arg);
err = -EINVAL;
}
return err;
}
在现有的 C 代码中,我使用这样的调用:
static int trivial_ioctl_test(){
int ret;
int fd = open(DEV_NAME, O_RDWR);
unsigned long arg = 0xffff;
ret = ioctl(fd, 1234, arg); // ===(1234) Driver got arg ffff; arg<<32 is ffff00000000
arg = arg<<32;
ret = ioctl(fd, 5678, arg); // === (5678) Driver got arg ffff00000000
close(fd);
}
在 python 中,我打开设备文件,然后得到以下结果:
>>> from fcntl import ioctl
>>> import os
>>> fd = os.open (DEV_NAME, os.O_RDWR, 0666)
>>> ioctl(fd, 1234, 0xffff)
0
>>> arg = 0xffff<<32
>>> # Kernel log: === (1234) Driver got arg ffff; arg<<32 is ffff00000000
>>> # This demonstrates that ioctl() happily accepts a 32-bit int as an argument.
>>> import struct
>>> ioctl(fd, 5678, struct.pack("L",arg))
'\x00\x00\x00\x00\xff\xff\x00\x00'
>>> # Kernel log: === (5678) Driver got arg 7fff9eb1fcb0
>>> # This demonstrates that ioctl() happily accepts a 64-bit pointer as an argument.
>>> ioctl(fd, 5678, arg)
Traceback (most recent call last):
File "<pyshell#10>", line 1, in <module>
ioctl(fd, 5678, arg)
OverflowError: signed integer is greater than maximum
>>> # Kernel log: (no change - OverflowError is within python)
>>> # Oh no! Can't pass a 64-bit int!
>>>
Python 有什么方法可以将我的 64 位参数传递给 ioctl() 吗?
最佳答案
使用 Python 的 fcntl.ioctl()
是否可行将取决于系统。追溯源码,错误信息来自以下测试 line 658 of getargs.c
...
else if (ival > INT_MAX) {
PyErr_SetString(PyExc_OverflowError,
"signed integer is greater than maximum");
RETURN_ERR_OCCURRED;
}
...在我的系统上,/usr/include/limits.h
告诉我...
# define INT_MAX 2147483647
...这是(大概)(2 ** ((sizeof(int) * 8) - 1)) - 1
。
因此,除非您在 sizeof(int)
至少为 8
的系统上工作,否则您必须直接使用ctypes
模块,但它是特定于平台的。
假设是 Linux,这样的东西应该可以工作...
from ctypes import *
libc = CDLL('libc.so.6')
fd = os.open (DEV_NAME, os.O_RDWR, 0666)
value = c_uint64(0xffff<<32)
libc.ioctl(fd, 5678, value)
关于python - fcntl.ioctl() 的 64 位参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17210650/
跟踪一个oracle进程,发现它首先打开一个文件/etc/netconfig作为文件句柄11,然后复制它作为256 通过使用参数 F_DUPFD 调用 fcntl,然后关闭 原始文件句柄 11。后来它
我读过有关套接字、连接、fcntl、缓冲区等的内容。但我不知道套接字和 fcntl 函数之间的联系是什么。我只知道socket是用来建立连接的,fcntl是用来控制打开文件的。我不知道fcntl是如何
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我有一个小程序,它在打开后无法更改文件访问模式。 int main(int argc, char* argv[]) { int fd; char *filename = argv[1]
我正在编写一个应用程序,它在我需要锁定的规范中每次我在上面写一个文件(这个文件将被其他应用程序读取其他团队正在研究): 我实现了以下功能: int lock_file (int fd) { i
我正在调试一些代码,并且总是有 l_pid = 0 用于设置文件锁。我觉得这很奇怪。这是正确的吗?文档没有说 0 零值 .. 最佳答案 l_pid只有在用F_GETLK获取锁状态时才有意义;设置锁时,
是否可以在文件上使用 fcntl() 系统调用来实现线程/进程同步(而不是信号量)? 最佳答案 是的。 Unix fcntl 锁(和一般的文件系统资源)是系统范围的,因此任何两个执行线程(无论它们是否
是否可以在 main() 以外的函数中使用 fcntl() ?调用后文件是否解锁?我这样说是因为在这种情况下 fcntl() 和 lockfile() 中的大部分其他内容在函数 返回 时都超出范围。
如何使用 fcntl 取消设置已设置的标志? 例如我可以使用 将套接字设置为非阻塞模式 fcntl(sockfd, F_SETFL, flags | O_NONBLOCK) 现在,我想取消设置 O_N
在基于 Debian 的操作系统(Ubuntu、Debian Squeeze)上,我使用 Python(2.7、3.2)fcntl 来锁定文件。据我了解,fnctl.flock 以某种方式锁定文件,如
我有一个简单的脚本,它遍历文件夹中的文件,然后将它们从 flv 转换为 mp4。如何在 bash 中跳过文件夹中具有 的文件fcntl 锁定它们,然后在解除锁定时返回? #!/bin/bash for
我正在尝试使用 IronPython 2.7 在 .NET 4.0 上使用 IronPython 执行此方法。我正在使用 Windows 7 import os import re import nl
我编写了一个简单的程序来帮助我测试 fcntl 文件锁定。参数“set”锁定我的测试文件。参数“get”告诉我文件是否被锁定。参数“un”尝试解锁文件。 在一个 shell 中,我运行程序来锁定文件。
我正在使用一个不运行 unix/linux/windows 或任何熟悉的操作系统的系统。然而,有一些套接字库,其中之一是socket.h。问题是那里有setsockopt函数和一些选项,但没有fcnt
我想通过系统调用fcntl来预分配存储。这是我执行此操作的代码: fstore_t store = {F_ALLOCATECONTIG, F_PEOFPOSMODE, 0, length, 0}; i
{net04:~/xxxx/wip} gcc -o write_test write_test.c In file included from write_test.c:4: global.h:10
// Wait until data can be read without blocking. size_t read_some(implementation_type& impl,
有什么方法可以从没有锁定这些范围的进程中删除文件上的 fcntl 字节范围锁? 我有几个对文件进行字节范围锁定的进程。我基本上需要想出的是一个外部工具,它可以帮助我删除指定文件的字节范围锁。 最佳答案
通过网络从磁盘读取和写入文件以获得最佳速度时,正确的 fcntl 标志是什么? 也许问题出在文件描述符上设置的 fcntl 标志? 最佳答案 我认为 fcntl 不会为您提供任何会影响性能的东西。也许
我目前正在尝试通过 python 锁定一个文件,这样其他进程甚至无法读取它。 到目前为止,我正在通过 python 解释器测试 fcntl.lockf() 的行为: >>> file = open("
我是一名优秀的程序员,十分优秀!