Accepting request 114941 from Base:System
- Update to version 1.33 - sg_ses: major rework of indexes (again), now two level - sg_write_buffer: new --specific option for mode specific field; new mode 13 (spc4r32) - sg_vpd: add hp3par volume info vendor VPD page - fix 'scsi ports' [0x88] page problem - add 'sinq' pseudo page for standard inquiry response - add power consumption page - sg_format: add --poll= option for request sense polling - improve handling of disks > 2 TB and DIF (protection) - sg_logs: LB provision lpage extra (sbc3r28) - sg_modes: application tag mpage subcode 0xf0->0x2 - sg_write_same: no prot fields when wrprotect=0 - sg_get_lba_status: reflect change in sbc3r25 to Parameter Data Length response field (offset reduced from 8 to 4) - sg_inq, sg_vpd: sync with spc4r33 - win32: change DataBufferOffset type per MSDN; caused problem with 64 bit machines (with buffered interface) - sg_luns: tweak documentation for vendor specific reports - add man pages for scsi_loging_level, scsi_mandat, scsi_satl and scsi_temperature - Update to version 1.32 + sg_sanitize: new utility for command added in sb3r27 + sg_sat_identify: add '--ident' to output WWN + sg_ses: major rework of descriptor output + add --index, --descriptor, --join, --clear, --get, and --set options + sg_raw: exit status corrections + sg_decode_sense: add --nospace and --hex options OBS-URL: https://build.opensuse.org/request/show/114941 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/sg3_utils?expand=0&rev=23
This commit is contained in:
commit
5a32af6ed9
@ -1,9 +1,11 @@
|
||||
#!/bin/bash
|
||||
# Skript to rescan SCSI bus, using the
|
||||
# scsi add-single-device mechanism
|
||||
# (c) 1998--2008 Kurt Garloff <kurt@garloff.de>, GNU GPL v2 or later
|
||||
# (c) 1998--2010 Kurt Garloff <kurt@garloff.de>, GNU GPL v2 or v3
|
||||
# (c) 2006--2008 Hannes Reinecke, GNU GPL v2 or later
|
||||
# $Id: rescan-scsi-bus.sh,v 1.29 2008/10/29 10:03:04 garloff Exp $
|
||||
# $Id: rescan-scsi-bus.sh,v 1.56 2012/01/14 22:23:53 garloff Exp $
|
||||
|
||||
SCAN_WILD_CARD=4294967295
|
||||
|
||||
setcolor ()
|
||||
{
|
||||
@ -20,26 +22,53 @@ unsetcolor ()
|
||||
yellow=""; norm=""
|
||||
}
|
||||
|
||||
# Output some text and return cursor to previous position
|
||||
# (only works for simple strings)
|
||||
# Stores length of string in LN and returns it
|
||||
print_and_scroll_back ()
|
||||
{
|
||||
STRG="$1"
|
||||
LN=${#STRG}
|
||||
BK=""
|
||||
declare -i cntr=0
|
||||
while test $cntr -lt $LN; do BK="$BK\e[D"; let cntr+=1; done
|
||||
echo -en "$STRG$BK"
|
||||
return $LN
|
||||
}
|
||||
|
||||
# Overwrite a text of length $1 (fallback to $LN) with whitespace
|
||||
white_out ()
|
||||
{
|
||||
BK=""; WH=""
|
||||
if test -n "$1"; then LN=$1; fi
|
||||
declare -i cntr=0
|
||||
while test $cntr -lt $LN; do BK="$BK\e[D"; WH="$WH "; let cntr+=1; done
|
||||
echo -en "$WH$BK"
|
||||
}
|
||||
|
||||
# Return hosts. sysfs must be mounted
|
||||
findhosts_26 ()
|
||||
{
|
||||
hosts=
|
||||
for hostdir in /sys/class/scsi_host/host*; do
|
||||
hosts=`find /sys/class/scsi_host/host* -maxdepth 4 -type d -o -type l 2> /dev/null | awk -F'/' '{print $5}' | sed -e 's~host~~' | sort -nu`
|
||||
scsi_host_data=`echo "$hosts" | sed -e 's~^~/sys/class/scsi_host/host~'`
|
||||
for hostdir in $scsi_host_data; do
|
||||
hostno=${hostdir#/sys/class/scsi_host/host}
|
||||
if [ -f $hostdir/isp_name ] ; then
|
||||
hostname="qla2xxx"
|
||||
hostname="qla2xxx"
|
||||
elif [ -f $hostdir/lpfc_drvr_version ] ; then
|
||||
hostname="lpfc"
|
||||
hostname="lpfc"
|
||||
else
|
||||
hostname=`cat $hostdir/proc_name`
|
||||
hostname=`cat $hostdir/proc_name`
|
||||
fi
|
||||
hosts="$hosts $hostno"
|
||||
#hosts="$hosts $hostno"
|
||||
echo "Host adapter $hostno ($hostname) found."
|
||||
done
|
||||
if [ -z "$hosts" ] ; then
|
||||
echo "No SCSI host adapters found in sysfs"
|
||||
exit 1;
|
||||
fi
|
||||
# Not necessary just use double quotes around variable to preserve new lines
|
||||
#hosts=`echo $hosts | tr ' ' '\n'`
|
||||
}
|
||||
|
||||
# Return hosts. /proc/scsi/HOSTADAPTER/? must exist
|
||||
@ -66,63 +95,72 @@ findhosts ()
|
||||
|
||||
printtype ()
|
||||
{
|
||||
local type=$1
|
||||
local type=$1
|
||||
|
||||
case "$type" in
|
||||
0) echo "Direct-Access " ;;
|
||||
1) echo "Sequential-Access" ;;
|
||||
2) echo "Printer " ;;
|
||||
3) echo "Processor " ;;
|
||||
4) echo "WORM " ;;
|
||||
5) echo "CD-ROM " ;;
|
||||
6) echo "Scanner " ;;
|
||||
7) echo "Optical Device " ;;
|
||||
8) echo "Medium Changer " ;;
|
||||
9) echo "Communications " ;;
|
||||
10) echo "Unknown " ;;
|
||||
11) echo "Unknown " ;;
|
||||
12) echo "RAID " ;;
|
||||
13) echo "Enclosure " ;;
|
||||
14) echo "Direct-Access-RBC" ;;
|
||||
*) echo "Unknown " ;;
|
||||
esac
|
||||
case "$type" in
|
||||
0) echo "Direct-Access " ;;
|
||||
1) echo "Sequential-Access" ;;
|
||||
2) echo "Printer " ;;
|
||||
3) echo "Processor " ;;
|
||||
4) echo "WORM " ;;
|
||||
5) echo "CD-ROM " ;;
|
||||
6) echo "Scanner " ;;
|
||||
7) echo "Optical Device " ;;
|
||||
8) echo "Medium Changer " ;;
|
||||
9) echo "Communications " ;;
|
||||
10) echo "Unknown " ;;
|
||||
11) echo "Unknown " ;;
|
||||
12) echo "RAID " ;;
|
||||
13) echo "Enclosure " ;;
|
||||
14) echo "Direct-Access-RBC" ;;
|
||||
*) echo "Unknown " ;;
|
||||
esac
|
||||
}
|
||||
|
||||
print02i()
|
||||
{
|
||||
if [ "$1" = "*" ] ; then
|
||||
echo "00"
|
||||
else
|
||||
printf "%02i" "$1"
|
||||
fi
|
||||
}
|
||||
|
||||
# Get /proc/scsi/scsi info for device $host:$channel:$id:$lun
|
||||
# Optional parameter: Number of lines after first (default = 2),
|
||||
# result in SCSISTR, return code 1 means empty.
|
||||
procscsiscsi ()
|
||||
{
|
||||
if test -z "$1"; then LN=2; else LN=$1; fi
|
||||
CHANNEL=`printf "%02i" $channel`
|
||||
ID=`printf "%02i" $id`
|
||||
LUN=`printf "%02i" $lun`
|
||||
CHANNEL=`print02i "$channel"`
|
||||
ID=`print02i "$id"`
|
||||
LUN=`print02i "$lun"`
|
||||
if [ -d /sys/class/scsi_device ]; then
|
||||
SCSIPATH="/sys/class/scsi_device/${host}:${channel}:${id}:${lun}"
|
||||
if [ -d "$SCSIPATH" ] ; then
|
||||
SCSISTR="Host: scsi${host} Channel: $CHANNEL Id: $ID Lun: $LUN"
|
||||
if [ "$LN" -gt 0 ] ; then
|
||||
IVEND=$(cat ${SCSIPATH}/device/vendor)
|
||||
IPROD=$(cat ${SCSIPATH}/device/model)
|
||||
IPREV=$(cat ${SCSIPATH}/device/rev)
|
||||
SCSIDEV=$(printf ' Vendor: %-08s Model: %-16s Rev: %-4s' "$IVEND" "$IPROD" "$IPREV")
|
||||
SCSISTR="$SCSISTR
|
||||
SCSIPATH="/sys/class/scsi_device/${host}:${channel}:${id}:${lun}"
|
||||
if [ -d "$SCSIPATH" ] ; then
|
||||
SCSISTR="Host: scsi${host} Channel: $CHANNEL Id: $ID Lun: $LUN"
|
||||
if [ "$LN" -gt 0 ] ; then
|
||||
IVEND=$(cat ${SCSIPATH}/device/vendor)
|
||||
IPROD=$(cat ${SCSIPATH}/device/model)
|
||||
IPREV=$(cat ${SCSIPATH}/device/rev)
|
||||
SCSIDEV=$(printf ' Vendor: %-08s Model: %-16s Rev: %-4s' "$IVEND" "$IPROD" "$IPREV")
|
||||
SCSISTR="$SCSISTR
|
||||
$SCSIDEV"
|
||||
fi
|
||||
if [ "$LN" -gt 1 ] ; then
|
||||
ILVL=$(cat ${SCSIPATH}/device/scsi_level)
|
||||
type=$(cat ${SCSIPATH}/device/type)
|
||||
ITYPE=$(printtype $type)
|
||||
SCSITMP=$(printf ' Type: %-16s ANSI SCSI revision: %02d' "$ITYPE" "$((ILVL - 1))")
|
||||
SCSISTR="$SCSISTR
|
||||
$SCSITMP"
|
||||
fi
|
||||
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
if [ "$LN" -gt 1 ] ; then
|
||||
ILVL=$(cat ${SCSIPATH}/device/scsi_level)
|
||||
type=$(cat ${SCSIPATH}/device/type)
|
||||
ITYPE=$(printtype $type)
|
||||
SCSITMP=$(printf ' Type: %-16s ANSI SCSI revision: %02d' "$ITYPE" "$((ILVL - 1))")
|
||||
SCSISTR="$SCSISTR
|
||||
$SCSITMP"
|
||||
fi
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
else
|
||||
grepstr="scsi$host Channel: $CHANNEL Id: $ID Lun: $LUN"
|
||||
SCSISTR=`cat /proc/scsi/scsi | grep -A$LN -e"$grepstr"`
|
||||
grepstr="scsi$host Channel: $CHANNEL Id: $ID Lun: $LUN"
|
||||
SCSISTR=`cat /proc/scsi/scsi | grep -A$LN -e"$grepstr"`
|
||||
fi
|
||||
if test -z "$SCSISTR"; then return 1; else return 0; fi
|
||||
}
|
||||
@ -153,6 +191,7 @@ sgdevice24 ()
|
||||
}
|
||||
|
||||
# Find sg device that belongs to SCSI device $host $channel $id $lun
|
||||
# and return in SGDEV
|
||||
sgdevice ()
|
||||
{
|
||||
SGDEV=
|
||||
@ -174,21 +213,38 @@ sgdevice ()
|
||||
echo "scsi report-devs 0" >/proc/scsi/scsi
|
||||
fi
|
||||
fi
|
||||
}
|
||||
}
|
||||
|
||||
# Test if SCSI device is still responding to commands
|
||||
testonline ()
|
||||
{
|
||||
: testonline
|
||||
RC=0
|
||||
if test ! -x /usr/bin/sg_turs; then return 0; fi
|
||||
sgdevice
|
||||
if test -z "$SGDEV"; then return 0; fi
|
||||
sg_turs /dev/$SGDEV >/dev/null 2>&1
|
||||
RC=$?
|
||||
# Handle in progress of becoming ready and unit attention -- wait at max 11s
|
||||
declare -i ctr=0
|
||||
if test $RC = 2 -o $RC = 6; then
|
||||
RMB=`sg_inq /dev/$SGDEV | grep 'RMB=' | sed 's/^.*RMB=\(.\).*$/\1/'`
|
||||
print_and_scroll_back "$host:$channel:$id:$lun $SGDEV ($RMB) "
|
||||
fi
|
||||
while test $RC = 2 -o $RC = 6 && test $ctr -le 8; do
|
||||
if test $RC = 2 -a "$RMB" != "1"; then echo -n "."; let $LN+=1; sleep 1
|
||||
else usleep 20000; fi
|
||||
let ctr+=1
|
||||
sg_turs /dev/$SGDEV >/dev/null 2>&1
|
||||
RC=$?
|
||||
done
|
||||
if test $ctr != 0; then white_out; fi
|
||||
# echo -e "\e[A\e[A\e[A${yellow}Test existence of $SGDEV = $RC ${norm} \n\n\n"
|
||||
if test $RC = 1; then return $RC; fi
|
||||
# Reset RC (might be !=0 for passive paths)
|
||||
RC=0
|
||||
# OK, device online, compare INQUIRY string
|
||||
INQ=`sg_inq $sg_len_arg /dev/$SGDEV`
|
||||
INQ=`sg_inq $sg_len_arg /dev/$SGDEV 2>/dev/null`
|
||||
IVEND=`echo "$INQ" | grep 'Vendor identification:' | sed 's/^[^:]*: \(.*\)$/\1/'`
|
||||
IPROD=`echo "$INQ" | grep 'Product identification:' | sed 's/^[^:]*: \(.*\)$/\1/'`
|
||||
IPREV=`echo "$INQ" | grep 'Product revision level:' | sed 's/^[^:]*: \(.*\)$/\1/'`
|
||||
@ -196,7 +252,7 @@ testonline ()
|
||||
IPTYPE=`echo "$INQ" | sed -n 's/.* Device_type=\([0-9]*\) .*/\1/p'`
|
||||
IPQUAL=`echo "$INQ" | sed -n 's/ *PQual=\([0-9]*\) Device.*/\1/p'`
|
||||
if [ "$IPQUAL" != 0 ] ; then
|
||||
echo -e "\e[A\e[A\e[A\e[A${red}$SGDEV changed: ${bold}\nLU not available (PQual $IPQUAL)${norm}\n\n\n"
|
||||
echo -e "\e[A\e[A\e[A\e[A${red}$SGDEV changed: ${bold}LU not available (PQual $IPQUAL)${norm} \n\n\n"
|
||||
return 2
|
||||
fi
|
||||
|
||||
@ -204,24 +260,25 @@ testonline ()
|
||||
procscsiscsi
|
||||
TMPSTR=`echo "$SCSISTR" | grep 'Vendor:'`
|
||||
if [ "$TMPSTR" != "$STR" ]; then
|
||||
echo -e "\e[A\e[A\e[A\e[A${red}$SGDEV changed: ${bold}\nfrom:${SCSISTR#* } \nto: $STR ${norm}\n\n\n"
|
||||
echo -e "\e[A\e[A\e[A\e[A${red}$SGDEV changed: ${bold}\nfrom:${SCSISTR#* } \nto: $STR ${norm} \n\n\n"
|
||||
return 1
|
||||
fi
|
||||
TMPSTR=`echo "$SCSISTR" | sed -n 's/.*Type: *\(.*\) *ANSI.*/\1/p'`
|
||||
if [ $TMPSTR != $TYPE ] ; then
|
||||
echo -e "\e[A\e[A\e[A\e[A${red}$SGDEV changed: ${bold}\nfrom:${TMPSTR} \nto: $TYPE ${norm}\n\n\n"
|
||||
echo -e "\e[A\e[A\e[A\e[A${red}$SGDEV changed: ${bold}\nfrom:${TMPSTR} \nto: $TYPE ${norm} \n\n\n"
|
||||
return 1
|
||||
fi
|
||||
return $RC
|
||||
}
|
||||
|
||||
# Test if SCSI device $host $channen $id $lun exists
|
||||
# Outputs description from /proc/scsi/scsi, returns SCSISTR
|
||||
# Outputs description from /proc/scsi/scsi (unless arg passed)
|
||||
# Returns SCSISTR (empty if no dev)
|
||||
testexist ()
|
||||
{
|
||||
: testexist
|
||||
SCSISTR=
|
||||
if procscsiscsi; then
|
||||
if procscsiscsi && test -z "$1"; then
|
||||
echo "$SCSISTR" | head -n1
|
||||
echo "$SCSISTR" | tail -n2 | pr -o4 -l1
|
||||
fi
|
||||
@ -249,6 +306,7 @@ chanlist ()
|
||||
channelsearch="$channelsearch $chan"
|
||||
fi
|
||||
done
|
||||
if test -z "$channelsearch"; then channelsearch="0"; fi
|
||||
}
|
||||
|
||||
# Returns the list of existing targets per host
|
||||
@ -278,23 +336,59 @@ idlist ()
|
||||
done
|
||||
}
|
||||
|
||||
# Returns the list of existing LUNs
|
||||
getluns ()
|
||||
# Returns the list of existing LUNs from device $host $channel $id $lun
|
||||
# and returns list to stdout
|
||||
getluns()
|
||||
{
|
||||
if test ! -x /usr/bin/sg_luns; then return ""; fi
|
||||
sgdevice
|
||||
if test -z "$SGDEV"; then return ""; fi
|
||||
sg_luns -d /dev/$SGDEV | sed -n 's/.*lun=\(.*\)/\1/p'
|
||||
if test -z "$SGDEV"; then return 1; fi
|
||||
if test ! -x /usr/bin/sg_luns; then echo 0; return 1; fi
|
||||
LLUN=`sg_luns /dev/$SGDEV 2>/dev/null | sed -n 's/ \(.*\)/\1/p'`
|
||||
if test $? != 0; then echo 0; return 1; fi
|
||||
#echo "$LLUN" | sed -n 's/.*lun=\(.*\)/\1/p'
|
||||
for lun in $LLUN ; do
|
||||
# Swap LUN number
|
||||
l0=$(printf '%u' 0x$lun)
|
||||
l1=$(( ($l0 >> 48) & 0xffff ))
|
||||
l2=$(( ($l0 >> 32) & 0xffff ))
|
||||
l3=$(( ($l0 >> 16) & 0xffff ))
|
||||
l4=$(( $l0 & 0xffff ))
|
||||
l0=$(( ( ( ($l4 * 0xffff) + $l3 ) * 0xffff + $l2 ) * 0xffff + $l1 ))
|
||||
printf "%u\n" $l0
|
||||
done
|
||||
return 0
|
||||
}
|
||||
|
||||
# Perform scan on a single lun
|
||||
# Wait for udev to settle (create device nodes etc.)
|
||||
udevadm_settle()
|
||||
{
|
||||
if test -x /sbin/udevadm; then
|
||||
print_and_scroll_back " Calling udevadm settle (can take a while) "
|
||||
/sbin/udevadm settle
|
||||
white_out
|
||||
elif test -x /sbin/udevsettle; then
|
||||
print_and_scroll_back " Calling udevsettle (can take a while) "
|
||||
/sbin/udevsettle
|
||||
white_out
|
||||
else
|
||||
usleep 20000
|
||||
fi
|
||||
}
|
||||
|
||||
# Perform scan on a single lun $host $channel $id $lun
|
||||
dolunscan()
|
||||
{
|
||||
SCSISTR=
|
||||
devnr="$host $channel $id $lun"
|
||||
echo "Scanning for device $devnr ..."
|
||||
echo -e " Scanning for device $devnr ... "
|
||||
printf "${yellow}OLD: $norm"
|
||||
testexist
|
||||
# Special case: lun 0 just got added (for reportlunscan),
|
||||
# so make sure we correctly treat it as new
|
||||
if test "$lun" = "0" -a "$1"; then
|
||||
SCSISTR=""
|
||||
printf "\r\e[A\e[A\e[A"
|
||||
fi
|
||||
: f $remove s $SCSISTR
|
||||
if test "$remove" -a "$SCSISTR"; then
|
||||
# Device exists: Test whether it's still online
|
||||
@ -307,10 +401,9 @@ dolunscan()
|
||||
echo -e "${norm}\e[B\e[B"
|
||||
if test -e /sys/class/scsi_device/${host}:${channel}:${id}:${lun}/device; then
|
||||
echo 1 > /sys/class/scsi_device/${host}:${channel}:${id}:${lun}/device/delete
|
||||
if test $RC -eq 1 -o $lun -eq 0 ; then
|
||||
# Try readding, should fail if device is gone
|
||||
echo "$channel $id $lun" > /sys/class/scsi_host/host${host}/scan
|
||||
fi
|
||||
# FIXME: Can we skip udevadm settle for removal?
|
||||
#udevadm_settle
|
||||
usleep 20000
|
||||
else
|
||||
echo "scsi remove-single-device $devnr" > /proc/scsi/scsi
|
||||
if test $RC -eq 1 -o $lun -eq 0 ; then
|
||||
@ -322,9 +415,10 @@ dolunscan()
|
||||
if test $RC = 0 -o "$forcerescan" ; then
|
||||
if test -e /sys/class/scsi_device/${host}:${channel}:${id}:${lun}/device; then
|
||||
echo 1 > /sys/class/scsi_device/${host}:${channel}:${id}:${lun}/device/rescan
|
||||
udevadm_settle
|
||||
fi
|
||||
fi
|
||||
printf "\r\x1b[A\x1b[A\x1b[A${yellow}OLD: $norm"
|
||||
printf "\r\e[A\e[A\e[A${yellow}OLD: $norm"
|
||||
testexist
|
||||
if test -z "$SCSISTR"; then
|
||||
printf "\r${red}DEL: $norm\r\n\n"
|
||||
@ -337,13 +431,14 @@ dolunscan()
|
||||
printf "\r${green}NEW: $norm"
|
||||
if test -e /sys/class/scsi_host/host${host}/scan; then
|
||||
echo "$channel $id $lun" > /sys/class/scsi_host/host${host}/scan 2> /dev/null
|
||||
udevadm_settle
|
||||
else
|
||||
echo "scsi add-single-device $devnr" > /proc/scsi/scsi
|
||||
fi
|
||||
testexist
|
||||
if test -z "$SCSISTR"; then
|
||||
# Device not present
|
||||
printf "\r\x1b[A";
|
||||
printf "\r\e[A";
|
||||
# Optimization: if lun==0, stop here (only if in non-remove mode)
|
||||
if test $lun = 0 -a -z "$remove" -a $optscan = 1; then
|
||||
break;
|
||||
@ -354,58 +449,95 @@ dolunscan()
|
||||
fi
|
||||
}
|
||||
|
||||
# Perform report lun scan
|
||||
# Perform report lun scan on $host $channel $id using REPORT_LUNS
|
||||
doreportlun()
|
||||
{
|
||||
lun=0
|
||||
SCSISTR=
|
||||
devnr="$host $channel $id $lun"
|
||||
echo "Scanning for device $devnr ..."
|
||||
printf "${yellow}OLD: $norm"
|
||||
testexist
|
||||
echo -en " Scanning for device $devnr ...\r"
|
||||
lun0added=
|
||||
#printf "${yellow}OLD: $norm"
|
||||
# Phase one: If LUN0 does not exist, try to add
|
||||
testexist -q
|
||||
if test -z "$SCSISTR"; then
|
||||
# Device does not exist, try to add
|
||||
printf "\r${green}NEW: $norm"
|
||||
#printf "\r${green}NEW: $norm"
|
||||
if test -e /sys/class/scsi_host/host${host}/scan; then
|
||||
echo "$channel $id $lun" > /sys/class/scsi_host/host${host}/scan 2> /dev/null
|
||||
udevadm_settle
|
||||
else
|
||||
echo "scsi add-single-device $devnr" > /proc/scsi/scsi
|
||||
fi
|
||||
testexist
|
||||
if test -z "$SCSISTR"; then
|
||||
testexist -q
|
||||
if test -n "$SCSISTR"; then
|
||||
lun0added=1
|
||||
#testonline
|
||||
else
|
||||
# Device not present
|
||||
printf "\r\x1b[A";
|
||||
lunsearch=
|
||||
return
|
||||
# return
|
||||
# Find alternative LUN to send getluns to
|
||||
for dev in /sys/class/scsi_device/${host}:${channel}:${id}:*; do
|
||||
[ -d "$dev" ] || continue
|
||||
lun=${dev##*:}
|
||||
break
|
||||
done
|
||||
fi
|
||||
fi
|
||||
lunsearch=`getluns`
|
||||
targetluns=`getluns`
|
||||
REPLUNSTAT=$?
|
||||
lunremove=
|
||||
#echo "getluns reports " $targetluns
|
||||
olddev=`find /sys/class/scsi_device/ -name $host:$channel:$id:* 2>/dev/null`
|
||||
oldluns=`echo "$olddev" | awk -F'/' '{print $5}' | awk -F':' '{print $4}'`
|
||||
oldtargets="$targetluns"
|
||||
# OK -- if we don't have a LUN to send a REPORT_LUNS to, we could
|
||||
# fall back to wildcard scanning. Same thing if the device does not
|
||||
# support REPORT_LUNS
|
||||
# TODO: We might be better off to ALWAYS use wildcard scanning if
|
||||
# it works
|
||||
if test "$REPLUNSTAT" = "1"; then
|
||||
if test -e /sys/class/scsi_host/host${host}/scan; then
|
||||
echo "$channel $id -" > /sys/class/scsi_host/host${host}/scan 2> /dev/null
|
||||
udevadm_settle
|
||||
else
|
||||
echo "scsi add-single-device $host $channel $id $SCAN_WILD_CARD" > /proc/scsi/scsi
|
||||
fi
|
||||
targetluns=`find /sys/class/scsi_device/ -name $host:$channel:$id:* 2>/dev/null | awk -F'/' '{print $5}' | awk -F':' '{print $4}' | sort -n`
|
||||
let found+=`echo "$targetluns" | wc -l`
|
||||
let found-=`echo "$olddev" | wc -l`
|
||||
fi
|
||||
if test -z "$targetluns"; then targetluns="$oldtargets"; fi
|
||||
# Check existing luns
|
||||
for dev in /sys/class/scsi_device/${host}:${channel}:${id}:*; do
|
||||
for dev in $olddev; do
|
||||
[ -d "$dev" ] || continue
|
||||
lun=${dev##*:}
|
||||
newsearch=
|
||||
oldsearch="$lunsearch"
|
||||
for tmplun in $lunsearch; do
|
||||
inlist=
|
||||
# OK, is existing $lun (still) in reported list
|
||||
for tmplun in $targetluns; do
|
||||
if test $tmplun -eq $lun ; then
|
||||
dolunscan
|
||||
inlist=1
|
||||
dolunscan $lun0added
|
||||
else
|
||||
newsearch="$newsearch $tmplun"
|
||||
fi
|
||||
done
|
||||
if [ "${#oldsearch}" = "${#newsearch}" ] ; then
|
||||
# Stale lun
|
||||
lunremove="$lunremove $lun"
|
||||
# OK, we have now done a lunscan on $lun and
|
||||
# $newsearch is the old $targetluns without $lun
|
||||
if [ -z "$inlist" ]; then
|
||||
# Stale lun
|
||||
lunremove="$lunremove $lun"
|
||||
fi
|
||||
lunsearch="$newsearch"
|
||||
# $lun removed from $lunsearch (echo for whitespace cleanup)
|
||||
targetluns=`echo $newsearch`
|
||||
done
|
||||
# Add new ones and check stale ones
|
||||
for lun in $lunsearch $lunremove; do
|
||||
dolunscan
|
||||
for lun in $targetluns $lunremove; do
|
||||
dolunscan $lun0added
|
||||
done
|
||||
}
|
||||
|
||||
|
||||
# Perform search (scan $host)
|
||||
dosearch ()
|
||||
{
|
||||
@ -428,14 +560,35 @@ dosearch ()
|
||||
done
|
||||
}
|
||||
|
||||
expandlist ()
|
||||
{
|
||||
list=$1
|
||||
result=""
|
||||
first=${list%%,*}
|
||||
rest=${list#*,}
|
||||
while test ! -z "$first"; do
|
||||
beg=${first%%-*};
|
||||
if test "$beg" = "$first"; then
|
||||
result="$result $beg";
|
||||
else
|
||||
end=${first#*-}
|
||||
result="$result `seq $beg $end`"
|
||||
fi
|
||||
test "$rest" = "$first" && rest=""
|
||||
first=${rest%%,*}
|
||||
rest=${rest#*,}
|
||||
done
|
||||
echo $result
|
||||
}
|
||||
|
||||
# main
|
||||
if test @$1 = @--help -o @$1 = @-h -o @$1 = @-?; then
|
||||
echo "Usage: rescan-scsi-bus.sh [options] [host [host ...]]"
|
||||
echo "Options:"
|
||||
echo " -l activates scanning for LUNs 0-7 [default: 0]"
|
||||
echo " -l activates scanning for LUNs 0--7 [default: 0]"
|
||||
echo " -L NUM activates scanning for LUNs 0--NUM [default: 0]"
|
||||
echo " -w scan for target device IDs 0 .. 15 [default: 0-7]"
|
||||
echo " -c enables scanning of channels 0 1 [default: 0]"
|
||||
echo " -w scan for target device IDs 0--15 [default: 0--7]"
|
||||
echo " -c enables scanning of channels 0 1 [default: 0 / all detected ones]"
|
||||
echo " -r enables removing of devices [default: disabled]"
|
||||
echo " -i issue a FibreChannel LIP reset [default: disabled]"
|
||||
echo "--remove: same as -r"
|
||||
@ -448,6 +601,11 @@ if test @$1 = @--help -o @$1 = @-h -o @$1 = @-?; then
|
||||
echo "--channels=LIST: Scan only channel(s) in LIST"
|
||||
echo "--ids=LIST: Scan only target ID(s) in LIST"
|
||||
echo "--luns=LIST: Scan only lun(s) in LIST"
|
||||
echo "--sync/nosync: Issue a sync / no sync [default: sync if remove]"
|
||||
echo "--attachpq3: Tell kernel to attach sg to LUN 0 that reports PQ=3"
|
||||
echo "--reportlun2: Tell kernel to try REPORT_LUN even on SCSI2 devices"
|
||||
echo "--largelun: Tell kernel to support LUNs > 7 even on SCSI2 devs"
|
||||
echo "--sparselun: Tell kernel to support sparse LUN numbering"
|
||||
echo " Host numbers may thus be specified either directly on cmd line (deprecated) or"
|
||||
echo " or with the --hosts=LIST parameter (recommended)."
|
||||
echo "LIST: A[-B][,C[-D]]... is a comma separated list of single values and ranges"
|
||||
@ -455,27 +613,6 @@ if test @$1 = @--help -o @$1 = @-h -o @$1 = @-?; then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
expandlist ()
|
||||
{
|
||||
list=$1
|
||||
result=""
|
||||
first=${list%%,*}
|
||||
rest=${list#*,}
|
||||
while test ! -z "$first"; do
|
||||
beg=${first%%-*};
|
||||
if test "$beg" = "$first"; then
|
||||
result="$result $beg";
|
||||
else
|
||||
end=${first#*-}
|
||||
result="$result `seq $beg $end`"
|
||||
fi
|
||||
test "$rest" = "$first" && rest=""
|
||||
first=${rest%%,*}
|
||||
rest=${rest#*,}
|
||||
done
|
||||
echo $result
|
||||
}
|
||||
|
||||
if test ! -d /sys/class/scsi_host/ -a ! -d /proc/scsi/; then
|
||||
echo "Error: SCSI subsystem not active"
|
||||
exit 1
|
||||
@ -484,22 +621,30 @@ fi
|
||||
# Make sure sg is there
|
||||
modprobe sg >/dev/null 2>&1
|
||||
|
||||
sg_version=$(sg_inq -V 2>&1 | cut -d " " -f 3)
|
||||
sg_version=${sg_version##0.}
|
||||
if [ "$sg_version" -lt 70 ] ; then
|
||||
sg_len_arg="-36"
|
||||
if test -x /usr/bin/sg_inq; then
|
||||
sg_version=$(sg_inq -V 2>&1 | cut -d " " -f 3)
|
||||
sg_version=${sg_version##0.}
|
||||
#echo "\"$sg_version\""
|
||||
if [ -z "$sg_version" -o "$sg_version" -lt 70 ] ; then
|
||||
sg_len_arg="-36"
|
||||
else
|
||||
sg_len_arg="--len=36"
|
||||
fi
|
||||
else
|
||||
sg_len_arg="--len=36"
|
||||
fi
|
||||
echo "WARN: /usr/bin/sg_inq not present -- please install sg3_utils"
|
||||
echo " or rescan-scsi-bus.sh might not fully work."
|
||||
fi
|
||||
|
||||
# defaults
|
||||
unsetcolor
|
||||
lunsearch=""
|
||||
idsearch=`seq 0 7`
|
||||
channelsearch=""
|
||||
lunsearch=
|
||||
opt_idsearch=`seq 0 7`
|
||||
opt_channelsearch=
|
||||
remove=
|
||||
forceremove=
|
||||
optscan=1
|
||||
sync=1
|
||||
declare -i scan_flags=0
|
||||
if test -d /sys/class/scsi_host; then
|
||||
findhosts_26
|
||||
else
|
||||
@ -513,20 +658,26 @@ while test ! -z "$opt" -a -z "${opt##-*}"; do
|
||||
case "$opt" in
|
||||
l) lunsearch=`seq 0 7` ;;
|
||||
L) lunsearch=`seq 0 $2`; shift ;;
|
||||
w) idsearch=`seq 0 15` ;;
|
||||
c) channelsearch="0 1" ;;
|
||||
w) opt_idsearch=`seq 0 15` ;;
|
||||
c) opt_channelsearch="0 1" ;;
|
||||
r) remove=1 ;;
|
||||
i) lipreset=1 ;;
|
||||
-remove) remove=1 ;;
|
||||
-forcerescan) remove=1; forcerescan=1 ;;
|
||||
-forceremove) remove=1; forceremove=1 ;;
|
||||
-hosts=*) arg=${opt#-hosts=}; hosts=`expandlist $arg` ;;
|
||||
-channels=*) arg=${opt#-channels=};channelsearch=`expandlist $arg` ;;
|
||||
-ids=*) arg=${opt#-ids=}; idsearch=`expandlist $arg` ;;
|
||||
-channels=*) arg=${opt#-channels=};opt_channelsearch=`expandlist $arg` ;;
|
||||
-ids=*) arg=${opt#-ids=}; opt_idsearch=`expandlist $arg` ;;
|
||||
-luns=*) arg=${opt#-luns=}; lunsearch=`expandlist $arg` ;;
|
||||
-color) setcolor ;;
|
||||
-nooptscan) optscan=0 ;;
|
||||
-issue-lip) lipreset=1 ;;
|
||||
-sync) sync=2 ;;
|
||||
-nosync) sync=0 ;;
|
||||
-attachpq3) scan_flags=$(($scan_flags|0x1000000)) ;;
|
||||
-reportlun2) scan_flags=$(($scan_flags|0x20000)) ;;
|
||||
-largelun) scan_flags=$(($scan_flags|0x200)) ;;
|
||||
-sparselun) scan_flags=$((scan_flags|0x40)) ;;
|
||||
*) echo "Unknown option -$opt !" ;;
|
||||
esac
|
||||
shift
|
||||
@ -535,9 +686,26 @@ done
|
||||
|
||||
# Hosts given ?
|
||||
if test "@$1" != "@"; then
|
||||
hosts=$*;
|
||||
hosts=$*
|
||||
fi
|
||||
|
||||
if [ -d /sys/class/scsi_host -a ! -w /sys/class/scsi_host ]; then
|
||||
echo "You need to run scsi-rescan-bus.sh as root"
|
||||
exit 2
|
||||
fi
|
||||
if test "$sync" = 1 -a "$remove" = 1; then sync=2; fi
|
||||
if test "$sync" = 2; then echo "Syncing file systems"; sync; fi
|
||||
if test -w /sys/module/scsi_mod/parameters/default_dev_flags -a $scan_flags != 0; then
|
||||
OLD_SCANFLAGS=`cat /sys/module/scsi_mod/parameters/default_dev_flags`
|
||||
NEW_SCANFLAGS=$(($OLD_SCANFLAGS|$scan_flags))
|
||||
if test "$OLD_SCANFLAGS" != "$NEW_SCANFLAGS"; then
|
||||
echo -n "Temporarily setting kernel scanning flags from "
|
||||
printf "0x%08x to 0x%08x\n" $OLD_SCANFLAGS $NEW_SCANFLAGS
|
||||
echo $NEW_SCANFLAGS > /sys/module/scsi_mod/parameters/default_dev_flags
|
||||
else
|
||||
unset OLD_SCANFLAGS
|
||||
fi
|
||||
fi
|
||||
echo "Scanning SCSI subsystem for new devices"
|
||||
test -z "$remove" || echo " and remove devices that have disappeared"
|
||||
declare -i found=0
|
||||
@ -548,25 +716,40 @@ for host in $hosts; do
|
||||
# It's pointless to do a target scan on FC
|
||||
if test -n "$lipreset" ; then
|
||||
echo 1 > /sys/class/fc_host/host$host/issue_lip 2> /dev/null;
|
||||
echo "- - -" > /sys/class/scsi_host/host$host/scan 2> /dev/null;
|
||||
udevadm_settle
|
||||
fi
|
||||
channelsearch=""
|
||||
idsearch=""
|
||||
# We used to always trigger a rescan for FC to update channels and targets
|
||||
# Commented out -- as discussed with Hannes we should rely
|
||||
# on the main loop doing the scan, no need to do it here.
|
||||
#echo "- - -" > /sys/class/scsi_host/host$host/scan 2> /dev/null;
|
||||
#udevadm_settle
|
||||
channelsearch=
|
||||
idsearch=
|
||||
else
|
||||
channelsearch=$opt_channelsearch
|
||||
idsearch=$opt_idsearch
|
||||
fi
|
||||
[ -n "$channelsearch" ] && echo -n "channels $channelsearch "
|
||||
echo -n "for "
|
||||
if [ -n "$idsearch" ] ; then
|
||||
echo -n " SCSI target IDs " $idsearch
|
||||
echo -n " SCSI target IDs " $idsearch
|
||||
else
|
||||
echo -n " all SCSI target IDs"
|
||||
echo -n " all SCSI target IDs"
|
||||
fi
|
||||
if [ -n "$lunsearch" ] ; then
|
||||
echo ", LUNs " $lunsearch
|
||||
echo ", LUNs " $lunsearch
|
||||
else
|
||||
echo ", all LUNs"
|
||||
echo ", all LUNs"
|
||||
fi
|
||||
dosearch;
|
||||
dosearch
|
||||
done
|
||||
if test -n "$OLD_SCANFLAGS"; then
|
||||
echo $OLD_SCANFLAGS > /sys/module/scsi_mod/parameters/default_dev_flags
|
||||
fi
|
||||
echo "$found new device(s) found. "
|
||||
echo "$rmvd device(s) removed. "
|
||||
|
||||
# Local Variables:
|
||||
# sh-basic-offset: 2
|
||||
# End:
|
||||
|
||||
|
@ -1,3 +0,0 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:8ea682e51dc45209d8af91366fb4a15ea553152ce8a57928fa00b33b8f091d68
|
||||
size 696939
|
3
sg3_utils-1.33.tgz
Normal file
3
sg3_utils-1.33.tgz
Normal file
@ -0,0 +1,3 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:3034a4e798404cc963fc46437b0ceeb0edc635e02471ab13aa18acd8b716a27b
|
||||
size 952354
|
@ -1,3 +1,52 @@
|
||||
-------------------------------------------------------------------
|
||||
Sun Apr 22 11:50:44 UTC 2012 - puzel@suse.com
|
||||
|
||||
- Update to version 1.33
|
||||
- sg_ses: major rework of indexes (again), now two level
|
||||
- sg_write_buffer: new --specific option for mode specific
|
||||
field; new mode 13 (spc4r32)
|
||||
- sg_vpd: add hp3par volume info vendor VPD page
|
||||
- fix 'scsi ports' [0x88] page problem
|
||||
- add 'sinq' pseudo page for standard inquiry response
|
||||
- add power consumption page
|
||||
- sg_format: add --poll= option for request sense polling
|
||||
- improve handling of disks > 2 TB and DIF (protection)
|
||||
- sg_logs: LB provision lpage extra (sbc3r28)
|
||||
- sg_modes: application tag mpage subcode 0xf0->0x2
|
||||
- sg_write_same: no prot fields when wrprotect=0
|
||||
- sg_get_lba_status: reflect change in sbc3r25 to Parameter
|
||||
Data Length response field (offset reduced from 8 to 4)
|
||||
- sg_inq, sg_vpd: sync with spc4r33
|
||||
- win32: change DataBufferOffset type per MSDN; caused
|
||||
problem with 64 bit machines (with buffered interface)
|
||||
- sg_luns: tweak documentation for vendor specific reports
|
||||
- add man pages for scsi_loging_level, scsi_mandat,
|
||||
scsi_satl and scsi_temperature
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Mon Jan 16 19:59:42 UTC 2012 - tabraham@novell.com
|
||||
|
||||
- Update to version 1.32
|
||||
+ sg_sanitize: new utility for command added in sb3r27
|
||||
+ sg_sat_identify: add '--ident' to output WWN
|
||||
+ sg_ses: major rework of descriptor output
|
||||
+ add --index, --descriptor, --join, --clear, --get, and --set
|
||||
options
|
||||
+ sg_raw: exit status corrections
|
||||
+ sg_decode_sense: add --nospace and --hex options
|
||||
+ sg_logs: fix bug with large --maxlen
|
||||
+ zero response length when resid implies it is invalid
|
||||
+ add scope field to lb provisioning lpage (sb3r27)
|
||||
+ sg_inq: sync version descriptors with spc4r31
|
||||
+ sb_lib_data: sync asc/ascq codes with spc4r31
|
||||
+ sg_vpd: add LBPRZ field in LP provisioning VPD page
|
||||
+ sg_format: allow format of pdt 7 (some MO drives)
|
||||
+ sg_cmd_basic: sg_cmds_process_resp() handle status good
|
||||
with a sense key other than no_sense (e.g. completed)
|
||||
+ add README.iscsi
|
||||
|
||||
- Updated rescan-scsi-bus.sh to v1.56
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Thu Mar 10 08:47:43 UTC 2011 - coolo@novell.com
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
#
|
||||
# spec file for package sg3_utils
|
||||
#
|
||||
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||
# Copyright (c) 2012 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
@ -16,22 +16,20 @@
|
||||
#
|
||||
|
||||
|
||||
Url: http://sg.torque.net/sg/sg3_utils.html
|
||||
Url: http://sg.danny.cz/sg/sg3_utils.html
|
||||
|
||||
Name: sg3_utils
|
||||
%define sgver 1.31
|
||||
Version: 1.33
|
||||
Release: 0
|
||||
Summary: A collection of tools that send SCSI commands to devices
|
||||
License: BSD-3-Clause ; GPL-2.0 ; GPL-2.0+
|
||||
Group: Hardware/Other
|
||||
Provides: sg_utils
|
||||
Provides: scsi
|
||||
Obsoletes: scsi <= 1.7_2.38_1.25_0.19_1.02_0.93
|
||||
AutoReqProv: on
|
||||
PreReq: %insserv_prereq
|
||||
Version: 1.31
|
||||
Release: 1
|
||||
Summary: A collection of tools that send SCSI commands to devices
|
||||
Source: http://sg.torque.net/sg/p/sg3_utils-%{sgver}.tar.bz2
|
||||
Source: http://sg.danny.cz/sg/p/sg3_utils-%{version}.tgz
|
||||
Source2: http://www.garloff.de/kurt/linux/rescan-scsi-bus.sh
|
||||
Requires(pre): %insserv_prereq
|
||||
Provides: scsi
|
||||
Provides: sg_utils
|
||||
Obsoletes: scsi <= 1.7_2.38_1.25_0.19_1.02_0.93
|
||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||
|
||||
%description
|
||||
@ -43,11 +41,10 @@ ATAPI cd/dvd drives and SATA disks that connect via a translation layer
|
||||
or a bridge device are examples of devices that use SCSI command sets.
|
||||
|
||||
%package devel
|
||||
License: BSD-3-Clause ; GPL-2.0+
|
||||
Summary: A collection of tools that send SCSI commands to devices
|
||||
License: BSD-3-Clause ; GPL-2.0+
|
||||
Group: Development/Libraries/C and C++
|
||||
AutoReqProv: on
|
||||
Requires: %name = %version
|
||||
Requires: %{name} = %{version}
|
||||
|
||||
%description devel
|
||||
The sg3_utils package contains utilities that send SCSI commands to
|
||||
@ -88,7 +85,7 @@ install -m 755 %{S:2} $RPM_BUILD_ROOT%{_bindir}
|
||||
%attr(755,root,root) %{_bindir}/sg_map
|
||||
%attr(755,root,root) %{_bindir}/sg_turs
|
||||
%attr(755,root,root) %{_bindir}/sg_test_rwbuf
|
||||
#%attr(755,root,root) %{_bindir}/scsi_devfs_scan
|
||||
#%%attr(755,root,root) %%{_bindir}/scsi_devfs_scan
|
||||
%attr(755,root,root) %{_bindir}/sgm_dd
|
||||
%attr(755,root,root) %{_bindir}/sg_read
|
||||
%attr(755,root,root) %{_bindir}/sg_logs
|
||||
@ -133,6 +130,7 @@ install -m 755 %{S:2} $RPM_BUILD_ROOT%{_bindir}
|
||||
%attr(755,root,root) %{_bindir}/sg_write_same
|
||||
%attr(755,root,root) %{_bindir}/sg_decode_sense
|
||||
%attr(755,root,root) %{_bindir}/sg_referrals
|
||||
%attr(755,root,root) %{_bindir}/sg_sanitize
|
||||
%doc %{_mandir}/man8/sg_dd.8.gz
|
||||
%doc %{_mandir}/man8/sgp_dd.8.gz
|
||||
%doc %{_mandir}/man8/sgm_dd.8.gz
|
||||
@ -145,7 +143,7 @@ install -m 755 %{S:2} $RPM_BUILD_ROOT%{_bindir}
|
||||
%doc %{_mandir}/man8/sg_turs.8.gz
|
||||
%doc %{_mandir}/man8/sg_inq.8.gz
|
||||
%doc %{_mandir}/man8/sg_test_rwbuf.8.gz
|
||||
#%doc %{_mandir}/man8/scsi_devfs_scan.8.gz
|
||||
#%%doc %%{_mandir}/man8/scsi_devfs_scan.8.gz
|
||||
%doc %{_mandir}/man8/sg_start.8.gz
|
||||
%doc %{_mandir}/man8/sg_reset.8.gz
|
||||
%doc %{_mandir}/man8/sg_modes.8.gz
|
||||
@ -191,24 +189,29 @@ install -m 755 %{S:2} $RPM_BUILD_ROOT%{_bindir}
|
||||
%doc %{_mandir}/man8/sg_write_same.8.gz
|
||||
%doc %{_mandir}/man8/sg_decode_sense.8.gz
|
||||
%doc %{_mandir}/man8/sg_referrals.8.gz
|
||||
%doc %{_mandir}/man8/sg_sanitize.8.gz
|
||||
%doc %{_mandir}/man8/scsi_logging_level.8.gz
|
||||
%doc %{_mandir}/man8/scsi_mandat.8.gz
|
||||
%doc %{_mandir}/man8/scsi_satl.8.gz
|
||||
%doc %{_mandir}/man8/scsi_temperature.8.gz
|
||||
%attr(755,root,root) %{_libdir}/libsgutils2.so.*
|
||||
|
||||
%files devel
|
||||
%defattr(644,root,root)
|
||||
%attr(755,root,root) %{_libdir}/libsgutils2.so
|
||||
%attr(755,root,root) %dir %{_prefix}/include/scsi
|
||||
%{_prefix}/include/scsi/sg_cmds.h
|
||||
%{_prefix}/include/scsi/sg_cmds_basic.h
|
||||
%{_prefix}/include/scsi/sg_cmds_extra.h
|
||||
%{_prefix}/include/scsi/sg_lib.h
|
||||
%{_prefix}/include/scsi/sg_pt.h
|
||||
%{_prefix}/include/scsi/sg_io_linux.h
|
||||
%{_prefix}/include/scsi/sg_linux_inc.h
|
||||
%{_prefix}/include/scsi/sg_cmds_mmc.h
|
||||
%{_prefix}/include/scsi/sg_lib_data.h
|
||||
%{_includedir}/scsi/sg_cmds.h
|
||||
%{_includedir}/scsi/sg_cmds_basic.h
|
||||
%{_includedir}/scsi/sg_cmds_extra.h
|
||||
%{_includedir}/scsi/sg_lib.h
|
||||
%{_includedir}/scsi/sg_pt.h
|
||||
%{_includedir}/scsi/sg_io_linux.h
|
||||
%{_includedir}/scsi/sg_linux_inc.h
|
||||
%{_includedir}/scsi/sg_cmds_mmc.h
|
||||
%{_includedir}/scsi/sg_lib_data.h
|
||||
|
||||
%clean
|
||||
test ! -z "$RPM_BUILD_ROOT" -a "$RPM_BUILD_ROOT" != "/" && rm -rf $RPM_BUILD_ROOT
|
||||
rm -rf $RPM_BUILD_DIR/sg3_utils-%{sgver}
|
||||
rm -rf $RPM_BUILD_DIR/sg3_utils-%{version}
|
||||
|
||||
%changelog
|
||||
|
Loading…
x
Reference in New Issue
Block a user