diff options
author | Diego Elio Pettenò <flameeyes@gentoo.org> | 2005-10-31 18:39:21 +0000 |
---|---|---|
committer | Diego Elio Pettenò <flameeyes@gentoo.org> | 2005-10-31 18:39:21 +0000 |
commit | cdb8e41eb0ff3c8bfc982bc351b27ffc23cf9253 (patch) | |
tree | 25ebf748a259ab43bec2202557a2ce0b6f5a711d /media-sound/alsa-utils | |
parent | Also apply GGC3.3 patch for GCC4. Allows compilation on ppc-macos, marked ~p... (diff) | |
download | historical-cdb8e41eb0ff3c8bfc982bc351b27ffc23cf9253.tar.gz historical-cdb8e41eb0ff3c8bfc982bc351b27ffc23cf9253.tar.bz2 historical-cdb8e41eb0ff3c8bfc982bc351b27ffc23cf9253.zip |
Don't fail if restoring a card fails. See bug #100911.
Package-Manager: portage-2.0.53_rc7
Diffstat (limited to 'media-sound/alsa-utils')
-rw-r--r-- | media-sound/alsa-utils/ChangeLog | 6 | ||||
-rw-r--r-- | media-sound/alsa-utils/Manifest | 11 | ||||
-rw-r--r-- | media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild | 4 | ||||
-rw-r--r-- | media-sound/alsa-utils/files/alsasound-1.0.10_rc2 | 251 |
4 files changed, 264 insertions, 8 deletions
diff --git a/media-sound/alsa-utils/ChangeLog b/media-sound/alsa-utils/ChangeLog index 1e093e27e3bb..7d247d099e79 100644 --- a/media-sound/alsa-utils/ChangeLog +++ b/media-sound/alsa-utils/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for media-sound/alsa-utils # Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/ChangeLog,v 1.111 2005/10/11 15:37:59 flameeyes Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/ChangeLog,v 1.112 2005/10/31 18:39:21 flameeyes Exp $ + + 31 Oct 2005; Diego Pettenò <flameeyes@gentoo.org> + +files/alsasound-1.0.10_rc2, alsa-utils-1.0.10_rc2.ebuild: + Don't fail if restoring a card fails. See bug #100911. *alsa-utils-1.0.10_rc2 (11 Oct 2005) diff --git a/media-sound/alsa-utils/Manifest b/media-sound/alsa-utils/Manifest index 8105b1084323..15c3191cbd01 100644 --- a/media-sound/alsa-utils/Manifest +++ b/media-sound/alsa-utils/Manifest @@ -1,8 +1,8 @@ -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 -MD5 5d106e9f656e285c92570f9ed1dc9650 ChangeLog 17267 -MD5 7386ee7a3dc291848d8a3ada711ded07 alsa-utils-1.0.10_rc2.ebuild 2566 +MD5 d278ade7c05118f36156c02bb8b84f22 ChangeLog 17439 +MD5 6d8d0ddc510916e4f644f6643d763226 alsa-utils-1.0.10_rc2.ebuild 2588 MD5 a2a37bf9cb817343a6a58e20cfea9bb8 alsa-utils-1.0.7.ebuild 2272 MD5 26f5354615b23de013a20117251274ee alsa-utils-1.0.8.ebuild 2269 MD5 d9b19e1fc31acdd0b7091ce79400ce85 alsa-utils-1.0.9a-r1.ebuild 2525 @@ -12,6 +12,7 @@ MD5 6945018085dd4204d2f26490fb7b50b6 files/alsa-utils-1.0.10_rc1-largefile.patch MD5 4d2059fdfeeafe53e5d42692d9c2f14e files/alsa-utils-1.0.10_rc1-nls.patch 1959 MD5 504c2047f55a094833631892ab099ada files/alsa-utils-1.0.9a-strsignal.patch 454 MD5 2a50971b115f63d74d0054c7e3ee9144 files/alsasound 7106 +MD5 9224c89a555eeabd60baff541b5996b2 files/alsasound-1.0.10_rc2 7150 MD5 f4f492c382b243ebf558809a372fd6b7 files/alsasound.confd 515 MD5 5583841a2a5a206ad2838524c2cc7528 files/digest-alsa-utils-1.0.10_rc2 73 MD5 ddaf1d5cc1a19dff65e19e6470bc711d files/digest-alsa-utils-1.0.7 69 @@ -22,7 +23,7 @@ MD5 a1eaeb2ae801daeb712c90c060e922dc metadata.xml 158 -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.2 (GNU/Linux) -iD8DBQFDS9x3j5H05b2HAEkRAlGUAJ9SEJeO4jWgAqdM7uLAQAgtiUTgnwCfcr2n -TFyB3AuhuduYD3QOtZIKnmk= -=siQ8 +iD8DBQFDZmT1j5H05b2HAEkRAvy+AJ9c4aJhv9Go1Q+j2i74IOwwbIcLeACfduYv +P5CbIkB077EcPTLvqd5w/a4= +=JjbB -----END PGP SIGNATURE----- diff --git a/media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild b/media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild index 4f2694070c73..cb0400a1f5ed 100644 --- a/media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild +++ b/media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2005 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild,v 1.1 2005/10/11 15:37:59 flameeyes Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/alsa-utils-1.0.10_rc2.ebuild,v 1.2 2005/10/31 18:39:21 flameeyes Exp $ inherit eutils flag-o-matic autotools @@ -53,7 +53,7 @@ src_install() { newconfd ${FILESDIR}/alsasound.confd alsasound insinto /etc/modules.d newins ${FILESDIR}/alsa-modules.conf-rc alsa - doinitd ${FILESDIR}/alsasound + newinitd ${FILESDIR}/alsasound-1.0.10_rc2 alsasound } pkg_postinst() { diff --git a/media-sound/alsa-utils/files/alsasound-1.0.10_rc2 b/media-sound/alsa-utils/files/alsasound-1.0.10_rc2 new file mode 100644 index 000000000000..dfe51b71454d --- /dev/null +++ b/media-sound/alsa-utils/files/alsasound-1.0.10_rc2 @@ -0,0 +1,251 @@ +#!/sbin/runscript +# $Header: /var/cvsroot/gentoo-x86/media-sound/alsa-utils/files/alsasound-1.0.10_rc2,v 1.1 2005/10/31 18:39:21 flameeyes Exp $ +# +# Gentoo users: add this script to 'boot' run level. +# ================================================== +# +# alsasound This shell script takes care of starting and stopping +# the ALSA sound driver. +# +# This script requires /usr/sbin/alsactl and /usr/bin/aconnect programs +# from the alsa-utils package. +# +# Copyright (c) by Jaroslav Kysela <perex@suse.cz> +# +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + +# ChangeLog: +# +# 2003.07.29 - John Mylchreest <johnm@gentoo.org> +# Edited to support Linux kernel 2.5 and above as well as 2.4 +# +# 2004.06.02 - Jeremy Huddleston <eradicator@gentoo.org> +# Rewritten for better support for built-in drivers +# +# 2004.10.29 - Jeremy Huddleston <eradicator@gentoo.org> +# Cleaned up to work better for mixed builtin/module systems +# +# 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 +aconnect=/usr/bin/aconnect +alsascrdir=/etc/alsa.d + +opts="${opts} save" + +depend() { + need bootmisc localmount + after modules isapnp coldplug hotplug +} + +load_modules() { + # List of drivers for each card. + 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 + 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?" + fi + + if [[ ${ENABLE_OSS_EMUL} == "yes" ]] && modprobe -c | grep -q "snd.*oss$" ; then + # Test for use of OSS + 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}" + done + fi + + # We want to ensure snd-seq is loaded as it is needed for things like + # timidity even if we don't use a real sequencer. + DRIVERS="${DRIVERS} $(modprobe -l | grep "snd.seq\." | sed -e "s:\/.*\/::" -e "s:\..*::")" + + # We want to ensure snd-ioctl32 is loaded as it is needed for 32bit + # 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 + ebegin " Loading: ${DRIVER}" + /sbin/modprobe ${DRIVER} + eend $? + fi + done + + sleep 1 + + 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 + ebegin " Loading: ${SEQUENCER}" + /sbin/modprobe ${SEQUENCER} + eend $? + fi + done + fi + + for DRIVER in ${DRIVERS} + do + local TMP=${DRIVER##snd-} + TMP=${TMP##snd_} + if [[ -x "${alsascrdir}/${TMP}" ]] ; then + ebegin " Running: ${alsascrdir}/${TMP}" + ${alsascrdir}/${TMP} + eend $? + fi + done + + if [[ ! -d /proc/asound || -n "$(grep ' no soundcards ' /proc/asound/cards)" ]] ; then + eerror "ERROR: Failed to load necessary drivers" + fi +} + +unload_modules() { + local LOADED_MODULES="$(/sbin/lsmod | grep -E "^snd" | awk '{print $1}')" + local MODULE + for MODULE in ${LOADED_MODULES} + do + /sbin/rmmod ${MODULE} >& /dev/null + done + /sbin/rmmod soundcore >& /dev/null + /sbin/rmmod gameport >& /dev/null + + # Return success if the modules are unloaded + [[ -z "$(/sbin/lsmod | grep -E "^snd" | awk '{print $1}')" ]] +} + +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/*` + 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" + 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 && -x ${aconnect} ]] && ${aconnect} --removeall +} + +restore_mixer() { + 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} || ewarn "Errors while restoring defaults, ignoring" + done + else + eerror -e "ERROR: Cannot find alsactl, did you forget to install media-sound/alsa-utils?" + val=1 + fi + + eend ${val} + return ${val} +} + +save() { + ebegin "Storing ALSA Mixer Levels" + + local val=0 + + if [[ -x ${alsactl} ]] ; then + ${alsactl} -f ${asoundcfg} store + val=$? + else + eerror -e "ERROR: Cannot find alsactl." + val=1 + fi + + eend ${val} + return ${val} +} + +start() { + if [[ -f /proc/modules ]] ; then + ebegin "Loading ALSA modules" + if load_modules ; then + eend 0 + else + eend 1 + return 1 + fi + fi + + if [[ ${RESTORE_ON_START} == "yes" ]]; then + restore_mixer + fi +} + +stop() { + if [[ ! -d /proc/asound ]] ; then + eerror "ALSA is not loaded" + return 0 + fi + + if [[ ${SAVE_ON_STOP} == "yes" ]]; then + save + fi + + ebegin "Unloading ALSA" + terminate + eend 0 + + if [[ -f /proc/modules ]]; then + ebegin "Unloading ALSA modules" + if unload_modules; then + eend 0 + else + eend 1 + fi + fi +} |