fixed sound in SDL/win32 port

This commit is contained in:
ekeeke31 2008-08-26 15:58:27 +00:00
parent 20b6adf7d4
commit 2fc0a8efca
3 changed files with 52 additions and 70 deletions

View File

@ -10,10 +10,9 @@ void set_config_defaults(void)
config.psg_preamp = 1.5; config.psg_preamp = 1.5;
config.fm_preamp = 1.0; config.fm_preamp = 1.0;
config.boost = 1; config.boost = 1;
config.filter = 0; config.filter = 1;
config.hq_fm = 1;
config.hq_fm = 0; config.fm_core = 0;
config.fm_core = 1;
/* system options */ /* system options */
config.region_detect = 0; config.region_detect = 0;

View File

@ -1,9 +1,9 @@
#include <windows.h> #include <windows.h>
#include <SDL.h> #include <SDL.h>
#include "shared.h" #include "shared.h"
#define SOUND_FREQUENCY 44100 #define SOUND_FREQUENCY 48000
int timer_count = 0; int timer_count = 0;
int old_timer_count = 0; int old_timer_count = 0;
@ -13,37 +13,19 @@ int frameticker = 0;
int joynum = 0; int joynum = 0;
int update_input(void); int update_input(void);
unsigned char *keystate; uint8 *keystate;
unsigned char buf[0x24000]; uint8 buf[0x24000];
static uint8 *soundbuffer; uint8 soundbuffer[16][3840];
static uint8 *mixbuffer; int mixbuffer = 0;
static int mixhead = 0; int playbuffer = 0;
static int mixtail = 0;
static int whichab = 0;
uint8 log_error = 0; uint8 log_error = 0;
uint8 debug_on = 0; uint8 debug_on = 0;
uint8 turbo_mode = 0; uint8 turbo_mode = 0;
uint8 use_sound = 1; /* NOT WORKING */ uint8 use_sound = 1;
static int mixercollect( uint8 *outbuffer, int len ) int audio_len;
{
uint32 *dst = (uint32 *)outbuffer;
uint32 *src = (uint32 *)mixbuffer;
int done = 0;
memset(outbuffer, 0, len);
while ( ( mixtail != mixhead ) && ( done < len ) )
{
*dst++ = src[mixtail++];
if (mixtail == whichab) mixtail = 0;
done += 4;
}
return done;
}
Uint32 fps_callback(Uint32 interval) Uint32 fps_callback(Uint32 interval)
{ {
@ -58,7 +40,7 @@ Uint32 fps_callback(Uint32 interval)
if (region_code == REGION_USA) sprintf(region,"USA"); if (region_code == REGION_USA) sprintf(region,"USA");
else if (region_code == REGION_EUROPE) sprintf(region,"EUR"); else if (region_code == REGION_EUROPE) sprintf(region,"EUR");
else sprintf(region,"JAP"); else sprintf(region,"JAP");
sprintf(caption, "Genesis Plus/SDL - %s (%s) - %d fps", rominfo.international, region, fps); sprintf(caption, "Genesis Plus/SDL - %s (%s) - %d fps - %d bytes", rominfo.international, region, fps, audio_len);
SDL_WM_SetCaption(caption, NULL); SDL_WM_SetCaption(caption, NULL);
frame_count = 0; frame_count = 0;
@ -68,51 +50,51 @@ Uint32 fps_callback(Uint32 interval)
static void sdl_sound_callback(void *userdata, Uint8 *stream, int len) static void sdl_sound_callback(void *userdata, Uint8 *stream, int len)
{ {
int actuallen = mixercollect( soundbuffer, len); audio_len = len;
memcpy(stream, soundbuffer[playbuffer], len);
memcpy(stream, soundbuffer, len); /* increment soundbuffers index */
playbuffer++;
playbuffer &= 0xf;
if (playbuffer == mixbuffer)
{
playbuffer--;
if ( playbuffer < 0 ) playbuffer = 15;
}
} }
int sdl_sound_init() static int sdl_sound_init()
{ {
SDL_InitSubSystem(SDL_INIT_AUDIO); SDL_AudioSpec audio;
SDL_AudioSpec as; if(SDL_Init(SDL_INIT_AUDIO) < 0)
as.freq = SOUND_FREQUENCY;
as.format = AUDIO_S16;
as.channels = 2;
as.samples = snd.buffer_size;
as.callback = sdl_sound_callback;
char caption[256];
if(SDL_OpenAudio(&as, 0) == -1)
{ {
char caption[256]; char caption[256];
sprintf(caption, "SDL open audio failed"); sprintf(caption, "SDL audio can't initialize");
MessageBox(NULL, caption, "Error", 0); MessageBox(NULL, caption, "Error", 0);
return 0; return 0;
} }
soundbuffer = (uint8 *)malloc(as.size); audio.freq = SOUND_FREQUENCY;
mixbuffer = (uint8 *)malloc(as.size * 4); audio.format = AUDIO_S16LSB;
whichab = as.size; audio.channels = 2;
audio.samples = snd.buffer_size;
audio.callback = sdl_sound_callback;
if(SDL_OpenAudio(&audio, NULL) == -1)
{
char caption[256];
sprintf(caption, "SDL can't open audio");
MessageBox(NULL, caption, "Error", 0);
return 0;
}
memset(soundbuffer, 0, 16 * 3840);
mixbuffer = 0;
playbuffer = 0;
return 1; return 1;
} }
static void sdl_sound_update()
{
int i;
uint32 *dst = (uint32 *)mixbuffer;
for(i = 0; i < snd.buffer_size; ++i)
{
dst[mixhead++] = (snd.buffer[0][i] & 0xffff) | ((snd.buffer[1][i] & 0xffff) <<16);
if (mixhead == whichab) mixhead = 0;
}
}
int main (int argc, char **argv) int main (int argc, char **argv)
{ {
int running = 1; int running = 1;
@ -212,14 +194,14 @@ int main (int argc, char **argv)
/* set default config */ /* set default config */
set_config_defaults(); set_config_defaults();
input.system[0] = SYSTEM_GAMEPAD; input.system[0] = SYSTEM_GAMEPAD;
input.system[1] = SYSTEM_GAMEPAD; input.system[1] = SYSTEM_MOUSE;
/* initialize emulation */ /* initialize emulation */
system_init(); system_init();
audio_init(SOUND_FREQUENCY); audio_init(SOUND_FREQUENCY);
/* initialize SDL audio */ /* initialize SDL audio */
if (use_sound) sdl_sound_init(); if (use_sound) use_sound = sdl_sound_init();
/* load SRAM */ /* load SRAM */
f = fopen("./game.srm", "rb"); f = fopen("./game.srm", "rb");
@ -360,7 +342,6 @@ int main (int argc, char **argv)
SDL_BlitSurface(bmp, &display, screen, &viewport); SDL_BlitSurface(bmp, &display, screen, &viewport);
SDL_UpdateRect(screen, viewport.x, viewport.y, viewport.w, viewport.h); SDL_UpdateRect(screen, viewport.x, viewport.y, viewport.w, viewport.h);
if (use_sound) sdl_sound_update();
} }
} }
@ -372,12 +353,12 @@ int main (int argc, char **argv)
fclose(f); fclose(f);
} }
system_shutdown();
SDL_PauseAudio(1); SDL_PauseAudio(1);
SDL_CloseAudio(); SDL_CloseAudio();
SDL_FreeSurface(bmp); SDL_FreeSurface(bmp);
SDL_FreeSurface(screen); SDL_FreeSurface(screen);
SDL_Quit(); SDL_Quit();
system_shutdown();
error_shutdown(); error_shutdown();
free(cart_rom); free(cart_rom);
@ -445,8 +426,8 @@ int update_input(void)
/* Map mouse buttons to player #1 inputs */ /* Map mouse buttons to player #1 inputs */
if(state & SDL_BUTTON_MMASK) input.pad[joynum] |= INPUT_C; if(state & SDL_BUTTON_MMASK) input.pad[joynum] |= INPUT_C;
if(state & SDL_BUTTON_RMASK) input.pad[joynum] |= INPUT_A; if(state & SDL_BUTTON_RMASK) input.pad[joynum] |= INPUT_B;
if(state & SDL_BUTTON_LMASK) input.pad[joynum] |= INPUT_B; if(state & SDL_BUTTON_LMASK) input.pad[joynum] |= INPUT_A;
} }
else if (system_hw == SYSTEM_PICO) else if (system_hw == SYSTEM_PICO)
{ {
@ -460,8 +441,8 @@ int update_input(void)
/* Map mouse buttons to player #1 inputs */ /* Map mouse buttons to player #1 inputs */
if(state & SDL_BUTTON_MMASK) pico_current++; if(state & SDL_BUTTON_MMASK) pico_current++;
if(state & SDL_BUTTON_RMASK) input.pad[joynum] |= INPUT_A; if(state & SDL_BUTTON_RMASK) input.pad[joynum] |= INPUT_B;
if(state & SDL_BUTTON_LMASK) input.pad[joynum] |= INPUT_B; if(state & SDL_BUTTON_LMASK) input.pad[joynum] |= INPUT_A;
} }

View File

@ -9,5 +9,7 @@ extern uint8 debug_on;
extern uint8 log_error; extern uint8 log_error;
extern int frame_count; extern int frame_count;
extern uint8 soundbuffer[16][3840];
extern int mixbuffer;
#endif /* _MAIN_H_ */ #endif /* _MAIN_H_ */