- 論壇徽章:
- 0
|
本帖最后由 mxgsgtc 于 2017-03-17 16:17 編輯
static struct usb_class_driver skel_class = { .name = "skel%d",
.fops = &skel_fops,
.minor_base = USB_SKEL_MINOR_BASE,
};
在skel_probe 函數(shù)中
{
----
----
retval = usb_register_dev(interface, &skel_class);
if (retval) {
/* something prevented us from registering this driver */
err("Not able to get a minor for this device.");
usb_set_intfdata(interface, NULL);
goto error;
}
------
-----
}
我想問下關(guān)于:usb_register_dev這個(gè)函數(shù)的問題,這個(gè)函數(shù)會(huì)創(chuàng)建一個(gè)usb子設(shè)備A,并在/dev/生成節(jié)點(diǎn)
問題1: 這個(gè)子設(shè)備A是字符設(shè)備還是塊設(shè)備,如何判斷的呢?
根據(jù)我的分析
usb_register_dev-->device_add-->devtmpfs_create_node
devtmpfs_create_node函數(shù)中
{
----
nodename = device_get_devnode(dev, &mode, &tmp);
if (!nodename)
return -ENOMEM;
if (mode == 0)
mode = 0600;
if (is_blockdev(dev))
mode |= S_IFBLK;
else
mode |= S_IFCHR;//這里有個(gè)字符設(shè)備的賦值
-----
}
所以我大致判斷, usb_register_dev生成出來的是字符設(shè)備,不知道對(duì)不對(duì)
問題2:假設(shè)通過usb_register_dev生成出來的是字符設(shè)備, 但是在此函數(shù)中我并沒有找到cdev結(jié)構(gòu)的分配(字符設(shè)備都需要分配這個(gè)結(jié)構(gòu)吧),那cdev是從哪里分配的呢?
問題3:skel_class中的.fops在VFS的角度上講是如何被調(diào)用的呢?
static const struct file_operations skel_fops = {
.owner = THIS_MODULE,
.read = skel_read,
.write = skel_write,
.open = skel_open,
.release = skel_release,
.flush = skel_flush,
.llseek = noop_llseek,
};
/*
* usb class driver info in order to get a minor number from the usb core,
* and to have the device registered with the driver core
*/
static struct usb_class_driver skel_class = {
.name = "skel%d",
.fops = &skel_fops,
.minor_base = USB_SKEL_MINOR_BASE,
};
usb_register_dev(interface, &skel_class);調(diào)用后, 新生成子設(shè)備A, 但是cdev結(jié)構(gòu)并沒有被分配,既然沒有分配,就沒有在內(nèi)核全局變量cdev_map中注冊(cè)
那么open("/dev/A"); 是如何調(diào)用的skel_open呢? |
|