Doron Shoham schrieb:
check if device is mounted on / before allocating it
Signed-off-by: Doron Shoham <dorons@xxxxxxxxxxxx>
---
scripts/tgt-admin | 21 +++++++++++++++------
1 files changed, 15 insertions(+), 6 deletions(-)
diff --git a/scripts/tgt-admin b/scripts/tgt-admin
index 22c4725..9a3d304 100755
--- a/scripts/tgt-admin
+++ b/scripts/tgt-admin
@@ -270,16 +270,20 @@ sub process_options {
}
my @value_arr = @$value;
my $i = 1;
+ my $local_device = `mount |grep -w "on /"`;
Instead of executing an external mount command we could do everything in
perl - read /proc/mounts and parse it.
+ if ($local_device =~ /(\/dev\/sd\w*)/) {
+ $local_device = $1;
+ }
foreach my $backing_store (@value_arr) {
- # Check if device exists
- if ( -e $backing_store) {
+ # Check if device exists and it is not mounted on /
+ if ( ( -e $backing_store) && ( $backing_store != $local_device) ) {
execute("tgtadm --lld $driver --op new --mode logicalunit --tid $next_tid --lun $i -b $backing_store");
$i += 1;
}
else {
print("skipping device $backing_store\n");
- print("$backing_store does not exist - please check the configuration file\n");
+ print("$backing_store does not exist or is mounted on / - please check the configuration file\n");
"is mounted on /" won't be very accurate if the device is mounted on
/mnt/blah.
}
}
}
@@ -296,9 +300,14 @@ sub process_options {
}
my @value_arr = @$value;
my $i = 1;
+ my $local_device = `mount |grep -w "on /"`;
+ if ($local_device =~ /(\/dev\/sd\w*)/) {
+ $local_device = $1;
/dev/hd* can be also local (used by legacy IDE). /dev/xvd* can be also
local (used by Xen). mtd devices can be also local (although I doubt
anyone would use them as targets).
+ }
+
foreach my $direct_store (@value_arr) {
- # Check if device exists
- if ( -e $direct_store) {
+ # Check if device exists and it is not mounted on /
+ if ( ( -e $direct_store) && ( $direct_store != $local_device) ) {
$inq=`sg_inq $direct_store`;
if ($inq=~/Vendor identification:\s*(\w+)\s*\n*Product identification:\s*([\w\s\/\-]+)\n\s*\n*Product revision level:\s*(\w*)\s*\n*Unit serial number:\s*(\w+)/)
{
@@ -318,7 +327,7 @@ sub process_options {
}
else {
print("skipping device $direct_store\n");
- print("$direct_store does not exist - please check the configuration file\n");
+ print("$direct_store does not exist or is mounted on / - please check the configuration file\n");
}
}
}
--
Tomasz Chmielewski
http://wpkg.org
--
To unsubscribe from this list: send the line "unsubscribe stgt" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html