Hi Jens, this series cleans up our main per-device node data structure by merging the block_device and hd_struct data structures that have the same scope, but different life times. The main effect (besides removing lots of code) is that instead of having two device sizes that need complex synchronization there is just one now. Note that this now includes the previous "misc cleanups" series as I had to fix up a thing in there with the changed patch ordering. The first patch already is in 5.10-rc, but not in for-5.11/block A git tree is available here: git://git.infradead.org/users/hch/block.git bdev-lookup Gitweb: http://git.infradead.org/users/hch/block.git/shortlog/refs/heads/bdev-lookup Changes since v1: - spelling fixes - fix error unwinding in __alloc_disk_node - use bdev_is_partition in a few more places - don't send the RESIZE=1 uevent for hidden gendisks - rename __bdget_disk to disk_find_part - drop a bcache patch - some patch reordering - add more refactoring - use rcu protection to prevent racing with a disk going away in blkdev_get - split up some of the big patches into many small ones - clean up the freeze_bdev interface Diffstat: block/bio.c | 6 block/blk-cgroup.c | 50 - block/blk-core.c | 68 +- block/blk-flush.c | 2 block/blk-iocost.c | 36 - block/blk-lib.c | 2 block/blk-merge.c | 2 block/blk-mq.c | 9 block/blk-mq.h | 7 block/blk.h | 84 --- block/genhd.c | 467 ++++------------- block/ioctl.c | 14 block/partitions/core.c | 252 +++------ drivers/block/drbd/drbd_receiver.c | 2 drivers/block/drbd/drbd_worker.c | 3 drivers/block/loop.c | 24 drivers/block/mtip32xx/mtip32xx.c | 15 drivers/block/mtip32xx/mtip32xx.h | 2 drivers/block/nbd.c | 6 drivers/block/xen-blkback/common.h | 4 drivers/block/xen-blkfront.c | 20 drivers/block/zram/zram_drv.c | 87 --- drivers/block/zram/zram_drv.h | 1 drivers/md/bcache/request.c | 4 drivers/md/bcache/super.c | 29 - drivers/md/dm-core.h | 7 drivers/md/dm-table.c | 9 drivers/md/dm.c | 45 - drivers/md/md.c | 8 drivers/mtd/mtdsuper.c | 17 drivers/nvme/target/admin-cmd.c | 20 drivers/s390/block/dasd.c | 8 drivers/s390/block/dasd_ioctl.c | 9 drivers/scsi/scsicam.c | 2 drivers/target/target_core_file.c | 6 drivers/target/target_core_pscsi.c | 7 drivers/usb/gadget/function/storage_common.c | 8 fs/block_dev.c | 730 +++++++++------------------ fs/btrfs/sysfs.c | 15 fs/btrfs/volumes.c | 13 fs/buffer.c | 2 fs/ext4/ioctl.c | 2 fs/ext4/super.c | 18 fs/ext4/sysfs.c | 10 fs/f2fs/checkpoint.c | 5 fs/f2fs/f2fs.h | 2 fs/f2fs/file.c | 14 fs/f2fs/super.c | 8 fs/f2fs/sysfs.c | 9 fs/inode.c | 3 fs/internal.h | 7 fs/io_uring.c | 10 fs/pipe.c | 5 fs/pstore/blk.c | 2 fs/quota/quota.c | 40 + fs/statfs.c | 2 fs/super.c | 86 --- fs/xfs/xfs_fsops.c | 7 include/linux/blk-cgroup.h | 4 include/linux/blk_types.h | 24 include/linux/blkdev.h | 27 include/linux/fs.h | 5 include/linux/genhd.h | 110 ---- include/linux/part_stat.h | 45 - init/do_mounts.c | 271 ++++------ kernel/trace/blktrace.c | 54 - mm/filemap.c | 13 67 files changed, 957 insertions(+), 1928 deletions(-)