1

我正在尝试创建一个字符设备驱动程序(内核模块)。模块被加载,创建字符设备,如下所示:

    root@imx6x-std:~# ls -l /dev/socledchrdevregion
crw-rw-rw-    1 root     root      246,   0 Jan  1 08:56 /dev/socledchrdevregion

但是当我尝试使用测试应用程序打开设备时(驱动程序中的 open 函数除了打印调试消息之外没有做任何特别的事情),我得到一个错误:

root@imx6x-std:~# ./led_ioctltest
led_ioctltest: open /dev/socledchrdevregion failed due to No such device or addres

以下是 /proc/devices 的内容:

    root@imx6x-std:~# cat /proc/devices
Character devices:
  1 mem
  5 /dev/tty
  5 /dev/console
  5 /dev/ptmx
 10 misc
 13 input
 29 fb
 81 video4linux
 89 i2c
 90 mtd
116 alsa
128 ptm
136 pts
153 spi
180 usb
189 usb_device
199 galcore
207 ttymxc
244 vuc_sim
245 vuc
246 socledchrdevregion
247 ubi0
248 mxc_src
249 mxc_vpu
250 conti_kmod_tracing
251 mxc_ipu
252 ptp
253 pps
254 rtc

Block devices:
259 blkext
 31 mtdblock
179 mmc

该设备存在,主要编号为 246。

这是我尝试打开设备的方式:

 #define DEVICE "/dev/socledchrdevregion"
fd = open(DEVICE, O_RDONLY);

这是 LKM 的一个片段:

if ((ret = alloc_chrdev_region(&first, 0, 1, DEVICE_NAME)) < 0)
{
        printk(KERN_ERR PRINTK_CONTEXT": FAILED TO ALLOCATE CHRDEVREGION \n");
        return -1;
}

printk(KERN_INFO PRINTK_CONTEXT": ALLOCATE CHRDEVREGION SUCCESS \n");

classptr = class_create(THIS_MODULE, "socledclass");
device_create(classptr, NULL, first, NULL, DEVICE_NAME);
printk(KERN_INFO "PRINTK_CONTEXT: DEVICE CREATED \n");
led_cdevptr = cdev_alloc();
led_cdevptr->ops = &led_fops;

谁能帮我找出错误?如有必要,我将发布完整的代码。

4

1 回答 1

4

您已经使用 sysfs 注册了您的设备,这会导致它变得可见(并让 udev 创建设备文件)。但是,您没有注册实际设备。您分配了一个主要的未成年人,但他们没有连接到您的司机。

您很可能已经跳过 call cdev_add

简而言之,顺序是: alloc_chrdev_region为您提供一系列您可以使用的主要/次要设备 ID,这些 ID 保证仅适用于您的设备。

cdev_addalloc_chrdev_region为这些 ID 注册实际的处理程序(如果您的设备设置了预分配的区域,例如 /dev/null 或 /dev/random,则可以在不调用的情况下调用它)。

于 2016-10-15T13:44:38.640 回答