Re: [PATCH 1/3] ismounted fix

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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


[Index of Archives]     [Linux Kernel]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux SCSI]

  Powered by Linux