aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--testing/hdparm/APKBUILD12
-rw-r--r--testing/hdparm/hdparm.confd26
-rw-r--r--testing/hdparm/hdparm.initd142
3 files changed, 177 insertions, 3 deletions
diff --git a/testing/hdparm/APKBUILD b/testing/hdparm/APKBUILD
index 38ca77c67d..f9fb4bf9b4 100644
--- a/testing/hdparm/APKBUILD
+++ b/testing/hdparm/APKBUILD
@@ -1,14 +1,16 @@
# Maintainer: Natanael Copa <ncopa@alpinelinux.org>
pkgname=hdparm
pkgver=9.27
-pkgrel=0
+pkgrel=1
pkgdesc="A shell utility for manipulating Linux IDE drive/driver parameters"
url="http://sourceforge.net/projects/hdparm/"
license="BSD"
depends=
makedepends=
subpackages="$pkgname-doc"
-source="http://downloads.sourceforge.net/sourceforge/$pkgname/$pkgname-$pkgver.tar.gz"
+source="http://downloads.sourceforge.net/sourceforge/$pkgname/$pkgname-$pkgver.tar.gz
+ hdparm.initd
+ hdparm.confd"
_builddir="$srcdir"/$pkgname-$pkgver
build() {
@@ -22,6 +24,10 @@ package() {
make DESTDIR="$pkgdir" install || return 1
install -m755 contrib/idectl "$pkgdir"/sbin || return 1
install -m755 contrib/ultrabayd "$pkgdir"/sbin || return 1
+ install -Dm755 "$srcdir"/hdparm.initd "$pkgdir"/etc/init.d/hdparm
+ install -Dm644 "$srcdir"/hdparm.confd "$pkgdir"/etc/conf.d/hdparm
install -D -m 644 LICENSE.TXT $pkgdir/usr/share/licenses/hdparm/LICENSE.TXT || return 1
}
-md5sums="e652dabb6c9233fb8a23ef60a17a1829 hdparm-9.27.tar.gz"
+md5sums="e652dabb6c9233fb8a23ef60a17a1829 hdparm-9.27.tar.gz
+d530139a31b3941b3b0fbb4d98391a85 hdparm.initd
+998430f701b1d54588cb02ef1505c3ed hdparm.confd"
diff --git a/testing/hdparm/hdparm.confd b/testing/hdparm/hdparm.confd
new file mode 100644
index 0000000000..a1ae626b3b
--- /dev/null
+++ b/testing/hdparm/hdparm.confd
@@ -0,0 +1,26 @@
+# /etc/conf.d/hdparm: config file for /etc/init.d/hdparm
+
+#
+# Note that options such as -y which force *immediate* power saving options
+# should generally not be placed here. The hdparm init.d script may run at
+# anytime with respect to other init.d scripts that do system wide drive
+# scans (like the hald script), so they will merely get spun right back up.
+# If you wish to use these options, please use the local.start init.d script
+# instead so that you're guaranteed that it will run last.
+#
+
+# You can either set hdparm arguments for each drive using hdX_args,
+# discX_args, cdromX_args and genericX_args, e.g.
+#
+# hda_args="-d1 -X66"
+# disc1_args="-d1"
+# cdrom0_args="-d1"
+
+# or you can set options for all PATA drives
+pata_all_args="-d1"
+
+# or you can set options for all SATA drives
+sata_all_args=""
+
+# or, you can set hdparm options for all drives
+all_args=""
diff --git a/testing/hdparm/hdparm.initd b/testing/hdparm/hdparm.initd
new file mode 100644
index 0000000000..89aa4f82b7
--- /dev/null
+++ b/testing/hdparm/hdparm.initd
@@ -0,0 +1,142 @@
+#!/sbin/runscript
+# METHOD
+# ------
+# if /dev/ide exists, find all block devices beneath it named disc, cd, or
+# generic.
+#
+# for the disc and cd ones, if there is a a matching /dev/hdX symlink and
+# hdX_args is set in the config file, use hdX_args. otherwise, if there is a
+# matching /dev/discs/discX or /dev/cdroms/cdromX symlink, and discX_args or
+# cdromX_args is set in the config file, use discX_args / cdromX_args. finally,
+# if all_args is set in the config file, use that.
+#
+# for the generic ones, sort them and look for genericX_args in the config file
+# or use all_args.
+#
+# if /dev/ide does not exist, check the /dev/hdX entries, and see which ones
+# correspond to real devices by opening them for reading. then check hdX_args
+# and all_args in the config file.
+#
+# for each device considered, if no args are found in the config file, do not
+# run hdparm.
+
+depend() {
+ before bootmisc
+}
+
+do_hdparm() {
+ local e=
+ eval e=\$${extra_args}
+ [ -z "${args}${all_args}${e}" ] && return 0
+
+ if [ -n "${args:=${all_args} ${e}}" ] ; then
+ local orgdevice=$(readlink -f "${device}")
+ if [ -b "${orgdevice}" ] ; then
+ ebegin "Running hdparm on ${device}"
+ hdparm ${args} "${device}" > /dev/null
+ eend $?
+ fi
+ fi
+}
+
+scan_devfs() {
+ local extra_args="pata_all_args" device= alias= args=
+
+ # devfs compatible systems
+ for device in $(find /dev/ide -name disc) ; do
+ args=''
+
+ for alias in /dev/hd? ; do
+ if [ "${alias}" -ef "${device}" ] ; then
+ device=${alias}
+ eval args=\$"$(basename "${alias}")"_args
+ break
+ fi
+ done
+
+ if [ -z "$args" ] ; then
+ for alias in /dev/discs/* ; do
+ if [ "${alias}"/disc -ef "${device}" ]; then
+ device="${alias}/disc"
+ eval args=\$"$(basename "${alias}")"_args
+ break
+ fi
+ done
+ fi
+
+ do_hdparm
+ done
+
+ for device in $(find /dev/ide -name cd) ; do
+ args=''
+
+ for alias in /dev/hd? ; do
+ if [ "${alias}" -ef "${device}" ] ; then
+ device=${alias}
+ eval args=\$"$(basename "${alias}")"_args
+ break
+ fi
+ done
+
+ if [ -z "$args" ] ; then
+ for alias in /dev/cdroms/* ; do
+ if [ "${alias}" -ef "${device}" ] ; then
+ device=${alias}
+ eval args=\$"$(basename "${alias}")"_args
+ break
+ fi
+ done
+ fi
+
+ do_hdparm
+ done
+
+ local count=0
+ # of course, the sort approach would fail here if any of the
+ # host/bus/target/lun numbers reached 2 digits..
+ for device in $(find /dev/ide -name generic | sort) ; do
+ eval args=\$generic${count}_args
+ do_hdparm
+ count=$((${count} + 1))
+ done
+}
+
+scan_nondevfs() {
+ # non-devfs compatible system
+ for device in /dev/hd* /dev/sd* ; do
+ [ -e "${device}" ] || continue
+ case "${device}" in
+ *[0-9]) continue ;;
+ /dev/hd*) extra_args="pata_all_args" ;;
+ /dev/sd*) extra_args="sata_all_args" ;;
+ *) extra_args="" ;;
+ esac
+
+ # check that the block device really exists by
+ # opening it for reading
+ local errmsg= status= nomed=1
+ errmsg=$(export LC_ALL=C ; : 2>&1 <"${device}")
+ status=$?
+ case ${errmsg} in
+ *": No medium found") nomed=0;;
+ esac
+ if [ -b "${device}" ] && [ "${status}" = "0" -o "${nomed}" = "0" ] ; then
+ local conf_var="${device##*/}_args"
+ eval args=\$${conf_var}
+ do_hdparm
+ fi
+ done
+}
+
+start() {
+ if get_bootparam "nohdparm" ; then
+ ewarn "Skipping hdparm init as requested in kernel cmdline"
+ return 0
+ fi
+
+ if [ -e /dev/.devfsd -a -d /dev/ide ] ; then
+ scan_devfs
+ else
+ scan_nondevfs
+ fi
+}