a580b31a54
in every sense. General ------- - Multichannel safe, endian safe, format safe * Large part of critical pcm filters such as vchan.c, feeder_rate.c, feeder_volume.c, feeder_fmt.c and feeder.c has been rewritten so that using them does not cause the pcm data to be converted to 16bit little endian. * Macrosses for accessing pcm data safely are defined within sound.h in the form of PCM_READ_* / PCM_WRITE_* * Currently, most of them are probably limited for mono/stereo handling, but the future addition of true multichannel will be much easier. - Low latency operation * Well, this require lot more works to do not just within sound driver, but we're heading towards right direction. Buffer/block sizing within channel.c is rewritten to calculate precise allocation for various combination of sample/data/rate size. As a result, applying correct SNDCTL_DSP_POLICY value will achive expected latency behaviour simmilar to what commercial 4front driver do. * Signal handling fix. ctrl+c of "cat /dev/zero > /dev/dsp" does not result long delay. * Eliminate sound truncation if the sound data is too small. DIY: 1) Download / extract http://people.freebsd.org/~ariff/lowlatency/shortfiles.tar.gz 2) Do a comparison between "cat state*.au > /dev/dsp" and "for x in state*.au ; do cat $x > /dev/dsp ; done" - there should be no "perceivable" differences. Double close for PR kern/31445. CAVEAT: Low latency come with (unbearable) price especially for poorly written applications. Applications that trying to act smarter by requesting (wrong) blocksize/blockcount will suffer the most. Fixup samples/patches can be found at: http://people.freebsd.org/~ariff/ports/ - Switch minimum/maximum sampling rate limit to "1" and "2016000" (48k * 42) due to closer compatibility with 4front driver. Discussed with: marcus@ (long time ago?) - All driver specific sysctls in the form of "hw.snd.pcm%d.*" have been moved to their own dev sysctl nodes, notably: hw.snd.pcm%d.vchans -> dev.pcm.%d.vchans Bump __FreeBSD_version. Driver specific --------------- - Ditto for sysctls. - snd_atiixp, snd_es137x, snd_via8233, snd_hda * Numerous cleanups and fixes. * _EXPERIMENTAL_ polling mode support using simple callout_* mechanisme. This was intended for pure debugging and latency measurement, but proven good enough in few unexpected and rare cases (such as problematic shared IRQ with GIANT devices - USB). Polling can be enabled/disabled through dev.pcm.0.polling. Disabled by default. - snd_ich * Fix possible overflow during speed calibration. Delay final initialization (pcm_setstatus) after calibration finished. PR: kern/100169 Tested by: Kevin Overman <oberman@es.net> * Inverted EAPD for few Nec VersaPro. PR: kern/104715 Submitted by: KAWATA Masahiko <kawata@mta.biglobe.ne.jp> Thanks to various people, notably Joel Dahl, Yuriy Tsibizov, Kevin Oberman, those at #freebsd-azalia @ freenode and others for testing. Joel Dahl will do the manpage update.
107 lines
3.9 KiB
C
107 lines
3.9 KiB
C
/*-
|
|
* Copyright (c) 1999 Cameron Grant <cg@freebsd.org>
|
|
* 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$
|
|
*/
|
|
|
|
#define AC97_MUTE 0x8080
|
|
|
|
#define AC97_REG_RESET 0x00
|
|
#define AC97_CAP_MICCHANNEL (1 << 0)
|
|
#define AC97_CAP_TONE (1 << 2)
|
|
#define AC97_CAP_SIMSTEREO (1 << 3)
|
|
#define AC97_CAP_HEADPHONE (1 << 4)
|
|
#define AC97_CAP_LOUDNESS (1 << 5)
|
|
#define AC97_CAP_DAC_18 (1 << 6)
|
|
#define AC97_CAP_DAC_20 (1 << 7)
|
|
#define AC97_CAP_ADC_18 (1 << 8)
|
|
#define AC97_CAP_ADC_20 (1 << 9)
|
|
#define AC97_MIX_MASTER 0x02
|
|
#define AC97_MIX_AUXOUT 0x04
|
|
#define AC97_MIX_MONO 0x06
|
|
#define AC97_MIX_TONE 0x08
|
|
#define AC97_MIX_BEEP 0x0a
|
|
#define AC97_MIX_PHONE 0x0c
|
|
#define AC97_MIX_MIC 0x0e
|
|
#define AC97_MIX_LINE 0x10
|
|
#define AC97_MIX_CD 0x12
|
|
#define AC97_MIX_VIDEO 0x14
|
|
#define AC97_MIX_AUX 0x16
|
|
#define AC97_MIX_PCM 0x18
|
|
#define AC97_REG_RECSEL 0x1a
|
|
#define AC97_MIX_RGAIN 0x1c
|
|
#define AC97_MIX_MGAIN 0x1e
|
|
#define AC97_REG_GEN 0x20
|
|
#define AC97_REG_3D 0x22
|
|
#define AC97_REG_POWER 0x26
|
|
#define AC97_POWER_ADC (1 << 0)
|
|
#define AC97_POWER_DAC (1 << 1)
|
|
#define AC97_POWER_ANL (1 << 2)
|
|
#define AC97_POWER_REF (1 << 3)
|
|
#define AC97_POWER_STATUS (AC97_POWER_ADC | AC97_POWER_DAC | \
|
|
AC97_POWER_REF | AC97_POWER_ANL )
|
|
#define AC97_REGEXT_ID 0x28
|
|
#define AC97_EXTCAP_VRA (1 << 0)
|
|
#define AC97_EXTCAP_DRA (1 << 1)
|
|
#define AC97_EXTCAP_VRM (1 << 3)
|
|
#define AC97_EXTCAPS (AC97_EXTCAP_VRA | AC97_EXTCAP_DRA | AC97_EXTCAP_VRM)
|
|
#define AC97_EXTCAP_SDAC (1 << 7)
|
|
|
|
#define AC97_REGEXT_STAT 0x2a
|
|
#define AC97_REGEXT_FDACRATE 0x2c
|
|
#define AC97_REGEXT_SDACRATE 0x2e
|
|
#define AC97_REGEXT_LDACRATE 0x30
|
|
#define AC97_REGEXT_LADCRATE 0x32
|
|
#define AC97_REGEXT_MADCRATE 0x34
|
|
#define AC97_MIXEXT_CLFE 0x36
|
|
#define AC97_MIXEXT_SURROUND 0x38
|
|
#define AC97_REG_ID1 0x7c
|
|
#define AC97_REG_ID2 0x7e
|
|
|
|
#define AC97_F_EAPD_INV 0x00000001
|
|
#define AC97_F_RDCD_BUG 0x00000002
|
|
|
|
#define AC97_DECLARE(name) static DEFINE_CLASS(name, name ## _methods, sizeof(struct kobj))
|
|
#define AC97_CREATE(dev, devinfo, cls) ac97_create(dev, devinfo, &cls ## _class)
|
|
|
|
struct ac97_info;
|
|
|
|
#include "ac97_if.h"
|
|
|
|
extern kobj_class_t ac97_getmixerclass(void);
|
|
|
|
struct ac97_info *ac97_create(device_t dev, void *devinfo, kobj_class_t cls);
|
|
void ac97_destroy(struct ac97_info *codec);
|
|
void ac97_setflags(struct ac97_info *codec, u_int32_t val);
|
|
u_int32_t ac97_getflags(struct ac97_info *codec);
|
|
int ac97_setrate(struct ac97_info *codec, int which, int rate);
|
|
int ac97_setextmode(struct ac97_info *codec, u_int16_t mode);
|
|
u_int16_t ac97_getextmode(struct ac97_info *codec);
|
|
u_int16_t ac97_getextcaps(struct ac97_info *codec);
|
|
u_int16_t ac97_getcaps(struct ac97_info *codec);
|
|
|
|
u_int16_t ac97_rdcd(struct ac97_info *codec, int reg);
|
|
void ac97_wrcd(struct ac97_info *codec, int reg, u_int16_t val);
|