On Fri, Apr 29, 2016 at 12:32 PM, Douglas Anderson <dianders at chromium.org> wrote: > This series picks patches from various different places to produce what > I consider the best solution to getting consistent mmc and mmcblk > ordering. > > Why consistent ordering and why not just use UUIDs? IMHO consistent > ordering solves a few different problems: > > 1. For poor, feeble-minded humans like me, have sane numbering for > devices helps a lot. When grepping through dmesg it's terribly handy > if a given SDMMC device has a consistent number. I know that I can > do "dmesg | grep mmc0" or "dmesg | grep mmcblk0" to find info about > the eMMC. I know that I can do "dmesg | grep mmc1" to find info > about the SD card slot. I don't want it to matter which one probed > first, I don't want it to matter if I'm working on a variant of the > hardware that has the SD card slot disabled, and I don't want to care > what my boot device was. Worrying about what device number I got > increases my cognitive load. > > 2. There are cases where it's not trivially easy during development to > use the UUID. Specifically I work a lot with coreboot / depthcharge > as a BIOS. When configured properly, that BIOS has a nice feature to > allow you to fetch the kernel and kernel command line from TFTP by > pressing Ctrl-N. In this particular case the BIOS doesn't actually > know which disk I'd like for my root filesystem, so it's not so easy > for it to put the right UUID into the command line. For this > purpose, knowing that "mmcblk0" will always refer to eMMC is handy. Why don't you use labels? This works whether your rootfs is on /dev/vdXy, /dev/sdXy or /dev/mmcblkXpy. I can feel your pain as I've been looking at the per device crap that is Android fstab files which labels solve beautifully and worked without Android changes. Sorry, I'm not keen to add something that is both MMC and DT specific. If consistent numbering for devices is a goal in the kernel, then I'd feel otherwise. But I'm pretty sure that is a non-goal. Aliases were largely intended for backwards compatibility in cases where the numbering was already consistent (IOW consoles). Rob