Как работает cdev и связанная с ним файловая операция?
На самом деле работает над драйвером PCI. У меня есть две карты 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 связан со всеми устройствами.
Нужна ваша помощь, спасибо всем.
PS: fops = файловые операции
1 ответ
Подпись .open
операция
int open(struct inode* inode, struct file* file)
Незначительный номер открытого устройства можно получить через
iminor(inode)
Другие файловые операции также могут получить номер устройства, используя file->f_inode
как инод.
С другой стороны, .open
может хранить некоторые специфичные для устройства данные в file->f_private
и другие операции могут получить к ним доступ таким образом.