summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--media-sound/alsa-utils/ChangeLog7
-rw-r--r--media-sound/alsa-utils/files/alsasound115
-rw-r--r--media-sound/alsa-utils/files/alsasound.confd15
3 files changed, 89 insertions, 48 deletions
diff --git a/media-sound/alsa-utils/ChangeLog b/media-sound/alsa-utils/ChangeLog
index 27f259baf186..da2d9283cefd 100644
--- a/media-sound/alsa-utils/ChangeLog
+++ b/media-sound/alsa-utils/ChangeLog
@@ -1,6 +1,11 @@
# ChangeLog for media-sound/alsa-utils
# Copyright 2002-2005 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/ChangeLog,v 1.91 2005/04/12 07:56:46 eradicator Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/ChangeLog,v 1.92 2005/04/21 09:07:45 eradicator Exp $
+
+ 21 Apr 2005; Jeremy Huddleston <eradicator@gentoo.org> files/alsasound,
+ files/alsasound.confd:
+ Cleaned up alsasound init script. Added RESTORE_ON_START and ENABLE_OSS_EMUL
+ options.
12 Apr 2005; Jeremy Huddleston <eradicator@gentoo.org>
-alsa-utils-0.9.8.ebuild, -alsa-utils-1.0.6.ebuild:
diff --git a/media-sound/alsa-utils/files/alsasound b/media-sound/alsa-utils/files/alsasound
index 99f35aa9276a..a5698c50cb52 100644
--- a/media-sound/alsa-utils/files/alsasound
+++ b/media-sound/alsa-utils/files/alsasound
@@ -1,5 +1,5 @@
#!/sbin/runscript
-# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/files/alsasound,v 1.22 2005/01/31 21:44:54 eradicator Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/files/alsasound,v 1.23 2005/04/21 09:07:45 eradicator Exp $
#
# Gentoo users: add this script to 'boot' run level.
# ==================================================
@@ -40,6 +40,10 @@
#
# 2004.11.29 - Jeremy Huddleston <eradicator@gentoo.org>
# Added save option thanks to Ben Anderson <roothorick@new.rr.com>
+#
+# 2005.04.21 - Jeremy Huddleston <eradicator@gentoo.org>
+# Added restore option and oss option.
+# Cleaned up code to use bash builtins instead of test.
alsactl=/usr/sbin/alsactl
asoundcfg=/etc/asound.state
@@ -55,19 +59,20 @@ depend() {
load_modules() {
# List of drivers for each card.
- DRIVERS="$(modprobe -c | grep -E "^[[:space:]]*alias[[:space:]]+snd-card-[[:digit:]]" | awk '{print $2}')"
+ local DRIVERS="$(modprobe -c | grep -E "^[[:space:]]*alias[[:space:]]+snd-card-[[:digit:]]" | awk '{print $2}')"
# Fall back on the automated aliases if we don't have ALSA configured properly...
- if [ -z "${DRIVERS}" ] && ! ([ -d /proc/asound ] && [ -z "$(grep ' no soundcards ' /proc/asound/cards)" ]); then
+ if [[ -z "${DRIVERS}" && ! ( -d /proc/asound && -z "$(grep ' no soundcards ' /proc/asound/cards)" ) ]] ; then
ewarn "Could not detect custom ALSA settings. Loading all detected alsa drivers."
DRIVERS="$(modprobe -c | grep pci: | awk '{ print $3 }' | grep snd.* | sort | uniq)"
- [ -z "${DRIVERS}" ] && eerror "Unable to find any ALSA drivers. Have you compiled alsa-drivers correctly?"
+ [[ -z "${DRIVERS}" ]] && eerror "Unable to find any ALSA drivers. Have you compiled alsa-drivers correctly?"
fi
- if modprobe -c | grep -q "snd.*oss$" ; then
+ if [[ ${ENABLE_OSS_EMUL} == "yes" ]] && modprobe -c | grep -q "snd.*oss$" ; then
# Test for use of OSS
- OSS="$(modprobe -l | grep "snd.*oss" | sed -e "s:\/.*\/::" -e "s:\..*::")"
+ local OSS="$(modprobe -l | grep "snd.*oss" | sed -e "s:\/.*\/::" -e "s:\..*::")"
# Add oss modules to list
+ local i
for i in ${OSS}
do
DRIVERS="${DRIVERS} ${i}"
@@ -82,11 +87,12 @@ load_modules() {
# compatibility
DRIVERS="${DRIVERS} $(modprobe -l | grep "snd.ioctl32\." | sed -e "s:\/.*\/::" -e "s:\..*::")"
+ local DRIVER
for DRIVER in ${DRIVERS}
do
- if [ ! "${DRIVER}" = off ] &&
- [ -z `cut -d' ' -f1 /proc/modules | egrep "^${DRIVER}\$"` ] &&
- [ -z `cut -d' ' -f1 /proc/modules | egrep "^${DRIVER//-/_}\$"` ]; then
+ if [[ "${DRIVER}" != "off" &&
+ -z $(cut -d' ' -f1 /proc/modules | egrep "^${DRIVER}\$") &&
+ -z $(cut -d' ' -f1 /proc/modules | egrep "^${DRIVER//-/_}\$") ]] ; then
ebegin " Loading: ${DRIVER}"
/sbin/modprobe ${DRIVER}
eend $?
@@ -95,12 +101,13 @@ load_modules() {
sleep 1
- if [ -f /proc/asound/seq/drivers ] ; then
- SEQUENCERS="$(awk -F, '$2~/^empty$/ {print $1}' /proc/asound/seq/drivers)"
+ if [[ -f /proc/asound/seq/drivers ]] ; then
+ local SEQUENCERS="$(awk -F, '$2~/^empty$/ {print $1}' /proc/asound/seq/drivers)"
+ local SEQUENCER
for SEQUENCER in ${SEQUENCERS}
do
- if [ -z `cut -d' ' -f1 /proc/modules | egrep "^${SEQUENCER}\$"` ] &&
- [ -z `cut -d' ' -f1 /proc/modules | egrep "^${SEQUENCER//-/_}\$"` ]; then
+ if [[ -z $(cut -d' ' -f1 /proc/modules | egrep "^${SEQUENCER}\$") &&
+ -z $(cut -d' ' -f1 /proc/modules | egrep "^${SEQUENCER//-/_}\$") ]] ; then
ebegin " Loading: ${SEQUENCER}"
/sbin/modprobe ${SEQUENCER}
eend $?
@@ -110,22 +117,23 @@ load_modules() {
for DRIVER in ${DRIVERS}
do
- TMP=${DRIVER##snd-}
+ local TMP=${DRIVER##snd-}
TMP=${TMP##snd_}
- if [ -x "${alsascrdir}/${TMP}" ]; then
+ if [[ -x "${alsascrdir}/${TMP}" ]] ; then
ebegin " Running: ${alsascrdir}/${TMP}"
${alsascrdir}/${TMP}
eend $?
fi
done
- if [ ! -d /proc/asound ] || [ ! -z "$(grep ' no soundcards ' /proc/asound/cards)" ]; then
+ if [[ ! -d /proc/asound || -n "$(grep ' no soundcards ' /proc/asound/cards)" ]] ; then
eerror "ERROR: Failed to load necessary drivers"
fi
}
unload_modules() {
- LOADED_MODULES="$(/sbin/lsmod | grep -E "^snd" | awk '{print $1}')"
+ local LOADED_MODULES="$(/sbin/lsmod | grep -E "^snd" | awk '{print $1}')"
+ local MODULE
for MODULE in ${LOADED_MODULES}
do
/sbin/rmmod ${MODULE} >& /dev/null
@@ -134,7 +142,7 @@ unload_modules() {
/sbin/rmmod gameport >& /dev/null
# Return success if the modules are unloaded
- test -z "$(/sbin/lsmod | grep -E "^snd" | awk '{print $1}')"
+ [[ -z "$(/sbin/lsmod | grep -E "^snd" | awk '{print $1}')" ]]
}
terminate() {
@@ -142,58 +150,71 @@ terminate() {
# Kill processes holding open sound devices
#
# DEVS=`find /dev/ -follow -type c -maxdepth 1 -print 2>/dev/null | xargs ls -dils | grep "1*1[46]," | cut -d: -f2 | cut -d" " -f2; echo /proc/asound/dev/*`
- ossdevs="/dev/admmidi? /dev/adsp? /dev/amidi? /dev/audio* /dev/dmfm* \
+ local ossdevs="/dev/admmidi? /dev/adsp? /dev/amidi? /dev/audio* /dev/dmfm* \
/dev/dmmidi? /dev/dsp* /dev/dspW* /dev/midi0? /dev/mixer? /dev/music \
/dev/patmgr? /dev/sequencer* /dev/sndstat"
- alsadevs="/proc/asound/dev/* /dev/sound/* /dev/snd/*"
- fuser -k $ossdevs $alsadevs 2> /dev/null 1>/dev/null
+ local alsadevs="/proc/asound/dev/* /dev/sound/* /dev/snd/*"
+ fuser -k ${ossdevs} ${alsadevs} >& /dev/null
#
# remove all sequencer connections if any
#
- [ -f /proc/asound/seq/clients -a -x $aconnect ] && $aconnect --removeall
+ [[ -f /proc/asound/seq/clients && -x ${aconnect} ]] && ${aconnect} --removeall
}
restore_mixer() {
- if [ ! -r $asoundcfg ]; then
- ewarn "No mixer config in $asoundcfg, you have to unmute your card!"
- elif [ -x $alsactl ]; then
- CARDS="$(cat /proc/asound/cards | awk '/: / { print $1 }')"
+ if [[ ${RESTORE_ON_START} == "no" ]] ; then
+ return 0
+ fi
+
+ ebegin "Restoring Mixer Levels"
+
+ local val=0
+
+ if [[ ! -r ${asoundcfg} ]] ; then
+ ewarn "No mixer config in ${asoundcfg}, you have to unmute your card!"
+ elif [[ -x ${alsactl} ]] ; then
+ local CARDS="$(cat /proc/asound/cards | awk '/: / { print $1 }')"
+ local CARDNUM
for CARDNUM in ${CARDS}
do
- [ -e /dev/snd/controlC0 ] || sleep 2
- [ -e /dev/snd/controlC0 ] || sleep 2
- [ -e /dev/snd/controlC0 ] || sleep 2
- [ -e /dev/snd/controlC0 ] || sleep 2
- $alsactl -f $asoundcfg restore ${CARDNUM}
+ [[ -e /dev/snd/controlC0 ]] || sleep 2
+ [[ -e /dev/snd/controlC0 ]] || sleep 2
+ [[ -e /dev/snd/controlC0 ]] || sleep 2
+ [[ -e /dev/snd/controlC0 ]] || sleep 2
+ ${alsactl} -f ${asoundcfg} restore ${CARDNUM}
+ ((val=val+$?))
done
else
eerror -e "ERROR: Cannot find alsactl, did you forget to install media-sound/alsa-utils?"
- return 1
+ val=1
fi
- return 0
+ eend ${val}
+ return ${val}
}
save() {
ebegin "Storing ALSA Mixer Levels"
+
+ local val=0
- if [ -x $alsactl ]; then
- $alsactl -f $asoundcfg store
+ if [[ -x ${alsactl} ]] ; then
+ ${alsactl} -f ${asoundcfg} store
val=$?
- eend $val
- return $val
else
eerror -e "ERROR: Cannot find alsactl."
- eend 1
- return 1
+ val=1
fi
+
+ eend ${val}
+ return ${val}
}
start() {
- if [ -f /proc/modules ]; then
+ if [[ -f /proc/modules ]] ; then
ebegin "Loading ALSA modules"
- if load_modules; then
+ if load_modules ; then
eend 0
else
eend 1
@@ -201,18 +222,18 @@ start() {
fi
fi
- ebegin "Restoring Mixer Levels"
- restore_mixer
- eend $?
+ if [[ ${RESTORE_ON_START} == "yes" ]]; then
+ restore_mixer
+ fi
}
stop() {
- if [ ! -d /proc/asound ] ; then
+ if [[ ! -d /proc/asound ]] ; then
eerror "ALSA is not loaded"
return 0
fi
- if [ "${SAVE_ON_STOP}" = "yes" ]; then
+ if [[ ${SAVE_ON_STOP} == "yes" ]]; then
save
fi
@@ -220,7 +241,7 @@ stop() {
terminate
eend 0
- if [ -f /proc/modules ]; then
+ if [[ -f /proc/modules ]]; then
ebegin "Unloading ALSA modules"
if unload_modules; then
eend 0
diff --git a/media-sound/alsa-utils/files/alsasound.confd b/media-sound/alsa-utils/files/alsasound.confd
index 7be75537b602..6e82cdd32e95 100644
--- a/media-sound/alsa-utils/files/alsasound.confd
+++ b/media-sound/alsa-utils/files/alsasound.confd
@@ -1,3 +1,18 @@
+# ENABLE_OSS_EMUL:
+# Do you want to enable in-kernel oss emulation?
+# no - Do not load oss emul drivers
+# yes - Load oss emul drivers if they're found
+
+ENABLE_OSS_EMUL="yes"
+
+# RESTORE_ON_START:
+# Do you want to restore your mixer settings? If not, your cards will be
+# muted.
+# no - Do not restore state
+# yes - Restore state
+
+RESTORE_ON_START="yes"
+
# SAVE_ON_STOP:
# Do you want to save changes made to your mixer volumes when alsasound
# stops?