mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-02-05 20:31:53 +00:00
Refactor : excised more DS deadc0de
This commit is contained in:
parent
3767f55846
commit
1679b8e76a
@ -47,81 +47,6 @@ typedef struct IDirectSoundBuffer {
|
||||
|
||||
#define DS_OK 0
|
||||
|
||||
// The call failed because resources (such as a priority level)
|
||||
// were already being used by another caller.
|
||||
#define DSERR_ALLOCATED 0x8878000A
|
||||
|
||||
// The control (vol,pan,etc.) requested by the caller is not available.
|
||||
#define DSERR_CONTROLUNAVAIL 0x8878001E
|
||||
|
||||
// An invalid parameter was passed to the returning function
|
||||
#define DSERR_INVALIDPARAM 0x80070057
|
||||
|
||||
// This call is not valid for the current state of this object
|
||||
#define DSERR_INVALIDCALL 0x88780032
|
||||
|
||||
// An undetermined error occured inside the DirectSound subsystem
|
||||
#define DSERR_GENERIC 0x80004005
|
||||
|
||||
// The caller does not have the priority level required for the function to
|
||||
// succeed.
|
||||
#define DSERR_PRIOLEVELNEEDED 0x88780046
|
||||
|
||||
// Not enough free memory is available to complete the operation
|
||||
#define DSERR_OUTOFMEMORY 0x8007000E
|
||||
|
||||
// The specified WAVE format is not supported
|
||||
#define DSERR_BADFORMAT 0x88780064
|
||||
|
||||
// The function called is not supported at this time
|
||||
#define DSERR_UNSUPPORTED 0x80004001
|
||||
|
||||
// No sound driver is available for use
|
||||
#define DSERR_NODRIVER 0x88780078
|
||||
|
||||
// This object is already initialized
|
||||
#define DSERR_ALREADYINITIALIZED 0x88780082
|
||||
|
||||
// This object does not support aggregation
|
||||
#define DSERR_NOAGGREGATION 0x80040110
|
||||
|
||||
// The buffer memory has been lost, and must be restored.
|
||||
#define DSERR_BUFFERLOST 0x88780096
|
||||
|
||||
// Another app has a higher priority level, preventing this call from
|
||||
// succeeding.
|
||||
#define DSERR_OTHERAPPHASPRIO 0x887800A0
|
||||
|
||||
// This object has not been initialized
|
||||
#define DSERR_UNINITIALIZED 0x887800AA
|
||||
|
||||
// The requested COM interface is not available
|
||||
#define DSERR_NOINTERFACE 0x80000004
|
||||
|
||||
// Access is denied
|
||||
#define DSERR_ACCESSDENIED 0x80070005
|
||||
|
||||
// Tried to create a DSBCAPS_CTRLFX buffer shorter than DSBSIZE_FX_MIN milliseconds
|
||||
#define DSERR_BUFFERTOOSMALL 0x887800B4
|
||||
|
||||
// Attempt to use DirectSound 8 functionality on an older DirectSound object
|
||||
#define DSERR_DS8_REQUIRED 0x887800BE
|
||||
|
||||
// A circular loop of send effects was detected
|
||||
#define DSERR_SENDLOOP 0x887800C8
|
||||
|
||||
// The GUID specified in an audiopath file does not match a valid MIXIN buffer
|
||||
#define DSERR_BADSENDBUFFERGUID 0x887800D2
|
||||
|
||||
// The object requested was not found (numerically equal to DMUS_E_NOT_FOUND)
|
||||
#define DSERR_OBJECTNOTFOUND 0x88781193
|
||||
|
||||
|
||||
#define DSBLOCK_FROMWRITECURSOR 0x1 // Locks from the current write position, making a call to IDirectSoundBuffer::GetCurrentPosition unnecessary. If this flag is specified, the dwWriteCursor parameter is ignored.
|
||||
#define DSBLOCK_ENTIREBUFFER 0x2 // Locks the entire buffer. The dwWriteBytes parameter is ignored.
|
||||
|
||||
|
||||
#define DSBSTATUS_BUFFERLOST 0x00000002
|
||||
#define DSBSTATUS_LOOPING 0x00000004
|
||||
#define DSBSTATUS_PLAYING 0x00000001
|
||||
#define _DSBSTATUS_NOTPLAYING 0x08000000
|
||||
@ -129,8 +54,6 @@ typedef struct IDirectSoundBuffer {
|
||||
#define DSBVOLUME_MIN -10000
|
||||
#define DSBVOLUME_MAX 0
|
||||
|
||||
#define DSSCL_NORMAL 0x00000001
|
||||
|
||||
#if defined(FAILED)
|
||||
#undef FAILED
|
||||
#endif
|
||||
@ -140,13 +63,6 @@ typedef struct IDirectSoundBuffer {
|
||||
static inline bool FAILED(int x) { return x != DS_OK; }
|
||||
static inline bool SUCCEEDED(int x) { return x == DS_OK; }
|
||||
|
||||
#define WAVE_FORMAT_PCM 0x0001
|
||||
#define DSBCAPS_GETCURRENTPOSITION2 0x00010000
|
||||
#define DSBCAPS_STICKYFOCUS 0x00004000
|
||||
#define DSBCAPS_LOCSOFTWARE 0x00000008
|
||||
#define DSBCAPS_CTRLVOLUME 0x00000080
|
||||
#define DSBCAPS_CTRLPOSITIONNOTIFY 0x00000100
|
||||
|
||||
typedef struct AudioParams_s {
|
||||
uint16_t nChannels;
|
||||
unsigned long nSamplesPerSec;
|
||||
@ -157,13 +73,9 @@ typedef struct AudioParams_s {
|
||||
} AudioParams_s;
|
||||
|
||||
typedef struct IDirectSound {
|
||||
|
||||
void *implementation_specific;
|
||||
|
||||
#define LPUNKNOWN void*
|
||||
int (*CreateSoundBuffer)(AudioParams_s *pcDSBufferDesc, LPDIRECTSOUNDBUFFER * ppDSBuffer, LPUNKNOWN pUnkOuter);
|
||||
int (*CreateSoundBuffer)(AudioParams_s *pcDSBufferDesc, LPDIRECTSOUNDBUFFER * ppDSBuffer, void *pUnkOuter);
|
||||
int (*DestroySoundBuffer)(LPDIRECTSOUNDBUFFER * ppDSBuffer);
|
||||
|
||||
} IDirectSound, *LPDIRECTSOUND;
|
||||
|
||||
#endif /* whole file */
|
||||
|
@ -26,6 +26,12 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
* Author: Copyright (c) 2002-2006, Tom Charlesworth
|
||||
*/
|
||||
|
||||
#define DSBCAPS_GETCURRENTPOSITION2 0x00010000
|
||||
#define DSBCAPS_STICKYFOCUS 0x00004000
|
||||
#define DSBCAPS_LOCSOFTWARE 0x00000008
|
||||
#define DSBCAPS_CTRLVOLUME 0x00000080
|
||||
#define DSBCAPS_CTRLPOSITIONNOTIFY 0x00000100
|
||||
|
||||
|
||||
// Linux port by Aaron Culliney, 2013
|
||||
|
||||
|
@ -65,24 +65,13 @@ bool DSGetLock(LPDIRECTSOUNDBUFFER pVoice, unsigned long dwOffset, unsigned long
|
||||
if(hr != DS_OK)
|
||||
return false;
|
||||
|
||||
if(nStatus & DSBSTATUS_BUFFERLOST)
|
||||
{
|
||||
do
|
||||
{
|
||||
hr = pVoice->Restore(pVoice->_this);
|
||||
if(hr == DSERR_BUFFERLOST)
|
||||
usleep(10);
|
||||
}
|
||||
while(hr != DS_OK);
|
||||
}
|
||||
|
||||
// Get write only pointer(s) to sound buffer
|
||||
if(dwBytes == 0)
|
||||
{
|
||||
if(FAILED(hr = pVoice->Lock(pVoice->_this, 0, 0,
|
||||
(void**)ppDSLockedBuffer0, pdwDSLockedBufferSize0,
|
||||
(void**)ppDSLockedBuffer1, pdwDSLockedBufferSize1,
|
||||
DSBLOCK_ENTIREBUFFER)))
|
||||
0)))
|
||||
return false;
|
||||
}
|
||||
else
|
||||
|
@ -324,7 +324,7 @@ void speaker_destroy(void) {
|
||||
void speaker_init(void) {
|
||||
SpeakerVoice.bIsSpeaker = true;
|
||||
SpeakerVoice.bActive = true;
|
||||
long err = DSGetSoundBuffer(&SpeakerVoice, DSBCAPS_CTRLVOLUME, SOUNDCORE_BUFFER_SIZE, SPKR_SAMPLE_RATE, 1);
|
||||
long err = DSGetSoundBuffer(&SpeakerVoice, 0, SOUNDCORE_BUFFER_SIZE, SPKR_SAMPLE_RATE, 1);
|
||||
assert(!err);
|
||||
_speaker_init_timing();
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user