/usr/bin/scsi_stop is in sg3-utils 1.36-1ubuntu1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 | #!/bin/bash
################################################
#
# Spin down the given SCS disk(s).
#
# SCSI disks (or disks that understand SCSI commands)
# are assumed. By default, the immediate bit is set so the
# command should return immediately. The disk however will
# take 10 seconds or more to spin down. The '-w' option
# causes each stop to wait until the disk reports that it
# has stopped.
#
# This script assumes the sg3_utils package is installed.
#
###############################################
verbose=""
immediate="-i"
usage()
{
echo "Usage: scsi_stop [-h] [-v] [-w] <device>+"
echo " where:"
echo " -h, --help print usage message"
echo " -v, --verbose more verbose output"
echo " -w, --wait wait for each stop to complete"
echo ""
echo "Send SCSI START STOP UNIT command to stop each <device>"
}
opt="$1"
while test ! -z "$opt" -a -z "${opt##-*}"; do
opt=${opt#-}
case "$opt" in
h|-help) usage ; exit 0 ;;
v|-verbose) verbose="-v" ;;
w|-wait) immediate="" ;;
*) echo "Unknown option: -$opt " ; exit 1 ;;
esac
shift
opt="$1"
done
if [ $# -lt 1 ]
then
usage
exit 1
fi
for i
do
# Use '-r' (read-only) otherwise using a block device node
# (e.g. 'sg_start 0 /dev/sdb') can result in a change of state
# event causing the disk to spin up again immediately.
echo "sg_start -r $immediate 0 $verbose $i"
sg_start -r $immediate 0 $verbose $i
done
|