- DSP DMA timer and count now using more accurate values for 16-bit mode

- wave buffer size increased
- log messages improved
This commit is contained in:
Volker Ruppert 2006-02-09 21:59:42 +00:00
parent e69a129d01
commit 409e18127b
2 changed files with 23 additions and 13 deletions

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: sb16.cc,v 1.45 2005-10-23 07:17:01 vruppert Exp $ // $Id: sb16.cc,v 1.46 2006-02-09 21:59:42 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -989,16 +989,21 @@ void bx_sb16_c::dsp_dma(Bit8u command, Bit8u mode, Bit16u length, Bit8u comp)
DSP.dma.blocklength = length; DSP.dma.blocklength = length;
DSP.dma.issigned = (mode >> 4) & 1; DSP.dma.issigned = (mode >> 4) & 1;
DSP.dma.count = (DSP.dma.blocklength + 1) * DSP.dma.bps - 1;
DSP.dma.highspeed = (comp >> 4) & 1; DSP.dma.highspeed = (comp >> 4) & 1;
DSP.dma.chunkindex = 0; DSP.dma.chunkindex = 0;
DSP.dma.chunkcount = 0; DSP.dma.chunkcount = 0;
Bit32u sampledatarate = (Bit32u) DSP.dma.samplerate * (Bit32u) DSP.dma.bps; Bit32u sampledatarate = (Bit32u) DSP.dma.samplerate * (Bit32u) DSP.dma.bps;
DSP.dma.timer = (Bit32u) bx_options.sb16.Odmatimer->get () / sampledatarate; if ((DSP.dma.bits == 16) && (BX_SB16_DMAH != 0)) {
DSP.dma.count = (DSP.dma.blocklength + 1) * (DSP.dma.bps / 2) - 1;
DSP.dma.timer = (Bit32u) bx_options.sb16.Odmatimer->get () / (sampledatarate / 2);
} else {
DSP.dma.count = (DSP.dma.blocklength + 1) * DSP.dma.bps - 1;
DSP.dma.timer = (Bit32u) bx_options.sb16.Odmatimer->get () / sampledatarate;
}
writelog( WAVELOG(5), "DMA is %db, %dHz, %s, %s, mode %d, %s, %s, %d bps, %d us/b", writelog( WAVELOG(5), "DMA is %db, %dHz, %s, %s, mode %d, %s, %s, %d bps, %d usec/DMA",
DSP.dma.bits, DSP.dma.samplerate, (DSP.dma.stereo != 0)?"stereo":"mono", DSP.dma.bits, DSP.dma.samplerate, (DSP.dma.stereo != 0)?"stereo":"mono",
(DSP.dma.output == 1)?"output":"input", DSP.dma.mode, (DSP.dma.output == 1)?"output":"input", DSP.dma.mode,
(DSP.dma.issigned == 1)?"signed":"unsigned", (DSP.dma.issigned == 1)?"signed":"unsigned",
@ -1229,7 +1234,11 @@ void bx_sb16_c::dsp_dmadone()
//if auto-DMA, reinitialize //if auto-DMA, reinitialize
if (DSP.dma.mode == 2) if (DSP.dma.mode == 2)
{ {
DSP.dma.count = (DSP.dma.blocklength + 1) * DSP.dma.bps - 1; if ((DSP.dma.bits == 16) && (BX_SB16_DMAH != 0)) {
DSP.dma.count = (DSP.dma.blocklength + 1) * (DSP.dma.bps / 2) - 1;
} else {
DSP.dma.count = (DSP.dma.blocklength + 1) * DSP.dma.bps - 1;
}
writelog( WAVELOG(4), "auto-DMA reinitializing to length %d", DSP.dma.count); writelog( WAVELOG(4), "auto-DMA reinitializing to length %d", DSP.dma.count);
} }
else else
@ -1278,7 +1287,7 @@ void bx_sb16_c::dma_read16(Bit16u *data_word)
DEV_dma_set_drq(BX_SB16_DMAH, 0); // the timer will raise it again DEV_dma_set_drq(BX_SB16_DMAH, 0); // the timer will raise it again
if (DSP.dma.count % 100 == 0) // otherwise it's just too many lines of log if (DSP.dma.count % 100 == 0) // otherwise it's just too many lines of log
writelog( WAVELOG(5), "Received 16-bit DMA %4x, %d remaining ", writelog( WAVELOG(5), "Received 16-bit DMA %04x, %d remaining ",
*data_word, DSP.dma.count); *data_word, DSP.dma.count);
DSP.dma.count--; DSP.dma.count--;
@ -1286,7 +1295,7 @@ void bx_sb16_c::dma_read16(Bit16u *data_word)
dsp_getsamplebyte(*data_word & 0xff); dsp_getsamplebyte(*data_word & 0xff);
dsp_getsamplebyte(*data_word >> 8); dsp_getsamplebyte(*data_word >> 8);
if (DSP.dma.count == 0xffff) // last byte received if (DSP.dma.count == 0xffff) // last word received
dsp_dmadone(); dsp_dmadone();
} }
@ -1308,7 +1317,7 @@ void bx_sb16_c::dma_write16(Bit16u *data_word)
writelog( WAVELOG(5), "Sent 16-bit DMA %4x, %d remaining ", writelog( WAVELOG(5), "Sent 16-bit DMA %4x, %d remaining ",
*data_word, DSP.dma.count); *data_word, DSP.dma.count);
if (DSP.dma.count == 0xffff) // last byte sent if (DSP.dma.count == 0xffff) // last word sent
dsp_dmadone(); dsp_dmadone();
} }

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: sb16.h,v 1.20 2005-02-04 19:50:50 vruppert Exp $ // $Id: sb16.h,v 1.21 2006-02-09 21:59:42 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -86,10 +86,11 @@
/* Definitions for the output functions */ /* Definitions for the output functions */
#define BX_SOUND_OUTPUT_OK 0 #define BX_SOUND_OUTPUT_OK 0
#define BX_SOUND_OUTPUT_ERR 1 #define BX_SOUND_OUTPUT_ERR 1
#define BX_SOUND_OUTPUT_WAVEPACKETSIZE 4096
// the is the size of a DMA chunk sent to output // this is the size of a DMA chunk sent to output
// it should not be too large to avoid lag, and not too // it should not be too large to avoid lag, and not too
// small to avoid unnecessary overhead. // small to avoid unnecessary overhead.
#define BX_SOUND_OUTPUT_WAVEPACKETSIZE 8192
#define BX_SB16_MIX_REG 0x100 // total number of mixer registers #define BX_SB16_MIX_REG 0x100 // total number of mixer registers