2008-09-13 17:01:38 +00:00
|
|
|
.\" Copyright (c) 2006-2008 Joel Dahl <joel@FreeBSD.org>
|
|
|
|
.\" Copyright (c) 2008 Alexander Motin <mav@FreeBSD.org>
|
2006-10-01 11:16:31 +00:00
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
.\" SUCH DAMAGE.
|
|
|
|
.\"
|
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
2010-01-22 11:04:25 +00:00
|
|
|
.Dd January 22, 2010
|
2006-10-01 11:16:31 +00:00
|
|
|
.Dt SND_HDA 4
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm snd_hda
|
|
|
|
.Nd "Intel High Definition Audio bridge device driver"
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
To compile this driver into the kernel, place the following lines in your
|
|
|
|
kernel configuration file:
|
|
|
|
.Bd -ragged -offset indent
|
|
|
|
.Cd "device sound"
|
|
|
|
.Cd "device snd_hda"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
Alternatively, to load the driver as a module at boot time, place the
|
|
|
|
following line in
|
|
|
|
.Xr loader.conf 5 :
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
snd_hda_load="YES"
|
|
|
|
.Ed
|
|
|
|
.Sh DESCRIPTION
|
2008-09-13 17:01:38 +00:00
|
|
|
The High Definition (HD) Audio specification was developed by Intel as the
|
|
|
|
logical successor of the old AC'97 specification and has several advantages,
|
|
|
|
such as higher bandwidth which allows more channels and more detailed formats,
|
|
|
|
support for several logical audio devices, and general purpose DMA channels.
|
|
|
|
.Pp
|
2006-10-01 11:16:31 +00:00
|
|
|
The
|
|
|
|
.Nm
|
2008-09-13 17:01:38 +00:00
|
|
|
driver is a HDA bus controller driver and HDA codecs audio functions bridge
|
|
|
|
driver that allows the generic audio driver,
|
2006-10-01 11:16:31 +00:00
|
|
|
.Xr sound 4 ,
|
2008-09-13 17:01:38 +00:00
|
|
|
to be used with this hardware.
|
2008-11-06 21:47:02 +00:00
|
|
|
Only audio functions are supported by
|
2008-11-07 17:55:09 +00:00
|
|
|
.Nm .
|
2009-11-13 09:57:50 +00:00
|
|
|
Modem and other possible functions are not implemented.
|
2008-09-13 17:01:38 +00:00
|
|
|
.Pp
|
2006-10-01 11:16:31 +00:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver supports hardware that conforms with revision 1.0 of the Intel High
|
|
|
|
Definition Audio specification and tries to behave much like the Microsoft
|
|
|
|
Universal Audio Architecture (UAA) draft (revision 0.7b) for handling audio
|
|
|
|
devices.
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
According to HDA and UAA specifications, depending on the number of HDA buses
|
2008-09-13 17:01:38 +00:00
|
|
|
and codecs present in system, their audio capabilities and BIOS provided
|
2008-09-14 09:56:35 +00:00
|
|
|
configuration, the
|
2008-09-13 17:01:38 +00:00
|
|
|
.Nm
|
2008-09-14 09:56:35 +00:00
|
|
|
driver often provides several PCM audio devices.
|
|
|
|
For example, one device for main rear 7.1 output and inputs, one device
|
|
|
|
for independent headset connectors at front and one device for SPDIF or
|
|
|
|
HDMI audio input/output.
|
2008-11-06 21:47:02 +00:00
|
|
|
The assignment of audio inputs and outputs may be tuned with
|
|
|
|
.Xr device.hints 5 .
|
|
|
|
The driver's verbose boot messages provide a lot of information about
|
|
|
|
the operation of the driver and present audio setup.
|
2008-10-03 09:19:07 +00:00
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
The default audio device may be tuned by setting the
|
|
|
|
.Ar hw.snd.default_unit
|
|
|
|
sysctl, as described in
|
|
|
|
.Xr sound 4 ,
|
2008-11-07 17:55:09 +00:00
|
|
|
or explicitly specified in application settings.
|
2007-01-17 14:27:03 +00:00
|
|
|
.Ss Boot-time Configuration
|
|
|
|
The following variables are available at boot-time through the
|
|
|
|
.Xr device.hints 5
|
|
|
|
file:
|
2008-09-13 17:01:38 +00:00
|
|
|
.Bl -tag -width ".Va hint.hdac.%d.config"-offset indent
|
|
|
|
.It Va hint.hdac.%d.config
|
2007-01-17 14:27:03 +00:00
|
|
|
Configures a range of possible options.
|
|
|
|
Possible values are:
|
2007-05-05 10:33:28 +00:00
|
|
|
.Dq Li dmapos ,
|
|
|
|
.Dq Li eapdinv ,
|
2007-01-17 14:27:03 +00:00
|
|
|
.Dq Li gpio0 ,
|
|
|
|
.Dq Li gpio1 ,
|
|
|
|
.Dq Li gpio2 ,
|
2007-05-05 10:33:28 +00:00
|
|
|
.Dq Li gpio3 ,
|
|
|
|
.Dq Li gpio4 ,
|
|
|
|
.Dq Li gpio5 ,
|
|
|
|
.Dq Li gpio6 ,
|
|
|
|
.Dq Li gpio7 ,
|
2007-01-17 14:27:03 +00:00
|
|
|
.Dq Li gpioflush ,
|
2007-05-05 10:33:28 +00:00
|
|
|
.Dq Li ivref ,
|
|
|
|
.Dq Li ivref50 ,
|
|
|
|
.Dq Li ivref80 ,
|
|
|
|
.Dq Li ivref100 ,
|
2007-01-17 14:27:03 +00:00
|
|
|
.Dq Li fixedrate ,
|
|
|
|
.Dq Li forcestereo ,
|
2007-05-05 10:33:28 +00:00
|
|
|
.Dq Li ovref ,
|
|
|
|
.Dq Li ovref50 ,
|
|
|
|
.Dq Li ovref80 ,
|
|
|
|
.Dq Li ovref100 ,
|
2008-09-13 17:01:38 +00:00
|
|
|
.Dq Li senseinv ,
|
2007-01-17 14:27:03 +00:00
|
|
|
.Dq Li softpcmvol ,
|
|
|
|
and
|
|
|
|
.Dq Li vref .
|
|
|
|
An option prefixed with
|
|
|
|
.Dq Li no ,
|
|
|
|
such as
|
2007-01-18 15:27:15 +00:00
|
|
|
.Dq Li nofixedrate ,
|
2007-01-17 14:27:03 +00:00
|
|
|
will do the opposite and takes precedence.
|
|
|
|
Options can be separated by whitespace and commas.
|
2010-01-12 17:50:26 +00:00
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
.Dq Li GPIO Ns s
|
|
|
|
are a codec's General Purpose I/O pins which system integrators sometimes
|
2008-09-13 17:01:38 +00:00
|
|
|
use to control external muters, amplifiers and so on.
|
2008-11-06 21:47:02 +00:00
|
|
|
If you have no sound, or sound volume is not adequate, you may have to
|
|
|
|
experiment a bit with the GPIO setup to find the optimal setup for your
|
|
|
|
system.
|
2010-01-12 17:50:26 +00:00
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
The
|
|
|
|
.Dq Li ivref Ns Ar X
|
|
|
|
and
|
|
|
|
.Dq Li ovref Ns Ar X
|
|
|
|
options control the voltage used to power external microphones.
|
2008-10-24 18:28:52 +00:00
|
|
|
.It Va hint.hdac.%d.msi
|
|
|
|
Controls MSI (Message Signaled Interrupts) support.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va hint.hdac.%d.cad%d.nid%d.config
|
|
|
|
Overrides codec pin configuration set by BIOS.
|
2008-11-06 21:47:02 +00:00
|
|
|
May be specified as a 32-bit hexadecimal value with a leading
|
|
|
|
.Dq 0x ,
|
|
|
|
or as a set of space-separated
|
|
|
|
.Dq Ar option Ns = Ns Ar value
|
|
|
|
pairs.
|
2008-09-13 17:01:38 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
Pin configuration is the UAA driver's main source of information about codec
|
|
|
|
usage.
|
|
|
|
This information is usually provided by the codec manufacturer and tuned
|
|
|
|
by system integrators for specific system requirements.
|
|
|
|
The
|
|
|
|
.Nm
|
2008-11-06 21:47:02 +00:00
|
|
|
driver allows users to override it to fix integrator mistakes or to use the
|
|
|
|
available codec in alternative ways (for example to get stereo output and 2
|
|
|
|
inputs instead of a single 5.1 output).
|
|
|
|
.Pp
|
|
|
|
The following options are supported:
|
2008-09-13 17:01:38 +00:00
|
|
|
.Bl -tag -width ".Va device=" -offset indent
|
|
|
|
.It Va as
|
|
|
|
Association number.
|
2008-11-06 21:47:02 +00:00
|
|
|
Associations are used to group individual pins to form a complex multi-pin
|
2008-09-13 17:01:38 +00:00
|
|
|
device.
|
2008-11-06 21:47:02 +00:00
|
|
|
For example, to group 4 connectors for 7.1 output, or to treat several
|
2008-09-13 17:01:38 +00:00
|
|
|
input connectors as sources for the same input device.
|
2008-11-06 21:47:02 +00:00
|
|
|
Association numbers can be specified as numeric values from 0 to 15.
|
|
|
|
A value of 0 means disabled pin.
|
|
|
|
A value of 15 is a set of independent unassociated pins.
|
|
|
|
Each association includes only pins of the same direction (in/out) and is
|
|
|
|
detected atomically (all pins or none).
|
|
|
|
A separate PCM audio device is created for every pair of input and
|
|
|
|
output associations.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va seq
|
|
|
|
Sequence number.
|
2008-11-06 21:47:02 +00:00
|
|
|
A unique, per-association number used to order pins inside the
|
|
|
|
particular association.
|
|
|
|
Sequence numbers can be specified as numeric values from 0 to 15.
|
|
|
|
.Pp
|
2010-01-12 17:50:26 +00:00
|
|
|
For output assotiations sequence numbers encode speaker pairs positions:
|
|
|
|
0 - Front, 1 - Center/LFE, 2 - Back, 3 - Front Wide Center, 4 - Side.
|
|
|
|
Standard combinations are: (0) - Stereo; (0, 2), (0, 4) - Quadro;
|
|
|
|
(0, 1, 2), (0, 1, 4) - 5.1; (0, 1, 2, 4) - 7.1.
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
The sequence number 15 has a special meaning for output associations.
|
|
|
|
Output pins with this number and device type
|
|
|
|
.Dq Ar Headphones
|
|
|
|
will duplicate (with automatic mute if jack detection is supported) the
|
|
|
|
first pin in that association.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va device
|
|
|
|
Device type.
|
|
|
|
Can be specified as a number from 0 to 15 or as a name:
|
|
|
|
.Dq Li Line-out ,
|
|
|
|
.Dq Li Speaker ,
|
|
|
|
.Dq Li Headphones,
|
|
|
|
.Dq Li CD ,
|
|
|
|
.Dq Li SPDIF-out ,
|
|
|
|
.Dq Li Digital-out ,
|
|
|
|
.Dq Li Modem-line ,
|
|
|
|
.Dq Li Modem-handset ,
|
|
|
|
.Dq Li Line-in ,
|
|
|
|
.Dq Li AUX ,
|
|
|
|
.Dq Li Mic ,
|
|
|
|
.Dq Li Telephony ,
|
|
|
|
.Dq Li SPDIF-in ,
|
|
|
|
.Dq Li Digital-in ,
|
|
|
|
.Dq Li Res.E ,
|
|
|
|
or
|
|
|
|
.Dq Li Other .
|
|
|
|
The device type also describes the pin direction (in/out).
|
|
|
|
For example,
|
|
|
|
.Dq Li CD
|
2008-11-06 21:47:02 +00:00
|
|
|
always means an input pin, while
|
2008-09-13 17:01:38 +00:00
|
|
|
.Dq Li Headphones
|
2008-11-06 21:47:02 +00:00
|
|
|
always means an output.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va conn
|
|
|
|
Connection type.
|
2008-11-06 21:47:02 +00:00
|
|
|
Can be specified as a number from 0 to 3.
|
|
|
|
The connection type can also be specified as one of the special names
|
2008-09-13 17:01:38 +00:00
|
|
|
.Dq Li Jack ,
|
|
|
|
.Dq Li None ,
|
|
|
|
.Dq Li Fixed ,
|
|
|
|
or
|
|
|
|
.Dq Li Both .
|
2008-11-06 21:47:02 +00:00
|
|
|
Pins with a connection type of
|
2008-09-13 17:01:38 +00:00
|
|
|
.Dq Li None
|
2008-11-06 21:47:02 +00:00
|
|
|
are disabled.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va ctype
|
|
|
|
Connector physical type.
|
|
|
|
Can be specified as a number from 0 to 15.
|
2008-11-06 21:47:02 +00:00
|
|
|
This is a reference only value.
|
|
|
|
It is ignored by the
|
|
|
|
.Nm
|
|
|
|
driver.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va color
|
|
|
|
Connector color.
|
2008-11-06 21:47:02 +00:00
|
|
|
Can be specified as a number from 0 to 15 or as one of the names
|
2008-09-13 17:01:38 +00:00
|
|
|
.Dq Li Unknown ,
|
|
|
|
.Dq Li Black ,
|
|
|
|
.Dq Li Grey ,
|
|
|
|
.Dq Li Blue ,
|
|
|
|
.Dq Li Green ,
|
|
|
|
.Dq Li Red ,
|
|
|
|
.Dq Li Orange ,
|
|
|
|
.Dq Li Yellow ,
|
|
|
|
.Dq Li Purple ,
|
|
|
|
.Dq Li Pink ,
|
|
|
|
.Dq Li Res.A ,
|
|
|
|
.Dq Li Res.B ,
|
|
|
|
.Dq Li Res.C ,
|
|
|
|
.Dq Li Res.D ,
|
|
|
|
.Dq Li White ,
|
|
|
|
or
|
|
|
|
.Dq Li Other .
|
2008-11-06 21:47:02 +00:00
|
|
|
This is a reference only value.
|
|
|
|
It is ignored by the
|
|
|
|
.Nm
|
|
|
|
driver.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va loc
|
|
|
|
Connector physical location.
|
|
|
|
Can be specified as a number from 0 to 63.
|
2008-11-06 21:47:02 +00:00
|
|
|
This is a reference only value.
|
|
|
|
It is ignored by the
|
|
|
|
.Nm
|
|
|
|
driver.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va misc
|
|
|
|
Misc bits.
|
|
|
|
Can be specified as a number from 0 to 15.
|
2008-11-06 21:47:02 +00:00
|
|
|
Bit 0 has a special meaning. When set it means that jack detection is
|
|
|
|
not implemented in hardware.
|
2007-01-17 14:27:03 +00:00
|
|
|
.El
|
2006-11-29 17:07:02 +00:00
|
|
|
.Ss Runtime Configuration
|
|
|
|
The following
|
|
|
|
.Xr sysctl 8
|
|
|
|
variables are available in addition to those available to all
|
|
|
|
.Xr sound 4
|
|
|
|
devices:
|
2008-09-13 17:01:38 +00:00
|
|
|
.Bl -tag -width ".Va dev.hdac.%d.polling" -offset indent
|
|
|
|
.It Va dev.hdac.%d.polling
|
2008-11-06 21:47:02 +00:00
|
|
|
Enables polling mode.
|
|
|
|
In this mode the driver operates by querying the device state on timer
|
|
|
|
ticks using
|
2008-09-13 17:01:38 +00:00
|
|
|
.Xr callout 9
|
|
|
|
instead of interrupts.
|
2006-11-29 17:07:02 +00:00
|
|
|
Polling is disabled by default.
|
|
|
|
Do not enable it unless you are facing weird interrupt problems or if the
|
|
|
|
device cannot generate interrupts at all.
|
2008-09-13 17:01:38 +00:00
|
|
|
.It Va dev.hdac.%d.polling_interval
|
|
|
|
Controller/Jack Sense polling interval (1-1000 ms)
|
|
|
|
.It Va dev.hdac.%d.pindump
|
|
|
|
Setting this to a non-zero value dumps the current pin configuration, main
|
|
|
|
capabilities and jack sense status to console and syslog.
|
2006-11-29 17:07:02 +00:00
|
|
|
.El
|
2008-09-17 20:17:22 +00:00
|
|
|
.Sh EXAMPLES
|
2008-11-06 21:47:02 +00:00
|
|
|
Taking HP Compaq DX2300 with Realtek ALC888 HDA codec for example.
|
|
|
|
This system has two audio connectors on a front side, three audio connectors
|
|
|
|
on a rear side and one internal speaker.
|
|
|
|
According to verbose driver output and the codec datasheet,
|
|
|
|
this codec has five stereo DACs and two stereo ADCs, all of them are routable to
|
|
|
|
any codec pin (external connector).
|
|
|
|
All codec pins are reversible (could be configured either as input or output).
|
2008-09-17 20:17:22 +00:00
|
|
|
.Pp
|
2008-11-05 17:12:18 +00:00
|
|
|
So high codec uniformity and flexibility allow driver to configure it in many
|
2010-07-31 12:14:28 +00:00
|
|
|
different ways, depending on requested pins usage described by pins configuration.
|
2009-02-12 13:04:13 +00:00
|
|
|
The driver reports such default pin configuration when verbose messages enabled:
|
2008-09-17 20:17:22 +00:00
|
|
|
.Bd -literal
|
|
|
|
hdac0: nid 20 0x01014020 as 2 seq 0 Line-out Jack jack 1 loc 1 color Green misc 0
|
|
|
|
hdac0: nid 21 0x99130110 as 1 seq 0 Speaker Fixed jack 3 loc 25 color Unknown misc 1
|
|
|
|
hdac0: nid 22 0x411111f0 as 15 seq 0 Speaker None jack 1 loc 1 color Black misc 1
|
|
|
|
hdac0: nid 23 0x411111f0 as 15 seq 0 Speaker None jack 1 loc 1 color Black misc 1
|
|
|
|
hdac0: nid 24 0x01a19830 as 3 seq 0 Mic Jack jack 1 loc 1 color Pink misc 8
|
|
|
|
hdac0: nid 25 0x02a1983f as 3 seq 15 Mic Jack jack 1 loc 2 color Pink misc 8
|
|
|
|
hdac0: nid 26 0x01813031 as 3 seq 1 Line-in Jack jack 1 loc 1 color Blue misc 0
|
|
|
|
hdac0: nid 27 0x0221401f as 1 seq 15 Headphones Jack jack 1 loc 2 color Green misc 0
|
|
|
|
hdac0: nid 28 0x411111f0 as 15 seq 0 Speaker None jack 1 loc 1 color Black misc 1
|
|
|
|
hdac0: nid 30 0x411111f0 as 15 seq 0 Speaker None jack 1 loc 1 color Black misc 1
|
|
|
|
hdac0: nid 31 0x411111f0 as 15 seq 0 Speaker None jack 1 loc 1 color Black misc 1
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2009-02-12 13:04:13 +00:00
|
|
|
Here we can see, that the nodes with ID (nid) 25 and 27 are front panel
|
|
|
|
connectors (Jack, loc 2), nids 20, 24 and 26 are rear panel connectors
|
2008-11-05 17:12:18 +00:00
|
|
|
(Jack, loc 1) and nid 21 is a built-in speaker (Fixed, loc 25).
|
|
|
|
Pins with nids 22, 23, 28, 30 and 31 will be disabled by driver due to "None"
|
|
|
|
connectivity. So the pin count and description matches to connectors that
|
|
|
|
we have.
|
|
|
|
.Pp
|
|
|
|
Using association (as) and sequence (seq) fields values pins are grouped into
|
|
|
|
3 associations:
|
2008-09-17 20:17:22 +00:00
|
|
|
.Bd -literal
|
|
|
|
hdac0: Association 0 (1) out:
|
|
|
|
hdac0: Pin nid=21 seq=0
|
|
|
|
hdac0: Pin nid=27 seq=15
|
|
|
|
hdac0: Association 1 (2) out:
|
|
|
|
hdac0: Pin nid=20 seq=0
|
|
|
|
hdac0: Association 2 (3) in:
|
|
|
|
hdac0: Pin nid=24 seq=0
|
|
|
|
hdac0: Pin nid=26 seq=1
|
|
|
|
hdac0: Pin nid=25 seq=15
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
Each
|
|
|
|
.Xr pcm 4
|
|
|
|
device uses two associations: one for playback and one for recording.
|
|
|
|
Associations processed and assigned to
|
|
|
|
.Xr pcm 4
|
|
|
|
devices in increasing numerical order.
|
|
|
|
In this case association #0 (1) will become
|
|
|
|
.Li pcm0
|
|
|
|
device playback, using the internal speakers and
|
|
|
|
.Ar Headphones
|
|
|
|
jack with speaker automute on the headphones jack connection.
|
|
|
|
Association #1 (2) will become
|
|
|
|
.Li pcm1
|
|
|
|
playback, using the
|
|
|
|
.Ar Line-out
|
|
|
|
jack.
|
|
|
|
Association #2 (3) will become
|
|
|
|
.Li pcm0
|
|
|
|
recording, using the external microphones and the
|
|
|
|
.Ar Line-in
|
|
|
|
jack.
|
2008-11-05 17:12:18 +00:00
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver provides extensive verbose messages to diagnose its operation
|
|
|
|
logic and describe its current codec configuration.
|
2008-11-05 17:12:18 +00:00
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
Using
|
|
|
|
.Xr device.hints 5
|
|
|
|
it is possible to modify the configuration of the existing pins,
|
|
|
|
allowing a broad range of different audio setups.
|
|
|
|
Here are a few examples of some setups possible for this particular
|
|
|
|
hardware:
|
2008-09-17 20:17:22 +00:00
|
|
|
.Ss Example 1
|
2008-11-06 21:47:02 +00:00
|
|
|
Setting the
|
|
|
|
.Xr device.hints 5
|
|
|
|
options
|
2008-09-17 20:17:22 +00:00
|
|
|
.Bd -literal
|
|
|
|
hint.hdac.0.cad0.nid20.config="as=1"
|
|
|
|
hint.hdac.0.cad0.nid21.config="as=2"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
will swap line-out and speaker functions.
|
|
|
|
So the
|
|
|
|
.Li pcm0
|
|
|
|
device will play to the line-out and headphones jacks. Line-out will
|
|
|
|
be muted on the headphones jack connection.
|
|
|
|
Recording on
|
|
|
|
.Li pcm0
|
|
|
|
will go from two external microphones and line-in jacks.
|
|
|
|
.Li pcm1
|
|
|
|
playback will go to the internal speaker.
|
2008-09-17 20:17:22 +00:00
|
|
|
.Pp
|
|
|
|
.Ss Example 2
|
2008-11-06 21:47:02 +00:00
|
|
|
Setting the
|
|
|
|
.Xr device.hints 5
|
|
|
|
options
|
2008-09-17 20:17:22 +00:00
|
|
|
.Bd -literal
|
|
|
|
hint.hdac.0.cad0.nid20.config="as=1 seq=15 device=Headphones"
|
|
|
|
hint.hdac.0.cad0.nid27.config="as=2 seq=0"
|
|
|
|
hint.hdac.0.cad0.nid25.config="as=4 seq=0"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
will split the headphones and one of the microphones to a separate device.
|
|
|
|
The
|
|
|
|
.Li pcm0
|
|
|
|
device will play to the internal speaker and to the line-out jack, with
|
|
|
|
speaker automute on the line-out jack connection.
|
|
|
|
Recording on
|
|
|
|
.Li pcm0
|
|
|
|
will use input from one external microphone and the line-in jacks.
|
|
|
|
The
|
|
|
|
.Li pcm1
|
|
|
|
device will be completely dedicated to a headset (headphones and mic)
|
|
|
|
connected to the front connectors.
|
2008-09-17 20:17:22 +00:00
|
|
|
.Pp
|
|
|
|
.Ss Example 3
|
2008-11-06 21:47:02 +00:00
|
|
|
Setting the
|
|
|
|
.Xr device.hints 5
|
|
|
|
options
|
2008-09-17 20:17:22 +00:00
|
|
|
.Bd -literal
|
|
|
|
hint.hdac.0.cad0.nid20.config="as=1 seq=0"
|
|
|
|
hint.hdac.0.cad0.nid26.config="as=2 seq=0"
|
|
|
|
hint.hdac.0.cad0.nid27.config="as=3 seq=0"
|
|
|
|
hint.hdac.0.cad0.nid25.config="as=4 seq=0"
|
|
|
|
hint.hdac.0.cad0.nid24.config="as=5 seq=0 device=Line-out"
|
|
|
|
hint.hdac.0.cad0.nid21.config="as=6 seq=0"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
will give 4 independent devices:
|
|
|
|
.Li pcm0
|
|
|
|
.Pq line-out and line-in ,
|
|
|
|
.Li pcm1
|
|
|
|
.Pq headphones and mic ,
|
|
|
|
.Li pcm2
|
|
|
|
.Pq additional line-out via retasked rear mic jack ,
|
|
|
|
and
|
|
|
|
.Li pcm3
|
|
|
|
.Pq internal speaker .
|
2008-09-17 20:17:22 +00:00
|
|
|
.Pp
|
|
|
|
.Ss Example 4
|
2008-11-06 21:47:02 +00:00
|
|
|
Setting the
|
|
|
|
.Xr device.hints 5
|
|
|
|
options
|
2008-09-17 20:17:22 +00:00
|
|
|
.Bd -literal
|
|
|
|
hint.hdac.0.cad0.nid20.config="as=1 seq=0"
|
|
|
|
hint.hdac.0.cad0.nid24.config="as=1 seq=1 device=Line-out"
|
|
|
|
hint.hdac.0.cad0.nid26.config="as=1 seq=2 device=Line-out"
|
|
|
|
hint.hdac.0.cad0.nid21.config="as=2 seq=0"
|
|
|
|
.Ed
|
|
|
|
.Pp
|
2008-11-06 21:47:02 +00:00
|
|
|
will give 2 devices:
|
|
|
|
.Li pcm0
|
|
|
|
for 5.1 playback via 3 rear connectors (line-out and retasked
|
|
|
|
mic and line-in) and headset (headphones and mic) at front connectors.
|
|
|
|
.Li pcm1
|
|
|
|
for internal speaker playback.
|
|
|
|
On headphones connection rear connectors will be muted.
|
2010-01-22 11:04:25 +00:00
|
|
|
.Sh MIXER CONTROLS
|
|
|
|
Depending on codec configuration, these controls and signal sources could be
|
|
|
|
reported to
|
|
|
|
.Xr sound 4 :
|
|
|
|
.Bl -tag -width ".Va speaker" -offset indent
|
|
|
|
.It Va vol
|
|
|
|
overall output level (volume)
|
|
|
|
.It Va rec
|
|
|
|
overall recording level
|
|
|
|
.It Va igain
|
|
|
|
input-to-output monitoring loopback level
|
|
|
|
.It Va ogain
|
|
|
|
external amplifier control
|
|
|
|
.It Va pcm
|
|
|
|
PCM playback
|
|
|
|
.It Va mix
|
|
|
|
input mix
|
|
|
|
.It Va mic
|
|
|
|
first external or second internal microphone input
|
|
|
|
.It Va monitor
|
|
|
|
first internal or second external microphone input
|
|
|
|
.It Va line , Va line1 , Va line2, Va line3
|
|
|
|
analog (line) inputs
|
|
|
|
.It Va dig1 , Va dig2 , Va dig3
|
|
|
|
digital (S/PDIF, HDMI or DisplayPort) inputs
|
|
|
|
.It Va cd
|
|
|
|
CD input
|
|
|
|
.It Va speaker
|
|
|
|
PC speaker input
|
|
|
|
.It Va phin , Va phout , Va radio . Va video
|
|
|
|
other random inputs
|
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
Controls have different precision. Some could be just an on/off triggers.
|
|
|
|
Most of controls use logarithmic scale.
|
2006-10-01 11:16:31 +00:00
|
|
|
.Sh HARDWARE
|
|
|
|
The
|
|
|
|
.Nm
|
2009-01-07 16:01:23 +00:00
|
|
|
driver supports many Intel HDA compatible audio chipsets including the
|
|
|
|
following:
|
2006-10-01 11:16:31 +00:00
|
|
|
.Pp
|
|
|
|
.Bl -bullet -compact
|
|
|
|
.It
|
|
|
|
ATI SB450
|
|
|
|
.It
|
2006-10-08 19:41:37 +00:00
|
|
|
ATI SB600
|
|
|
|
.It
|
|
|
|
Intel 631x/632xESB
|
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
Intel 82801F (ICH6)
|
2006-10-01 11:16:31 +00:00
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
Intel 82801G (ICH7)
|
2006-10-01 11:16:31 +00:00
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
Intel 82801H (ICH8)
|
2006-10-08 19:41:37 +00:00
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
Intel 82801I (ICH9)
|
|
|
|
.It
|
|
|
|
Intel 82801J (ICH10)
|
|
|
|
.It
|
|
|
|
Intel US15W (SCH)
|
2007-07-14 12:35:29 +00:00
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
nVidia MCP51
|
|
|
|
.It
|
|
|
|
nVidia MCP55
|
2006-10-08 19:41:37 +00:00
|
|
|
.It
|
|
|
|
nVidia MCP61A
|
|
|
|
.It
|
|
|
|
nVidia MCP61B
|
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
nVidia MCP63
|
|
|
|
.It
|
2006-10-08 19:41:37 +00:00
|
|
|
nVidia MCP65A
|
|
|
|
.It
|
|
|
|
nVidia MCP65B
|
|
|
|
.It
|
2008-05-11 06:40:04 +00:00
|
|
|
nVidia MCP67A
|
|
|
|
.It
|
|
|
|
nVidia MCP67B
|
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
nVidia MCP68
|
|
|
|
.It
|
|
|
|
nVidia MCP69
|
|
|
|
.It
|
2009-11-13 09:57:50 +00:00
|
|
|
nVidia MCP73
|
|
|
|
.It
|
|
|
|
nVidia MCP78
|
|
|
|
.It
|
|
|
|
nVidia MCP79
|
|
|
|
.It
|
|
|
|
nVidia MCP89
|
|
|
|
.It
|
2006-10-08 19:41:37 +00:00
|
|
|
SiS 966
|
|
|
|
.It
|
|
|
|
VIA VT8251/8237A
|
2006-10-01 11:16:31 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
2009-01-07 16:01:23 +00:00
|
|
|
The following and many other codecs have been verified to work:
|
2006-10-01 11:16:31 +00:00
|
|
|
.Pp
|
|
|
|
.Bl -bullet -compact
|
|
|
|
.It
|
2007-06-12 15:26:41 +00:00
|
|
|
Analog Devices AD1981HD
|
2006-10-01 11:16:31 +00:00
|
|
|
.It
|
2007-06-12 15:26:41 +00:00
|
|
|
Analog Devices AD1983
|
2006-10-01 11:16:31 +00:00
|
|
|
.It
|
2008-05-11 06:40:04 +00:00
|
|
|
Analog Devices AD1984
|
|
|
|
.It
|
2007-06-12 15:26:41 +00:00
|
|
|
Analog Devices AD1986A
|
2006-10-01 11:16:31 +00:00
|
|
|
.It
|
2007-06-12 15:26:41 +00:00
|
|
|
Analog Devices AD1988
|
|
|
|
.It
|
|
|
|
Analog Devices AD1988B
|
2007-05-05 10:33:28 +00:00
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
CMedia CMI9880
|
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
Conexant CX20549 (Venice)
|
|
|
|
.It
|
|
|
|
Conexant CX20551 (Waikiki)
|
2006-10-01 11:16:31 +00:00
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
Conexant CX20561 (Hermosa)
|
2006-10-08 19:57:53 +00:00
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
Realtek ALC260
|
|
|
|
.It
|
2007-05-05 10:33:28 +00:00
|
|
|
Realtek ALC262
|
|
|
|
.It
|
2007-07-14 12:35:29 +00:00
|
|
|
Realtek ALC268
|
|
|
|
.It
|
2007-06-12 15:26:41 +00:00
|
|
|
Realtek ALC660
|
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
Realtek ALC861
|
|
|
|
.It
|
2007-05-05 10:33:28 +00:00
|
|
|
Realtek ALC861VD
|
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
Realtek ALC880
|
|
|
|
.It
|
|
|
|
Realtek ALC882
|
|
|
|
.It
|
2006-10-08 19:57:53 +00:00
|
|
|
Realtek ALC883
|
|
|
|
.It
|
2007-05-05 10:33:28 +00:00
|
|
|
Realtek ALC885
|
|
|
|
.It
|
2006-12-17 16:48:26 +00:00
|
|
|
Realtek ALC888
|
|
|
|
.It
|
2008-09-14 09:56:35 +00:00
|
|
|
Realtek ALC889
|
|
|
|
.It
|
2008-05-11 06:40:04 +00:00
|
|
|
Sigmatel STAC9205
|
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
Sigmatel STAC9220
|
|
|
|
.It
|
2008-09-14 09:56:35 +00:00
|
|
|
Sigmatel STAC9220D / 9223D
|
2006-10-08 19:57:53 +00:00
|
|
|
.It
|
2006-10-01 11:16:31 +00:00
|
|
|
Sigmatel STAC9221
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9221D
|
2006-12-17 16:48:26 +00:00
|
|
|
.It
|
2008-09-14 09:56:35 +00:00
|
|
|
Sigmatel STAC9227D
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9227X
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9228D
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9228X
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9229D
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9229X
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9230D
|
|
|
|
.It
|
|
|
|
Sigmatel STAC9230X
|
2007-02-16 18:23:17 +00:00
|
|
|
.It
|
|
|
|
Sigmatel STAC9271D
|
2007-05-05 10:33:28 +00:00
|
|
|
.It
|
2008-09-14 09:56:35 +00:00
|
|
|
Sigmatel STAC9872AK
|
|
|
|
.It
|
2007-05-05 10:33:28 +00:00
|
|
|
VIA VT1708
|
|
|
|
.It
|
2009-01-07 16:01:23 +00:00
|
|
|
VIA VT1708B
|
|
|
|
.It
|
2007-05-05 10:33:28 +00:00
|
|
|
VIA VT1709
|
2006-10-01 11:16:31 +00:00
|
|
|
.El
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr sound 4 ,
|
2009-01-06 11:11:58 +00:00
|
|
|
.Xr snd_ich 4 ,
|
2007-01-17 14:27:03 +00:00
|
|
|
.Xr device.hints 5 ,
|
|
|
|
.Xr loader.conf 5 ,
|
|
|
|
.Xr sysctl 8
|
2006-10-01 11:16:31 +00:00
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
device driver first appeared in
|
2008-01-04 12:57:34 +00:00
|
|
|
.Fx 6.3 .
|
2006-10-01 11:16:31 +00:00
|
|
|
.Sh AUTHORS
|
|
|
|
.An -nosplit
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
driver was written by
|
2008-09-13 17:01:38 +00:00
|
|
|
.An Stephane E. Potvin Aq sepotvin@videotron.ca ,
|
|
|
|
.An Ariff Abdullah Aq ariff@FreeBSD.org
|
2006-10-01 11:16:31 +00:00
|
|
|
and
|
2008-09-13 17:01:38 +00:00
|
|
|
.An Alexander Motin Aq mav@FreeBSD.org .
|
2006-10-01 11:16:31 +00:00
|
|
|
This manual page was written by
|
2008-11-06 21:47:02 +00:00
|
|
|
.An Joel Dahl Aq joel@FreeBSD.org ,
|
|
|
|
.An Alexander Motin Aq mav@FreeBSD.org
|
2008-09-13 17:01:38 +00:00
|
|
|
and
|
2008-11-06 21:47:02 +00:00
|
|
|
.An Giorgos Keramidas Aq keramida@FreeBSD.org .
|
2006-10-01 11:16:31 +00:00
|
|
|
.Sh BUGS
|
|
|
|
A few Hardware/OEM vendors tend to screw up BIOS settings, thus
|
|
|
|
rendering the
|
|
|
|
.Nm
|
|
|
|
driver useless, which usually results in a state where the
|
|
|
|
.Nm
|
2009-01-07 16:01:23 +00:00
|
|
|
driver seems to attach and work, but without any sound. Some of
|
|
|
|
that cases can be solved by tuning loader.conf variables. But before
|
|
|
|
trying to fix problem that way, make sure that problem is really exists
|
|
|
|
and the PCM audio device you are using really corresponds to expected
|
|
|
|
audio connector.
|
2008-09-17 20:17:22 +00:00
|
|
|
.Pp
|
2009-11-13 09:57:50 +00:00
|
|
|
Some vendors use non-standardized General Purpose I/O (GPIO) pins of codec
|
|
|
|
to control external amplifiers. In some cases setting proper combination of
|
|
|
|
GPIO bits may be needed to make sound work on specific device.
|
|
|
|
.Pp
|
|
|
|
HDMI and DisplayPort audio may also require support from video driver.
|