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 | d8a44b9403b51b0a411b6cf8f7b0dc9ef2ff78a8 (patch) | |
tree | 3015af8d3553443b0e90e17eacb61c17275a17a9 /media-sound | |
parent | Also apply GGC3.3 patch for GCC4. Allows compilation on ppc-macos, marked ~p... (diff) | |
download | gentoo-2-d8a44b9403b51b0a411b6cf8f7b0dc9ef2ff78a8.tar.gz gentoo-2-d8a44b9403b51b0a411b6cf8f7b0dc9ef2ff78a8.tar.bz2 gentoo-2-d8a44b9403b51b0a411b6cf8f7b0dc9ef2ff78a8.zip |
Don't fail if restoring a card fails. See bug #100911.
(Portage version: 2.0.53_rc7)
Diffstat (limited to 'media-sound')
-rw-r--r-- | media-sound/alsa-utils/ChangeLog | 6 | ||||
-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 |
3 files changed, 258 insertions, 3 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/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 +} |