实际上正在开发 PCI 驱动程序。 我有两个具有相同设备 ID 和供应商 ID 的 PCIe 卡。 因此,为了有所不同,我为这两张卡分配了两个不同的 MINOR 编号。
//request for device numbers
error = alloc_chrdev_region(&devt, 0, cards_found, DEVICE_NAME);
if (error == 0)
{
major = MAJOR(devt);
printk(KERN_INFO "(drv_init): MAJOR number is %d\n", major);
printk(KERN_INFO "(drv_init): MINOR number range from 0 to %d\n", cards_found-1);
cdevs = cdev_alloc();
cdevs->owner = THIS_MODULE;
cdev_init(cdevs, fops);
for(i=0;i<cards_found,i++)
{
devt = MKDEV(major, i);
error = cdev_add(cdevs, devt, 1);
if (error == 0)
{
printk(KERN_INFO "(drv_init): cdev_add success for minor number: %d", i);
}
else
{
printk(KERN_ALERT "(drv_init): cdev_add failed for minor number: %d,error code: %d, exit driver\n", i, error);
devt = MKDEV(major, 0);
unregister_chrdev_region(devt, cards_found);
pci_unregister_driver(&my_pci_driver);
return(error);
}
}
} `
我这样做是因为我在互联网上找到的所有文档都建议一台设备使用一个次号。
但是我不明白当我执行 fops_open 时操作系统如何知道哪张卡是目标,因为 fops 绑定(bind)到所有设备。
需要您的帮助,谢谢大家。
PS:fops = 文件操作
最佳答案
.open
操作的签名是
int open(struct inode* inode, struct file* file)
可以通过以下方式获取打开的设备的次要数量
iminor(inode)
其他文件操作也可以使用file->f_inode
作为inode来获取设备号。
或者,.open
可以在 file->f_private
中存储一些特定于设备的数据,其他操作可以通过这种方式访问它们。
关于linux-kernel - cdev 及其关联的文件操作如何工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36066635/