598 lines
14 KiB
XML
598 lines
14 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
|
|
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" []>
|
|
|
|
<book id="ViaAudioGuide">
|
|
<bookinfo>
|
|
<title>Via 686 Audio Driver for Linux</title>
|
|
|
|
<authorgroup>
|
|
<author>
|
|
<firstname>Jeff</firstname>
|
|
<surname>Garzik</surname>
|
|
</author>
|
|
</authorgroup>
|
|
|
|
<copyright>
|
|
<year>1999-2001</year>
|
|
<holder>Jeff Garzik</holder>
|
|
</copyright>
|
|
|
|
<legalnotice>
|
|
<para>
|
|
This documentation 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.
|
|
</para>
|
|
|
|
<para>
|
|
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.
|
|
</para>
|
|
|
|
<para>
|
|
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
|
|
</para>
|
|
|
|
<para>
|
|
For more details see the file COPYING in the source
|
|
distribution of Linux.
|
|
</para>
|
|
</legalnotice>
|
|
</bookinfo>
|
|
|
|
<toc></toc>
|
|
|
|
<chapter id="intro">
|
|
<title>Introduction</title>
|
|
<para>
|
|
The Via VT82C686A "super southbridge" chips contain
|
|
AC97-compatible audio logic which features dual 16-bit stereo
|
|
PCM sound channels (full duplex), plus a third PCM channel intended for use
|
|
in hardware-assisted FM synthesis.
|
|
</para>
|
|
<para>
|
|
The current Linux kernel audio driver for this family of chips
|
|
supports audio playback and recording, but hardware-assisted
|
|
FM features, and hardware buffer direct-access (mmap)
|
|
support are not yet available.
|
|
</para>
|
|
<para>
|
|
This driver supports any Linux kernel version after 2.4.10.
|
|
</para>
|
|
<para>
|
|
Please send bug reports to the mailing list <email>linux-via@gtf.org</email>.
|
|
To subscribe, e-mail <email>majordomo@gtf.org</email> with
|
|
</para>
|
|
<programlisting>
|
|
subscribe linux-via
|
|
</programlisting>
|
|
<para>
|
|
in the body of the message.
|
|
</para>
|
|
</chapter>
|
|
|
|
<chapter id="install">
|
|
<title>Driver Installation</title>
|
|
<para>
|
|
To use this audio driver, select the
|
|
CONFIG_SOUND_VIA82CXXX option in the section Sound during kernel configuration.
|
|
Follow the usual kernel procedures for rebuilding the kernel,
|
|
or building and installing driver modules.
|
|
</para>
|
|
<para>
|
|
To make this driver the default audio driver, you can add the
|
|
following to your /etc/conf.modules file:
|
|
</para>
|
|
<programlisting>
|
|
alias sound via82cxxx_audio
|
|
</programlisting>
|
|
<para>
|
|
Note that soundcore and ac97_codec support modules
|
|
are also required for working audio, in addition to
|
|
the via82cxxx_audio module itself.
|
|
</para>
|
|
</chapter>
|
|
|
|
<chapter id="reportbug">
|
|
<title>Submitting a bug report</title>
|
|
<sect1 id="bugrepdesc"><title>Description of problem</title>
|
|
<para>
|
|
Describe the application you were using to play/record sound, and how
|
|
to reproduce the problem.
|
|
</para>
|
|
</sect1>
|
|
<sect1 id="bugrepdiag"><title>Diagnostic output</title>
|
|
<para>
|
|
Obtain the via-audio-diag diagnostics program from
|
|
http://sf.net/projects/gkernel/ and provide a dump of the
|
|
audio chip's registers while the problem is occurring. Sample command line:
|
|
</para>
|
|
<programlisting>
|
|
./via-audio-diag -aps > diag-output.txt
|
|
</programlisting>
|
|
</sect1>
|
|
<sect1 id="bugrepdebug"><title>Driver debug output</title>
|
|
<para>
|
|
Define <constant>VIA_DEBUG</constant> at the beginning of the driver, then capture and email
|
|
the kernel log output. This can be viewed in the system kernel log (if
|
|
enabled), or via the dmesg program. Sample command line:
|
|
</para>
|
|
<programlisting>
|
|
dmesg > /tmp/dmesg-output.txt
|
|
</programlisting>
|
|
</sect1>
|
|
<sect1 id="bugrepprintk"><title>Bigger kernel message buffer</title>
|
|
<para>
|
|
If you wish to increase the size of the buffer displayed by dmesg, then
|
|
change the <constant>LOG_BUF_LEN</constant> macro at the top of linux/kernel/printk.c, recompile
|
|
your kernel, and pass the <constant>LOG_BUF_LEN</constant> value to dmesg. Sample command line with
|
|
<constant>LOG_BUF_LEN</constant> == 32768:
|
|
</para>
|
|
<programlisting>
|
|
dmesg -s 32768 > /tmp/dmesg-output.txt
|
|
</programlisting>
|
|
</sect1>
|
|
</chapter>
|
|
|
|
<chapter id="bugs">
|
|
<title>Known Bugs And Assumptions</title>
|
|
<para>
|
|
<variablelist>
|
|
<varlistentry><term>Low volume</term>
|
|
<listitem>
|
|
<para>
|
|
Volume too low on many systems. Workaround: use mixer program
|
|
such as xmixer to increase volume.
|
|
</para>
|
|
</listitem></varlistentry>
|
|
|
|
</variablelist>
|
|
|
|
</para>
|
|
</chapter>
|
|
|
|
<chapter id="thanks">
|
|
<title>Thanks</title>
|
|
<para>
|
|
Via for providing e-mail support, specs, and NDA'd source code.
|
|
</para>
|
|
<para>
|
|
MandrakeSoft for providing hacking time.
|
|
</para>
|
|
<para>
|
|
AC97 mixer interface fixes and debugging by Ron Cemer <email>roncemer@gte.net</email>.
|
|
</para>
|
|
<para>
|
|
Rui Sousa <email>rui.sousa@conexant.com</email>, for bugfixing
|
|
MMAP support, and several other notable fixes that resulted from
|
|
his hard work and testing.
|
|
</para>
|
|
<para>
|
|
Adrian Cox <email>adrian@humboldt.co.uk</email>, for bugfixing
|
|
MMAP support, and several other notable fixes that resulted from
|
|
his hard work and testing.
|
|
</para>
|
|
<para>
|
|
Thomas Sailer for further bugfixes.
|
|
</para>
|
|
</chapter>
|
|
|
|
<chapter id="notes">
|
|
<title>Random Notes</title>
|
|
<para>
|
|
Two /proc pseudo-files provide diagnostic information. This is generally
|
|
not useful to most users. Power users can disable CONFIG_SOUND_VIA82CXXX_PROCFS,
|
|
and remove the /proc support code. Once
|
|
version 2.0.0 is released, the /proc support code will be disabled by
|
|
default. Available /proc pseudo-files:
|
|
</para>
|
|
<programlisting>
|
|
/proc/driver/via/0/info
|
|
/proc/driver/via/0/ac97
|
|
</programlisting>
|
|
<para>
|
|
This driver by default supports all PCI audio devices which report
|
|
a vendor id of 0x1106, and a device id of 0x3058. Subsystem vendor
|
|
and device ids are not examined.
|
|
</para>
|
|
<para>
|
|
GNU indent formatting options:
|
|
<programlisting>
|
|
-kr -i8 -ts8 -br -ce -bap -sob -l80 -pcs -cs -ss -bs -di1 -nbc -lp -psl
|
|
</programlisting>
|
|
</para>
|
|
<para>
|
|
Via has graciously donated e-mail support and source code to help further
|
|
the development of this driver. Their assistance has been invaluable
|
|
in the design and coding of the next major version of this driver.
|
|
</para>
|
|
<para>
|
|
The Via audio chip apparently provides a second PCM scatter-gather
|
|
DMA channel just for FM data, but does not have a full hardware MIDI
|
|
processor. I haven't put much thought towards a solution here, but it
|
|
might involve using SoftOSS midi wave table, or simply disabling MIDI
|
|
support altogether and using the FM PCM channel as a second (input? output?)
|
|
</para>
|
|
</chapter>
|
|
|
|
<chapter id="changelog">
|
|
<title>Driver ChangeLog</title>
|
|
|
|
<sect1 id="version191"><title>
|
|
Version 1.9.1
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
DSP read/write bugfixes from Thomas Sailer.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Add new PCI id for single-channel use of Via 8233.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Other bug fixes, tweaks, new ioctls.
|
|
</para>
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version1115"><title>
|
|
Version 1.1.15
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Support for variable fragment size and variable fragment number (Rui
|
|
Sousa)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Fixes for the SPEED, STEREO, CHANNELS, FMT ioctls when in read &
|
|
write mode (Rui Sousa)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Mmaped sound is now fully functional. (Rui Sousa)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Make sure to enable PCI device before reading any of its PCI
|
|
config information. (fixes potential hotplug problems)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Clean up code a bit and add more internal function documentation.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
AC97 codec access fixes (Adrian Cox)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Big endian fixes (Adrian Cox)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
MIDI support (Adrian Cox)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Detect and report locked-rate AC97 codecs. If your hardware only
|
|
supports 48Khz (locked rate), then your recording/playback software
|
|
must upsample or downsample accordingly. The hardware cannot do it.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Use new pci_request_regions and pci_disable_device functions in
|
|
kernel 2.4.6.
|
|
</para>
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version1114"><title>
|
|
Version 1.1.14
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Use VM_RESERVE when available, to eliminate unnecessary page faults.
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version1112"><title>
|
|
Version 1.1.12
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
mmap bug fixes from Linus.
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version1111"><title>
|
|
Version 1.1.11
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Many more bug fixes. mmap enabled by default, but may still be buggy.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Uses new and spiffy method of mmap'ing the DMA buffer, based
|
|
on a suggestion from Linus.
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version1110"><title>
|
|
Version 1.1.10
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Many bug fixes. mmap enabled by default, but may still be buggy.
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version119"><title>
|
|
Version 1.1.9
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Redesign and rewrite audio playback implementation. (faster and smaller, hopefully)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Implement recording and full duplex (DSP_CAP_DUPLEX) support.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Make procfs support optional.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Quick interrupt status check, to lessen overhead in interrupt
|
|
sharing situations.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Add mmap(2) support. Disabled for now, it is still buggy and experimental.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Surround all syscalls with a semaphore for cheap and easy SMP protection.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Fix bug in channel shutdown (hardware channel reset) code.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Remove unnecessary spinlocks (better performance).
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Eliminate "unknown AFMT" message by using a different method
|
|
of selecting the best AFMT_xxx sound sample format for use.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Support for realtime hardware pointer position reporting
|
|
(DSP_CAP_REALTIME, SNDCTL_DSP_GETxPTR ioctls)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Support for capture/playback triggering
|
|
(DSP_CAP_TRIGGER, SNDCTL_DSP_SETTRIGGER ioctls)
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
SNDCTL_DSP_SETDUPLEX and SNDCTL_DSP_POST ioctls now handled.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Rewrite open(2) and close(2) logic to allow only one user at
|
|
a time. All other open(2) attempts will sleep until they succeed.
|
|
FIXME: open(O_RDONLY) and open(O_WRONLY) should be allowed to succeed.
|
|
</para>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Reviewed code to ensure that SMP and multiple audio devices
|
|
are fully supported.
|
|
</para>
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version118"><title>
|
|
Version 1.1.8
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Clean up interrupt handler output. Fixes the following kernel error message:
|
|
</para>
|
|
<programlisting>
|
|
unhandled interrupt ...
|
|
</programlisting>
|
|
</listitem>
|
|
|
|
<listitem>
|
|
<para>
|
|
Convert documentation to DocBook, so that PDF, HTML and PostScript (.ps) output is readily
|
|
available.
|
|
</para>
|
|
</listitem>
|
|
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version117"><title>
|
|
Version 1.1.7
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Fix module unload bug where mixer device left registered
|
|
after driver exit
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version116"><title>
|
|
Version 1.1.6
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Rewrite via_set_rate to mimic ALSA basic AC97 rate setting
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Remove much dead code
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Complete spin_lock_irqsave -> spin_lock_irq conversion in via_dsp_ioctl
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Fix build problem in via_dsp_ioctl
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Optimize included headers to eliminate headers found in linux/sound
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version115"><title>
|
|
Version 1.1.5
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Disable some overly-verbose debugging code
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Remove unnecessary sound locks
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Fix some ioctls for better time resolution
|
|
</para>
|
|
</listitem>
|
|
<listitem>
|
|
<para>
|
|
Begin spin_lock_irqsave -> spin_lock_irq conversion in via_dsp_ioctl
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
<sect1 id="version114"><title>
|
|
Version 1.1.4
|
|
</title>
|
|
<itemizedlist spacing="compact">
|
|
<listitem>
|
|
<para>
|
|
Completed rewrite of driver. Eliminated SoundBlaster compatibility
|
|
completely, and now uses the much-faster scatter-gather DMA engine.
|
|
</para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
</sect1>
|
|
|
|
</chapter>
|
|
|
|
<chapter id="intfunctions">
|
|
<title>Internal Functions</title>
|
|
!Isound/oss/via82cxxx_audio.c
|
|
</chapter>
|
|
|
|
</book>
|
|
|
|
|