summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoriedowse <iedowse@FreeBSD.org>2003-08-23 13:00:48 +0000
committeriedowse <iedowse@FreeBSD.org>2003-08-23 13:00:48 +0000
commitf55f06a8e780ccafa615fab92e6997be0a320372 (patch)
tree0a5a92f86327e05b9b16db73c231f1c91a5b8eed
parente9326e0b09fccf6fcc7a8cacfc59facea165dde3 (diff)
downloadFreeBSD-src-f55f06a8e780ccafa615fab92e6997be0a320372.zip
FreeBSD-src-f55f06a8e780ccafa615fab92e6997be0a320372.tar.gz
When calculating the block size to use for a particular sample rate,
round the result up to a multiple of 4 bytes so that it will always be a multiple of the sample size. Also use the actual buffer size from sc->bufsz instead of the default DS1_BUFFSIZE. This fixes panics and bad distortion I have seen on Yamaha DS-1 hardware, mainly when playing certain Real Audio media. Reviewed by: orion (an earlier version of the patch)
-rw-r--r--sys/dev/sound/pci/ds1.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/sys/dev/sound/pci/ds1.c b/sys/dev/sound/pci/ds1.c
index 4acec37..dad3015 100644
--- a/sys/dev/sound/pci/ds1.c
+++ b/sys/dev/sound/pci/ds1.c
@@ -526,12 +526,13 @@ static int
ds1pchan_setblocksize(kobj_t obj, void *data, u_int32_t blocksize)
{
struct sc_pchinfo *ch = data;
+ struct sc_info *sc = ch->parent;
int drate;
/* irq rate is fixed at 187.5hz */
drate = ch->spd * sndbuf_getbps(ch->buffer);
- blocksize = (drate << 8) / DS1_IRQHZ;
- sndbuf_resize(ch->buffer, DS1_BUFFSIZE / blocksize, blocksize);
+ blocksize = roundup2((drate << 8) / DS1_IRQHZ, 4);
+ sndbuf_resize(ch->buffer, sc->bufsz / blocksize, blocksize);
return blocksize;
}
@@ -653,12 +654,13 @@ static int
ds1rchan_setblocksize(kobj_t obj, void *data, u_int32_t blocksize)
{
struct sc_rchinfo *ch = data;
+ struct sc_info *sc = ch->parent;
int drate;
/* irq rate is fixed at 187.5hz */
drate = ch->spd * sndbuf_getbps(ch->buffer);
- blocksize = (drate << 8) / DS1_IRQHZ;
- sndbuf_resize(ch->buffer, DS1_BUFFSIZE / blocksize, blocksize);
+ blocksize = roundup2((drate << 8) / DS1_IRQHZ, 4);
+ sndbuf_resize(ch->buffer, sc->bufsz / blocksize, blocksize);
return blocksize;
}
OpenPOWER on IntegriCloud