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.
112 lines
3.5 KiB
C
112 lines
3.5 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$
|
|
*/
|
|
|
|
struct pcm_feederdesc {
|
|
u_int32_t type;
|
|
u_int32_t in, out;
|
|
u_int32_t flags;
|
|
int idx;
|
|
};
|
|
|
|
struct feeder_class {
|
|
KOBJ_CLASS_FIELDS;
|
|
int align;
|
|
struct pcm_feederdesc *desc;
|
|
void *data;
|
|
};
|
|
|
|
struct pcm_feeder {
|
|
KOBJ_FIELDS;
|
|
int align;
|
|
struct pcm_feederdesc *desc, desc_static;
|
|
void *data;
|
|
struct feeder_class *class;
|
|
struct pcm_feeder *source, *parent;
|
|
|
|
};
|
|
|
|
void feeder_register(void *p);
|
|
struct feeder_class *feeder_getclass(struct pcm_feederdesc *desc);
|
|
|
|
u_int32_t chn_fmtscore(u_int32_t fmt);
|
|
u_int32_t chn_fmtbestbit(u_int32_t fmt, u_int32_t *fmts);
|
|
u_int32_t chn_fmtbeststereo(u_int32_t fmt, u_int32_t *fmts);
|
|
u_int32_t chn_fmtbest(u_int32_t fmt, u_int32_t *fmts);
|
|
u_int32_t chn_fmtchain(struct pcm_channel *c, u_int32_t *to);
|
|
int chn_addfeeder(struct pcm_channel *c, struct feeder_class *fc, struct pcm_feederdesc *desc);
|
|
int chn_removefeeder(struct pcm_channel *c);
|
|
struct pcm_feeder *chn_findfeeder(struct pcm_channel *c, u_int32_t type);
|
|
void feeder_printchain(struct pcm_feeder *head);
|
|
|
|
#define FEEDER_DECLARE(feeder, palign, pdata) \
|
|
static struct feeder_class feeder ## _class = { \
|
|
.name = #feeder, \
|
|
.methods = feeder ## _methods, \
|
|
.size = sizeof(struct pcm_feeder), \
|
|
.align = palign, \
|
|
.desc = feeder ## _desc, \
|
|
.data = pdata, \
|
|
}; \
|
|
SYSINIT(feeder, SI_SUB_DRIVERS, SI_ORDER_ANY, feeder_register, &feeder ## _class);
|
|
|
|
#define FEEDER_ROOT 1
|
|
#define FEEDER_FMT 2
|
|
#define FEEDER_MIXER 3
|
|
#define FEEDER_RATE 4
|
|
#define FEEDER_FILTER 5
|
|
#define FEEDER_VOLUME 6
|
|
#define FEEDER_LAST FEEDER_VOLUME
|
|
|
|
#define FEEDRATE_SRC 1
|
|
#define FEEDRATE_DST 2
|
|
|
|
#define FEEDRATE_RATEMIN 1
|
|
#define FEEDRATE_RATEMAX 2016000 /* 48000 * 42 */
|
|
|
|
#define FEEDRATE_MIN 1
|
|
#define FEEDRATE_MAX 0x7fffff /* sign 24bit ~ 8ghz ! */
|
|
|
|
#define FEEDRATE_ROUNDHZ 25
|
|
#define FEEDRATE_ROUNDHZ_MIN 0
|
|
#define FEEDRATE_ROUNDHZ_MAX 500
|
|
|
|
/*
|
|
* Default buffer size for feeder processing.
|
|
*
|
|
* Big = less sndbuf_feed(), more memory usage.
|
|
* Small = aggresive sndbuf_feed() (perhaps too much), less memory usage.
|
|
*/
|
|
#define FEEDBUFSZ 16384
|
|
#define FEEDBUFSZ_MIN 2048
|
|
#define FEEDBUFSZ_MAX 131072
|
|
|
|
extern int feeder_rate_min;
|
|
extern int feeder_rate_max;
|
|
extern int feeder_rate_round;
|
|
extern int feeder_buffersize;
|