mirror of
https://github.com/Zeckmathederg/glfs.git
synced 2025-02-07 09:37:17 +08:00
git-svn-id: svn://svn.linuxfromscratch.org/BLFS/trunk/BOOK@1189 af4574ff-66df-0310-9fd7-8a98e5e911e0
104 lines
3.7 KiB
XML
104 lines
3.7 KiB
XML
<sect2>
|
|
<title>Configuring <application><acronym>ALSA</acronym>-utils</application></title>
|
|
|
|
<sect3><title>Config files</title>
|
|
|
|
<para><filename>/etc/asound.state</filename></para>
|
|
|
|
</sect3>
|
|
|
|
<sect3><title>Configuration Information</title>
|
|
|
|
<para>Probably the easiest way to store mixer levels is to set and retrieve
|
|
them using a bootscript. It is possible to do this with a
|
|
<userinput>post-install</userinput> line in
|
|
<filename>/etc/modules.conf</filename> but this is left as an exercise for
|
|
those readers who wish to do this.</para>
|
|
|
|
<para>The <application><acronym>ALSA</acronym>-drivers</application> package
|
|
installs a script as <filename>/etc/rc.d/init.d/alsasound</filename>. While it
|
|
is possible to use this script, it contains a lot of extraneous detail which
|
|
isn't needed on an <acronym>LFS</acronym> system and so we create our own
|
|
script <filename>/etc/rc.d/init.d/alsa</filename>.</para>
|
|
|
|
<para>To create the alsa script, do the following:</para>
|
|
|
|
<screen><userinput><command>cat > /etc/rc.d/init.d/alsa << "EOF"</command>
|
|
#!/bin/sh
|
|
# Begin $rc_base/init.d/alsa
|
|
|
|
# Based on sysklogd script from LFS-3.1 and earlier.
|
|
# Rewritten by Gerard Beekmans - gerard@linuxfromscratch.org
|
|
# ALSA specific parts by Mark Hymers - markh@linuxfromscratch.org
|
|
# Stores mixer settings in the default location: /etc/asound.state
|
|
|
|
source /etc/sysconfig/rc
|
|
source $rc_functions
|
|
|
|
case "$1" in
|
|
start)
|
|
echo "Starting alsa... Restoring volumes..."
|
|
loadproc /usr/sbin/alsactl restore
|
|
#echo " Loading MIDI font..."
|
|
#loadproc sfxload /path/to/soundfont
|
|
;;
|
|
|
|
stop)
|
|
echo "Stopping alsa... Saving volumes......"
|
|
loadproc /usr/sbin/alsactl store
|
|
#echo " Removing MIDI font.........."
|
|
#loadproc sfxload -i
|
|
;;
|
|
|
|
restart)
|
|
$0 stop
|
|
/usr/bin/sleep 1
|
|
$0 start
|
|
;;
|
|
|
|
*)
|
|
echo "Usage: $0 {start|stop|restart}"
|
|
exit 1
|
|
;;
|
|
|
|
esac
|
|
|
|
# End $rc_base/init.d/alsa
|
|
<command>EOF
|
|
chmod 755 /etc/rc.d/init.d/alsa</command></userinput></screen>
|
|
|
|
<para>You can then create the appropriate symlinks:
|
|
<screen><userinput><command>cd /etc/rc.d/init.d &&
|
|
ln -sf ../init.d/alsa ../rc0.d/K35alsa &&
|
|
ln -sf ../init.d/alsa ../rc1.d/K35alsa &&
|
|
ln -sf ../init.d/alsa ../rc2.d/S40alsa &&
|
|
ln -sf ../init.d/alsa ../rc3.d/S40alsa &&
|
|
ln -sf ../init.d/alsa ../rc4.d/S40alsa &&
|
|
ln -sf ../init.d/alsa ../rc5.d/S40alsa &&
|
|
ln -sf ../init.d/alsa ../rc6.d/K35alsa</command></userinput></screen></para>
|
|
|
|
<para>Note that all channels of your soundcard are muted by default. You can
|
|
use the <command>alsamixer</command> program from
|
|
<application><acronym>ALSA</acronym>-utils</application> (or any other
|
|
<acronym>OSS</acronym> mixer) to change this.</para>
|
|
|
|
<para>Also, the first time the above script is run, it will complain that
|
|
there is no state in <filename>/etc/asound.state</filename>. You can
|
|
prevent this by running the following commands after installing
|
|
<application><acronym>ALSA</acronym>-utils</application>:
|
|
<screen><userinput><command>touch /etc/asound.state &&
|
|
alsactl store</command></userinput></screen></para>
|
|
|
|
<para>A final note is that the lines loading <filename>sfxload</filename>
|
|
are commented out. They are there as an example of other things you may
|
|
wish to do in the startup script. <filename>sfxload</filename> is a
|
|
separate package of interest to SoundBlaster <acronym>AWE</acronym> and Live!
|
|
users. It is designed for loading "sound-fonts" (which are used for
|
|
<acronym>MIDI</acronym> output). You may wish to delete these lines and add
|
|
your own or, if you have the relevant soundcard, install <filename>sfxload
|
|
</filename> and uncomment them.</para>
|
|
|
|
</sect3>
|
|
|
|
</sect2>
|