cdev_init and struct file_operations

Valdis.Kletnieks at vt.edu Valdis.Kletnieks at vt.edu
Tue Aug 26 21:18:57 EDT 2014


On Tue, 26 Aug 2014 20:48:41 -0400, John de la Garza said:
> In the book Linux Device Drivers a struct cdev is setup like this:
>
> static void scull_setup_cdev(struct scull_dev *dev, int index)
> {
>     int err, devno = MKDEV(scull_major, scull_minor + index);
>
>     cdev_init(&dev->cdev, &scull_fops);
>     dev->cdev.owner = THIS_MODULE;
>     dev->cdev.ops = &scull_fops;
> ...
>
>
> the code for cdev_init does this:
> void cdev_init(struct cdev *cdev, const struct file_operations *fops)
> {
>         memset(cdev, 0, sizeof *cdev);
>         INIT_LIST_HEAD(&cdev->list);
>         kobject_init(&cdev->kobj, &ktype_cdev_default);
>         cdev->ops = fops;
> }
>
> Why does the code from ldd3 set dev->cdev.ops = &scull_fops again?

Probably because when ldd3 was written several years ago, cdev_init()
didn't set it, so it wasn't "again"....

> Doesn't cdev_init already do that?

It does *now*.

Remember that ldd3 was written about 6 million lines of code ago....
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 848 bytes
Desc: not available
Url : http://lists.kernelnewbies.org/pipermail/kernelnewbies/attachments/20140826/c1d339be/attachment.bin 


More information about the Kernelnewbies mailing list