210 lines
6.5 KiB
Diff
210 lines
6.5 KiB
Diff
|
From 9d36d4fb1d0774d9ef0597abb79390e88771bf1e Mon Sep 17 00:00:00 2001
|
||
|
From: Harald Hoyer <harald@redhat.com>
|
||
|
Date: Tue, 9 Apr 2013 10:47:39 +0200
|
||
|
Subject: [PATCH] dracut-functions.sh: make use of findmnt
|
||
|
|
||
|
---
|
||
|
dracut-functions.sh | 163 +++++++++++++++++++++-------------------------------
|
||
|
1 file changed, 64 insertions(+), 99 deletions(-)
|
||
|
|
||
|
diff --git a/dracut-functions.sh b/dracut-functions.sh
|
||
|
index eba7412..96d3c6e 100755
|
||
|
--- a/dracut-functions.sh
|
||
|
+++ b/dracut-functions.sh
|
||
|
@@ -319,131 +319,96 @@ get_maj_min() {
|
||
|
# $ find_block_device /usr
|
||
|
# 8:4
|
||
|
find_block_device() {
|
||
|
- local _x _mpt _majmin _dev _fs _maj _min _find_mpt
|
||
|
+ local _majmin _dev _majmin _find_mpt
|
||
|
_find_mpt="$1"
|
||
|
if [[ $use_fstab != yes ]]; then
|
||
|
- while read _x; do
|
||
|
- set -- $_x
|
||
|
- _majmin="$3"
|
||
|
- _mpt="$5"
|
||
|
- [[ $8 = "-" ]] && shift
|
||
|
- _fs="$8"
|
||
|
- _dev="$9"
|
||
|
- [[ $_mpt = $_find_mpt ]] || continue
|
||
|
- [[ $_fs = nfs ]] && { echo $_dev; return 0;}
|
||
|
- [[ $_fs = nfs3 ]] && { echo $_dev; return 0;}
|
||
|
- [[ $_fs = nfs4 ]] && { echo $_dev; return 0;}
|
||
|
- [[ $_fs = btrfs ]] && {
|
||
|
- get_maj_min $_dev
|
||
|
- return 0;
|
||
|
- }
|
||
|
- if [[ ${_majmin#0:} = $_majmin ]]; then
|
||
|
- echo $_majmin
|
||
|
- return 0 # we have a winner!
|
||
|
+ [[ -d $_find_mpt/. ]]
|
||
|
+ while read _majmin _dev; do
|
||
|
+ if [[ -b $_dev ]]; then
|
||
|
+ if ! [[ $_majmin ]] || [[ $_majmin == 0:* ]]; then
|
||
|
+ read _majmin < <(get_maj_min $_dev)
|
||
|
+ fi
|
||
|
+ if [[ $_majmin ]]; then
|
||
|
+ echo $_majmin
|
||
|
+ else
|
||
|
+ echo $_dev
|
||
|
+ fi
|
||
|
+ return 0
|
||
|
+ fi
|
||
|
+ if [[ $_dev = *:* ]]; then
|
||
|
+ echo $_dev
|
||
|
+ return 0
|
||
|
fi
|
||
|
- done < /proc/self/mountinfo
|
||
|
+ done < <(findmnt -e -v -n -o 'MAJ:MIN,SOURCE' "$_find_mpt")
|
||
|
fi
|
||
|
# fall back to /etc/fstab
|
||
|
- while read _dev _mpt _fs _x; do
|
||
|
- [ "${_dev%%#*}" != "$_dev" ] && continue
|
||
|
-
|
||
|
- if [[ $_mpt = $_find_mpt ]]; then
|
||
|
- [[ $_fs = nfs ]] && { echo $_dev; return 0;}
|
||
|
- [[ $_fs = nfs3 ]] && { echo $_dev; return 0;}
|
||
|
- [[ $_fs = nfs4 ]] && { echo $_dev; return 0;}
|
||
|
- [[ $_dev != ${_dev#UUID=} ]] && _dev=/dev/disk/by-uuid/${_dev#UUID=}
|
||
|
- [[ $_dev != ${_dev#LABEL=} ]] && _dev=/dev/disk/by-label/${_dev#LABEL=}
|
||
|
- [[ -b $_dev ]] || return 1 # oops, not a block device.
|
||
|
- get_maj_min "$_dev" && return 0
|
||
|
+
|
||
|
+ while read _majmin _dev; do
|
||
|
+ if ! [[ $_dev ]]; then
|
||
|
+ _dev="$_majmin"
|
||
|
+ unset _majmin
|
||
|
+ fi
|
||
|
+ if [[ -b $_dev ]]; then
|
||
|
+ [[ $_majmin ]] || read _majmin < <(get_maj_min $_dev)
|
||
|
+ if [[ $_majmin ]]; then
|
||
|
+ echo $_majmin
|
||
|
+ else
|
||
|
+ echo $_dev
|
||
|
+ fi
|
||
|
+ return 0
|
||
|
+ fi
|
||
|
+ if [[ $_dev = *:* ]]; then
|
||
|
+ echo $_dev
|
||
|
+ return 0
|
||
|
fi
|
||
|
- done < /etc/fstab
|
||
|
+ done < <(findmnt -e --fstab -v -n -o 'MAJ:MIN,SOURCE' "$_find_mpt")
|
||
|
|
||
|
return 1
|
||
|
}
|
||
|
|
||
|
-# find_dev_fstype <device>
|
||
|
-# Echo the filesystem type for a given device.
|
||
|
+# find_mp_fstype <mountpoint>
|
||
|
+# Echo the filesystem type for a given mountpoint.
|
||
|
# /proc/self/mountinfo is taken as the primary source of information
|
||
|
# and /etc/fstab is used as a fallback.
|
||
|
# No newline is appended!
|
||
|
# Example:
|
||
|
-# $ find_dev_fstype /dev/sda2;echo
|
||
|
+# $ find_mp_fstype /;echo
|
||
|
# ext4
|
||
|
-find_dev_fstype() {
|
||
|
- local _x _mpt _majmin _dev _fs _maj _min _find_dev
|
||
|
- _find_dev="$1"
|
||
|
- strstr "$_find_dev" "/dev" || _find_dev="/dev/block/$_find_dev"
|
||
|
- while read _x; do
|
||
|
- set -- $_x
|
||
|
- _majmin="$3"
|
||
|
- _mpt="$5"
|
||
|
- [[ $8 = "-" ]] && shift
|
||
|
- _fs="$8"
|
||
|
- _dev="$9"
|
||
|
- strstr "$_dev" "/dev" || continue
|
||
|
- [[ $_dev -ef $_find_dev ]] || continue
|
||
|
- [[ $_fs = "autofs" ]] && continue
|
||
|
- echo -n $_fs;
|
||
|
- return 0;
|
||
|
- done < /proc/self/mountinfo
|
||
|
+find_mp_fstype() {
|
||
|
+ local _fs
|
||
|
|
||
|
- # fall back to /etc/fstab
|
||
|
- while read _dev _mpt _fs _x; do
|
||
|
- [ "${_dev%%#*}" != "$_dev" ] && continue
|
||
|
- case "$_dev" in
|
||
|
- LABEL=*)
|
||
|
- _dev="$(echo $_dev | sed 's,/,\\x2f,g')"
|
||
|
- _dev="/dev/disk/by-label/${_dev#LABEL=}"
|
||
|
- ;;
|
||
|
- UUID=*)
|
||
|
- _dev="/dev/disk/by-uuid/${_dev#UUID=}"
|
||
|
- ;;
|
||
|
- PARTUUID=*)
|
||
|
- _dev="/dev/disk/by-partuuid/${_dev#PARTUUID=}"
|
||
|
- ;;
|
||
|
- esac
|
||
|
+ if [[ $use_fstab != yes ]]; then
|
||
|
+ while read _fs; do
|
||
|
+ [[ $_fs ]] || continue
|
||
|
+ [[ $_fs = "autofs" ]] && continue
|
||
|
+ echo -n $_fs
|
||
|
+ return 0
|
||
|
+ done < <(findmnt -e -v -n -o 'FSTYPE' "$1")
|
||
|
+ fi
|
||
|
|
||
|
- [[ $_dev -ef $_find_dev ]] || continue
|
||
|
- echo -n $_fs;
|
||
|
- return 0;
|
||
|
- done < /etc/fstab
|
||
|
+ while read _fs; do
|
||
|
+ [[ $_fs ]] || continue
|
||
|
+ [[ $_fs = "autofs" ]] && continue
|
||
|
+ echo -n $_fs
|
||
|
+ return 0
|
||
|
+ done < <(findmnt --fstab -e -v -n -o 'FSTYPE' "$1")
|
||
|
|
||
|
return 1
|
||
|
}
|
||
|
|
||
|
-# find_mp_fstype <mountpoint>
|
||
|
-# Echo the filesystem type for a given mountpoint.
|
||
|
+# find_dev_fstype <device>
|
||
|
+# Echo the filesystem type for a given device.
|
||
|
# /proc/self/mountinfo is taken as the primary source of information
|
||
|
# and /etc/fstab is used as a fallback.
|
||
|
# No newline is appended!
|
||
|
# Example:
|
||
|
-# $ find_mp_fstype /;echo
|
||
|
+# $ find_dev_fstype /dev/sda2;echo
|
||
|
# ext4
|
||
|
-find_mp_fstype() {
|
||
|
- local _x _mpt _majmin _dev _fs _maj _min _find_mpt
|
||
|
- _find_mpt="$1"
|
||
|
- while read _x; do
|
||
|
- set -- $_x
|
||
|
- _majmin="$3"
|
||
|
- _mpt="$5"
|
||
|
- [[ $8 = "-" ]] && shift
|
||
|
- _fs="$8"
|
||
|
- _dev="$9"
|
||
|
- [[ $_mpt = $_find_mpt ]] || continue
|
||
|
- [[ $_fs = "autofs" ]] && continue
|
||
|
- echo -n $_fs;
|
||
|
- return 0;
|
||
|
- done < /proc/self/mountinfo
|
||
|
-
|
||
|
- # fall back to /etc/fstab
|
||
|
- while read _dev _mpt _fs _x; do
|
||
|
- [ "${_dev%%#*}" != "$_dev" ] && continue
|
||
|
- [[ $_mpt = $_find_mpt ]] || continue
|
||
|
- echo -n $_fs;
|
||
|
- return 0;
|
||
|
- done < /etc/fstab
|
||
|
-
|
||
|
- return 1
|
||
|
+find_dev_fstype() {
|
||
|
+ local _x _mpt _majmin _dev _fs _maj _min _find_dev
|
||
|
+ _find_dev="$1"
|
||
|
+ [[ "$_find_dev" = /dev* ]] || _find_dev="/dev/block/$_find_dev"
|
||
|
+ find_mp_fstype "$_find_dev"
|
||
|
}
|
||
|
|
||
|
# finds the major:minor of the block device backing the root filesystem.
|