From a37f46396a1c88255f1d255a0048a1b81616e69a Mon Sep 17 00:00:00 2001 From: rjones Date: Mon, 14 Jan 2008 15:16:57 +0000 Subject: [PATCH] Make search_devices ignore any devices which fail blockdev --getsize, particularly removable devices with no media. Log everything sent to stderr in the logfile. --- virt-p2v.sh | 48 ++++++++++++++++++++++++++++-------------------- 1 file changed, 28 insertions(+), 20 deletions(-) diff --git a/virt-p2v.sh b/virt-p2v.sh index 228e1fc..e855068 100755 --- a/virt-p2v.sh +++ b/virt-p2v.sh @@ -62,12 +62,27 @@ override_root_filesystem="" override_network="" #---------------------------------------------------------------------- -# Logging. +# General script setup and logging. + +exec 2>> /tmp/virt-p2v.log function log { - echo "$@" >> /tmp/virt-p2v.log + echo "$@" 1>&2 } +log +log virt-p2v starting up at `date` + +# The first and only parameter must be the tty. Connect +# stdin/stdout to this device. +if [ -n "$1" ]; then + log connecting to /dev/$1 + exec /dev/$1 +fi + +# We can safely write files into /tmp without modifying anything. +cd /tmp + #---------------------------------------------------------------------- # Helper functions. @@ -169,7 +184,17 @@ function device_of_lvs_device { # Get list of physical block devices. Sets variable $devices # to something like "sda sdb". function search_devices { - devices=$(cd /sys/block && /bin/ls -d [hs]d*) + devices1=$(cd /sys/block && /bin/ls -d [hs]d*) + log search_devices: devices1: $devices1 + # Ignore devices which fail 'blockdev --getsize' - probably + # removable devices or other strange ones. + devices="" + for d in $devices1; do + if blockdev --getsize /dev/$d > /dev/null; then + devices="$devices${devices:+ }$d" + fi + done + log search_devices: devices: $devices } # Get list of partitions from a physical block device. Sets @@ -306,23 +331,6 @@ function auto_network { return $status } - -#---------------------------------------------------------------------- -# General script setup. - -log -log virt-p2v starting up at `date` - -# The first and only parameter must be the tty. Connect -# stdin/stdout/stderr to this device. -if [ -n "$1" ]; then - log connecting to /dev/$1 - exec /dev/$1 -fi - -# We can safely write files into /tmp without modifying anything. -cd /tmp - #---------------------------------------------------------------------- # Dialog with the user. -- 1.8.3.1