On Mon, Sep 17, 2012 at 04:00:34PM +0800, Dave Young wrote: > > ismounted handles both find-by-dev and find-by-mnt, but there's two issues: > 1. for find-by-dev, it use readlink to get the canonical dev name, but > lvm is different with other devices, lvm use the symlinks in /proc/mounts > without converting to canonical name. Well, dm-N are private DM names and should not be used anywhere in userspace. The official device name is /dev/mapper/<name> where the <name> is exported by /sys/block/dm-<N>/dm/name. You need something like: cn_device=$(cat /sys/block/${device##/dev/}/dm/name) > 2. for nfs mounting, just use [ -b $dev ] is not enough, it need being handled > seperately. > > grep all current ismounted() user, they are all ismounted <mntdir>, so change > to split the ismounted <dev> to another function dev_ismounted. Afterwards > ismounted() should be converted to dir_ismounted. > > in dev_ismounted, fix the dev name issue by using maj:min to comparing with > items in /proc/self/mountinfo. OTOH for nfs share just compare with the 1st > field of /proc/mounts. Do you know about findmnt(1)? It's smaller than stat(1) and provides all necessary functionality ;-) > -find_mount() { > - local dev mnt etc wanted_dev > - wanted_dev="$(readlink -e -q $1)" > +# get_maj_min <device> > +# Prints the major and minor of a device node. > +# Example: > +# $ get_maj_min /dev/sda2 > +# 8:2 > +get_maj_min() { > + local _dev > + _dev=$(stat -L -c '$((0x%t)):$((0x%T))' "$1" 2>/dev/null) > + _dev=$(eval "echo $_dev") > + echo $_dev > +} > + > +find_mount_point() { > + local _x majmin mnt wanted_majmin > + wanted_majmin="$(get_maj_min $1)" > + while read _x _x majmin _x mnt _x; do > + [ "$majmin" = "$wanted_majmin" ] && echo "$mnt" && return 0 You should not expect that devno returned by stat(1) matches with devno in /proc/self/mountinfo. For example btrfs uses some pseudo-devnos (don't forget that btrfs is not strictly per-device filesystem): # ls -la /dev/sdb brw-rw---- 1 root disk 8, 16 Sep 17 10:24 /dev/sdb ^^^^^ # grep /dev/sdb /proc/self/mountinfo 56 21 0:44 / /mnt/test rw,relatime - btrfs /dev/sdb rw,ssd,nospace_cache ^^^^ It's probably better to use a canonical device name. # findmnt /dev/sdb TARGET SOURCE FSTYPE OPTIONS /mnt/test /dev/sdb btrfs rw,relatime,ssd,nospace_cache Karel -- Karel Zak <kzak@xxxxxxxxxx> http://karelzak.blogspot.com -- To unsubscribe from this list: send the line "unsubscribe initramfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html