Revert "block: remove devnode callback from struct block_device_operations"
authorJens Axboe <axboe@kernel.dk>
Wed, 4 Jan 2023 21:44:02 +0000 (14:44 -0700)
committerJens Axboe <axboe@kernel.dk>
Wed, 4 Jan 2023 21:44:02 +0000 (14:44 -0700)
This reverts commit 85d6ce58e493ac8b7122e2fbe3f41b94d6ebdc11.

We're reinstating the pktcdvd driver, which needs this API.

Signed-off-by: Jens Axboe <axboe@kernel.dk>
block/genhd.c
include/linux/blkdev.h

index 08f7613..14329dc 100644 (file)
@@ -1201,10 +1201,21 @@ struct class block_class = {
        .dev_uevent     = block_uevent,
 };
 
+static char *block_devnode(struct device *dev, umode_t *mode,
+                          kuid_t *uid, kgid_t *gid)
+{
+       struct gendisk *disk = dev_to_disk(dev);
+
+       if (disk->fops->devnode)
+               return disk->fops->devnode(disk, mode);
+       return NULL;
+}
+
 const struct device_type disk_type = {
        .name           = "disk",
        .groups         = disk_attr_groups,
        .release        = disk_release,
+       .devnode        = block_devnode,
 };
 
 #ifdef CONFIG_PROC_FS
index 301cf1c..43d4e07 100644 (file)
@@ -1395,6 +1395,7 @@ struct block_device_operations {
        void (*swap_slot_free_notify) (struct block_device *, unsigned long);
        int (*report_zones)(struct gendisk *, sector_t sector,
                        unsigned int nr_zones, report_zones_cb cb, void *data);
+       char *(*devnode)(struct gendisk *disk, umode_t *mode);
        /* returns the length of the identifier or a negative errno: */
        int (*get_unique_id)(struct gendisk *disk, u8 id[16],
                        enum blk_unique_id id_type);