What I would do is:
- remove b_rdev completely. No driver is actually interested in what the
device number is, the only thing they want to use it for is to look up
which device index we have (and for doing the partition handling, but
as discussed in a completely independent discussion a few months ago,
we should handle that as a lvm remapping thing, NOT at the driver
level!)
- replace is with b_index
Then, the "get_queue" functions basically end up doing the mapping of
b_dev -> <queue,b_index>
and the LVM remapping would do
<queue1,b_index1> -> <queue2,b_index2>
instead of what happens now (right now we have:
/* At request creation time */
b_rdev = b_dev (equivalent to <queue,b_index> <- b_dev in get_queue)
/* at lvm remapping time */
b_rdev = mapping(b_rdev);
The current reliance on b_rdev is rather confusing, and has resulted in a
ton of bugs exactly because of that.
> You would still nee to make sure the blk_size[], blksize_size[],
> hardsect_size[], max_readahead[], max_sectors[] all got handled
> properly.
Actually, I htink Jens did most of these, and moved them into a device
array.
> Does the minor number for this "disk" layer have N bits for partition
> number and 8-N bits (later to be 20-N bits or similar) for device
> number?
I'd go with N=8, and only use this for the "new" cases, We've seen that
N=4 is too small (SCSI), and N=6 (IDE) is already too cramped with a 8-bit
minor number.
BUT! Note that when you do the partition handling in get_queue too (and
thus index is an index to the _device_ and has nothing to do with
partitions), you can trivially allow different majors to have different
numbers of partition bits, because the driver no longer cares. This is
required so that the get_queue remapping can easily handle the legacy
IDE/SCSI numbers anyway, so it's easyish to just have both at the same
time - you could have N=4 for a "disk major for old users that need the
16-bit device numbers and a single major", with N=8 for the "new style
major" which doesn't fit in 8 bits.
> Finally, how do I say that I want the root filesystem to be on a
> particular "mdp" device+partition. I cannot assume that my device
> will be the first to register with the "disk" layer, so I cannot be
> sure that "root=/dev/diska1" will work.
You have never been able to really assume that. Disks move around.
A lot of people seem to think that controller type or location on the PCI
bus should somehow have some "meaning", and that it guarantees that the
disks don't move in the namespace. That's crap. You can do that in user
space ("what controller are you on?") if you really really care.
Linus
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/