Fixed Game Genie option menu

Added more EQ options in audio menu
This commit is contained in:
ekeeke31 2009-07-30 07:15:54 +00:00
parent d112fb72a2
commit f404e9eaa9
13 changed files with 87 additions and 61 deletions

View File

@ -6,7 +6,7 @@ Genesis Plus GX 1.4.0 (??/??/????) (Eke-Eke)
------ ------
* modified SN76489 cut-off frequency * modified SN76489 cut-off frequency
* implemented optimized SN76489 core from Blargg that uses Blip Buffer linear synthesis (Noise Channel is now linear interpolated) * implemented optimized SN76489 core which uses Blip Buffer linear synthesis (Noise Channel is now linear interpolated) (credits to Blargg)
* added an option to boost SN76489 Noise Channel * added an option to boost SN76489 Noise Channel
* removed outdated Gens YM2612 core * removed outdated Gens YM2612 core
* improved YM2612 core general accuracy (SSG-EG, CSM mode,...) (based upon Nemesis recent tests on real MD) * improved YM2612 core general accuracy (SSG-EG, CSM mode,...) (based upon Nemesis recent tests on real MD)
@ -18,6 +18,7 @@ when High Quality FM is enabled.
* improved VDP sprite masking emulation: fixes 3D level in Mickey Mania (thanks to Nemesis for his sprite test program) * improved VDP sprite masking emulation: fixes 3D level in Mickey Mania (thanks to Nemesis for his sprite test program)
* fixed lightgun autodetection: fixes cursor position in Lethal Enforcers II * fixed lightgun autodetection: fixes cursor position in Lethal Enforcers II
* improved DIVU/DVIS (thanks to Jorge Cwik) & MULU/MULS 68k instructions timing accuracy * improved DIVU/DVIS (thanks to Jorge Cwik) & MULU/MULS 68k instructions timing accuracy
* added Game Genie hardware emulation (this means Game Genie ROM file is now fully supported, see README for more details)
* various code cleanup & core optimizations * various code cleanup & core optimizations
[Gamecube/Wii] [Gamecube/Wii]

View File

@ -44,7 +44,7 @@ void ggenie_init(void)
memset(&ggenie,0,sizeof(ggenie)); memset(&ggenie,0,sizeof(ggenie));
/* load Game Genie ROM program */ /* load Game Genie ROM program */
FILE *f = fopen(GAMEGENIE_ROM,"rb"); FILE *f = fopen(GG_ROM,"rb");
if (!f) return; if (!f) return;
fread(ggenie.rom,1,0x8000,f); fread(ggenie.rom,1,0x8000,f);
fclose(f); fclose(f);
@ -97,7 +97,7 @@ void ggenie_reset(void)
/* Byte write handler */ /* Byte write handler */
/* Note: 2nd revision of the Game Genie software use byte writes to set registe values on exit */ /* Note: 2nd revision of the Game Genie software use byte writes to set register values on exit */
static void ggenie_write_byte(uint32 address, uint32 data) static void ggenie_write_byte(uint32 address, uint32 data)
{ {
/* Lock bit */ /* Lock bit */
@ -212,6 +212,6 @@ static void ggenie_write_regs(uint8 offset, uint32 data, uint8 type)
static uint32 ggenie_read_regs(uint32 address) static uint32 ggenie_read_regs(uint32 address)
{ {
if (address < 0x40) return ggenie.regs[address >> 1]; if (address < 0x40) return ggenie.regs[address >> 1];
else return *(uint16 *)(cart_rom + address); else return *(uint16 *)(cart_rom + address); /* is that correct ? */
} }

View File

@ -71,6 +71,8 @@ void config_default(void)
config.hq_fm = 1; config.hq_fm = 1;
config.psgBoostNoise = 0; config.psgBoostNoise = 0;
config.filter = 1; config.filter = 1;
config.low_freq = 200;
config.high_freq = 8000;
config.lg = 1.0; config.lg = 1.0;
config.mg = 1.0; config.mg = 1.0;
config.hg = 1.0; config.hg = 1.0;

View File

@ -36,6 +36,8 @@ typedef struct
int32 psg_preamp; int32 psg_preamp;
int32 fm_preamp; int32 fm_preamp;
uint8 filter; uint8 filter;
uint16 low_freq;
uint16 high_freq;
float lg; float lg;
float mg; float mg;
float hg; float hg;

View File

@ -513,7 +513,7 @@ int FileSelector(unsigned char *buffer, bool useFAT)
else else
{ {
/* user confirmation */ /* user confirmation */
if (GUI_ConfirmPrompt("Load this file ?")) if (GUI_ConfirmPrompt("Load selected File ?"))
{ {
/* Load ROM file from device */ /* Load ROM file from device */
if (useFAT) if (useFAT)

View File

@ -217,16 +217,18 @@ static gui_item items_options[5] =
}; };
/* Audio options menu */ /* Audio options menu */
static gui_item items_audio[8] = static gui_item items_audio[10] =
{ {
{NULL,NULL,"High-Quality FM: LINEAR", "Setup YM2612 resampling", 52,132,276,48}, {NULL,NULL,"High-Quality FM: LINEAR", "Setup YM2612 resampling", 52,132,276,48},
{NULL,NULL,"PSG Noise Boost: OFF", "Boost PSG Noise Channel", 52,132,276,48}, {NULL,NULL,"PSG Noise Boost: OFF", "Boost PSG Noise Channel", 52,132,276,48},
{NULL,NULL,"PSG Volume: 2.50", "Adjust SN76489 output level", 52,132,276,48}, {NULL,NULL,"PSG Volume: 2.50", "Adjust SN76489 output level", 52,132,276,48},
{NULL,NULL,"FM Volume: 1.00", "Adjust YM2612 output level", 52,132,276,48}, {NULL,NULL,"FM Volume: 1.00", "Adjust YM2612 output level", 52,132,276,48},
{NULL,NULL,"Filtering: 3-BAND EQ", "Setup Audio filtering", 52,132,276,48}, {NULL,NULL,"Filtering: 3-BAND EQ", "Setup Audio filtering", 52,132,276,48},
{NULL,NULL,"Low Gain: 1.00", "Adjust EQ Low Gain", 52,132,276,48}, {NULL,NULL,"Low Freq: 200 Hz", "Adjust EQ Low Band Frequency", 52,132,276,48},
{NULL,NULL,"Middle Gain: 1.00", "Adjust EQ Middle Gain", 52,132,276,48}, {NULL,NULL,"High Freq: 20000 Hz","Adjust EQ High Band Frequency",52,132,276,48},
{NULL,NULL,"High Gain: 1.00", "Adjust EQ High Gain", 52,132,276,48}, {NULL,NULL,"Low Gain: 1.00", "Adjust EQ Low Band Gain", 52,132,276,48},
{NULL,NULL,"Middle Gain: 1.00", "Adjust EQ Middle Band Gain", 52,132,276,48},
{NULL,NULL,"High Gain: 1.00", "Adjust EQ High BandGain", 52,132,276,48},
}; };
/* System options menu */ /* System options menu */
@ -439,7 +441,7 @@ static gui_menu menu_audio =
{ {
"Audio Settings", "Audio Settings",
0,0, 0,0,
8,4,6, 10,4,6,
items_audio, items_audio,
buttons_list, buttons_list,
bg_list, bg_list,
@ -708,16 +710,18 @@ static void soundmenu ()
if (config.filter == 2) sprintf (items[4].text, "Filtering: 3-BAND EQ"); if (config.filter == 2) sprintf (items[4].text, "Filtering: 3-BAND EQ");
else if (config.filter == 1) sprintf (items[4].text, "Filtering: LOW PASS"); else if (config.filter == 1) sprintf (items[4].text, "Filtering: LOW PASS");
else sprintf (items[4].text, "Filtering: OFF"); else sprintf (items[4].text, "Filtering: OFF");
sprintf (items[5].text, "Low Gain: %1.2f", config.lg); sprintf (items[5].text, "Low Freq: %d", config.low_freq);
sprintf (items[6].text, "Middle Gain: %1.2f", config.mg); sprintf (items[6].text, "High Freq: %d", config.high_freq);
sprintf (items[7].text, "High Gain: %1.2f", config.hg); sprintf (items[7].text, "Low Gain: %1.2f", config.lg);
sprintf (items[8].text, "Middle Gain: %1.2f", config.mg);
sprintf (items[9].text, "High Gain: %1.2f", config.hg);
GUI_InitMenu(m); GUI_InitMenu(m);
if (config.filter < 2) if (config.filter < 2)
m->max_items = 5; m->max_items = 5;
else else
m->max_items = 8; m->max_items = 10;
GUI_SlideMenuTitle(m,strlen("Audio ")); GUI_SlideMenuTitle(m,strlen("Audio "));
@ -781,28 +785,40 @@ static void soundmenu ()
else else
{ {
/* enable items */ /* enable items */
m->max_items = 8; m->max_items = 10;
/* intialize EQ */ /* intialize EQ */
audio_init_equalizer(); audio_set_equalizer();
} }
break; break;
case 5: case 5:
GUI_OptionBox(m,0,"Low Gain",(void *)&config.lg,0.01,0.0,2.0,0); GUI_OptionBox(m,0,"Low Frequency",(void *)&config.low_freq,10,0,config.high_freq,1);
sprintf (items[5].text, "Low Gain: %1.2f", config.lg); sprintf (items[5].text, "Low Freq: %d", config.low_freq);
audio_set_equalizer(); audio_set_equalizer();
break; break;
case 6: case 6:
GUI_OptionBox(m,0,"Middle Gain",(void *)&config.mg,0.01,0.0,2.0,0); GUI_OptionBox(m,0,"High Frequency",(void *)&config.high_freq,100,config.low_freq,30000,1);
sprintf (items[6].text, "Middle Gain: %1.2f", config.mg); sprintf (items[6].text, "High Freq: %d", config.high_freq);
audio_set_equalizer(); audio_set_equalizer();
break; break;
case 7: case 7:
GUI_OptionBox(m,0,"Low Gain",(void *)&config.lg,0.01,0.0,2.0,0);
sprintf (items[7].text, "Low Gain: %1.2f", config.lg);
audio_set_equalizer();
break;
case 8:
GUI_OptionBox(m,0,"Middle Gain",(void *)&config.mg,0.01,0.0,2.0,0);
sprintf (items[8].text, "Middle Gain: %1.2f", config.mg);
audio_set_equalizer();
break;
case 9:
GUI_OptionBox(m,0,"High Gain",(void *)&config.hg,0.01,0.0,2.0,0); GUI_OptionBox(m,0,"High Gain",(void *)&config.hg,0.01,0.0,2.0,0);
sprintf (items[7].text, "High Gain: %1.2f", config.hg); sprintf (items[9].text, "High Gain: %1.2f", config.hg);
audio_set_equalizer(); audio_set_equalizer();
break; break;
@ -917,10 +933,17 @@ static void systemmenu ()
if (config.lock_on > CART_GG) config.lock_on = NO_CART; if (config.lock_on > CART_GG) config.lock_on = NO_CART;
if (config.lock_on == CART_GG) sprintf (items[4].text, "Lock-On: GAME GENIE"); if (config.lock_on == CART_GG) sprintf (items[4].text, "Lock-On: GAME GENIE");
else sprintf (items[4].text, "Lock-On: OFF"); else sprintf (items[4].text, "Lock-On: OFF");
if (genromsize || (config.bios_enabled == 3))
{
system_init ();
audio_init(48000);
system_reset ();
}
break;
case 5: /*** SVP emulation ***/ case 5: /*** SVP emulation ***/
GUI_OptionBox(m,0,"SVP Cycles",(void *)&SVP_cycles,1,1,1500,1); GUI_OptionBox(m,0,"SVP Cycles",(void *)&SVP_cycles,1,1,1500,1);
sprintf (items[4].text, "SVP Cycles: %d", SVP_cycles); sprintf (items[5].text, "SVP Cycles: %d", SVP_cycles);
break; break;
case -1: case -1:

View File

@ -58,7 +58,7 @@ static void load_bios(void)
config.bios_enabled &= ~2; config.bios_enabled &= ~2;
/* open BIOS file */ /* open BIOS file */
FILE *fp = fopen(BIOS_ROM, "rb"); FILE *fp = fopen(OS_ROM, "rb");
if (fp == NULL) return; if (fp == NULL) return;
/* read file */ /* read file */

View File

@ -26,13 +26,13 @@
#include "file_mem.h" #include "file_mem.h"
#define DEFAULT_PATH "/genplus" #define DEFAULT_PATH "/genplus"
#define GAMEGENIE_ROM "/genplus/ggenie.bin" #define GG_ROM "/genplus/ggenie.bin"
#define BIOS_ROM "/genplus/bios.bin" #define OS_ROM "/genplus/bios.bin"
#ifdef HW_RVL #ifdef HW_RVL
#define VERSION "version 1.3.2cW" #define VERSION "version 1.3.3W"
#else #else
#define VERSION "version 1.3.2cG" #define VERSION "version 1.3.3G"
#endif #endif
/* globals */ /* globals */

View File

@ -109,7 +109,9 @@ double do_3band(EQSTATE * es, int sample)
// Calculate midrange (signal - (low + high)) // Calculate midrange (signal - (low + high))
m = es->sdm3 - (h + l); //m = es->sdm3 - (h + l);
// fix from http://www.musicdsp.org/showArchiveComment.php?ArchiveID=236 ?
m = sample - (h + l);
// Scale, Combine and store // Scale, Combine and store

View File

@ -95,7 +95,7 @@ void SN76489_Reset()
p->NoiseShiftRegister=NoiseInitialState; p->NoiseShiftRegister=NoiseInitialState;
/* Clear Blip delta buffer */ /* Clear Blip delta buffer */
blip_clear(p->blip_buffer); if (p->blip_buffer) blip_clear(p->blip_buffer);
} }
void SN76489_Shutdown(void) void SN76489_Shutdown(void)

View File

@ -917,19 +917,20 @@ INLINE void set_ar_ksr(FM_CH *CH,FM_SLOT *SLOT,int v)
CH->SLOT[SLOT1].Incr=-1; CH->SLOT[SLOT1].Incr=-1;
} }
/* Even if it seems unnecessary, in some odd case, KSR and KC are both modified */ /* Even if it seems unnecessary to do it here, it could happen that KSR and KC */
/* and could result in SLOT->kc remaining unchanged. */ /* but the resulted SLOT->ksr value (kc >> SLOT->KSR) remains unchanged. */
/* In such case, AR values would not be recalculated despite SLOT->ar has changed */ /* In such case, Attack Rate would not be recalculated by "refresh_fc_eg_slot". */
/* This fixes the introduction music of Batman & Robin (Eke-Eke) */ /* This fixes the intro of "The Adventures of Batman & Robin" (Eke-Eke) */
if ((SLOT->ar + SLOT->ksr) < 94 /*32+62*/) if ((SLOT->ar + SLOT->ksr) < (32+62))
{ {
SLOT->eg_sh_ar = eg_rate_shift [SLOT->ar + SLOT->ksr ]; SLOT->eg_sh_ar = eg_rate_shift [SLOT->ar + SLOT->ksr ];
SLOT->eg_sel_ar = eg_rate_select[SLOT->ar + SLOT->ksr ]; SLOT->eg_sel_ar = eg_rate_select[SLOT->ar + SLOT->ksr ];
} }
else else
{ {
/* verified by Nemesis on real hardware (Attack phase is blocked) */
SLOT->eg_sh_ar = 0; SLOT->eg_sh_ar = 0;
SLOT->eg_sel_ar = 18*RATE_STEPS; /* verified by Nemesis on real hardware (Attack phase is blocked) */ SLOT->eg_sel_ar = 18*RATE_STEPS;
} }
} }
@ -1392,15 +1393,16 @@ INLINE void refresh_fc_eg_slot(FM_SLOT *SLOT , int fc , int kc )
SLOT->ksr = ksr; SLOT->ksr = ksr;
/* recalculate envelope generator rates */ /* recalculate envelope generator rates */
if ((SLOT->ar + SLOT->ksr) < 94 /*32+62*/) if ((SLOT->ar + SLOT->ksr) < (32+62))
{ {
SLOT->eg_sh_ar = eg_rate_shift [SLOT->ar + SLOT->ksr ]; SLOT->eg_sh_ar = eg_rate_shift [SLOT->ar + SLOT->ksr ];
SLOT->eg_sel_ar = eg_rate_select[SLOT->ar + SLOT->ksr ]; SLOT->eg_sel_ar = eg_rate_select[SLOT->ar + SLOT->ksr ];
} }
else else
{ {
/* verified by Nemesis on real hardware (Attack phase is blocked) */
SLOT->eg_sh_ar = 0; SLOT->eg_sh_ar = 0;
SLOT->eg_sel_ar = 18*RATE_STEPS; /* verified by Nemesis on real hardware (Attack phase is blocked) */ SLOT->eg_sel_ar = 18*RATE_STEPS;
} }
SLOT->eg_sh_d1r = eg_rate_shift [SLOT->d1r + SLOT->ksr]; SLOT->eg_sh_d1r = eg_rate_shift [SLOT->d1r + SLOT->ksr];
@ -1952,6 +1954,14 @@ void YM2612Update(int length)
out_fm[4] = 0; out_fm[4] = 0;
out_fm[5] = 0; out_fm[5] = 0;
/* update SSG-EG output */
update_ssg_eg_channel(&ym2612.CH[0].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[1].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[2].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[3].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[4].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[5].SLOT[SLOT1]);
/* calculate FM */ /* calculate FM */
chan_calc(&ym2612.CH[0]); chan_calc(&ym2612.CH[0]);
chan_calc(&ym2612.CH[1]); chan_calc(&ym2612.CH[1]);
@ -1961,18 +1971,10 @@ void YM2612Update(int length)
if (ym2612.dacen) if (ym2612.dacen)
{ {
/* DAC Mode */ /* DAC Mode */
*(ym2612.CH[5].connect4) += ym2612.dacout; out_fm[5] = ym2612.dacout;
} }
else chan_calc(&ym2612.CH[5]); else chan_calc(&ym2612.CH[5]);
/* update SSG-EG output */
update_ssg_eg_channel(&ym2612.CH[0].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[1].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[2].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[3].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[4].SLOT[SLOT1]);
update_ssg_eg_channel(&ym2612.CH[5].SLOT[SLOT1]);
/* advance LFO */ /* advance LFO */
advance_lfo(); advance_lfo();

View File

@ -43,14 +43,9 @@ uint8 system_hw;
****************************************************************/ ****************************************************************/
static EQSTATE eq; static EQSTATE eq;
void audio_init_equalizer(void)
{
init_3band_state(&eq,880,5000,snd.sample_rate);
audio_set_equalizer();
}
void audio_set_equalizer(void) void audio_set_equalizer(void)
{ {
init_3band_state(&eq,config.low_freq,config.high_freq,snd.sample_rate);
eq.lg = (double)(config.lg); eq.lg = (double)(config.lg);
eq.mg = (double)(config.mg); eq.mg = (double)(config.mg);
eq.hg = (double)(config.hg); eq.hg = (double)(config.hg);
@ -101,10 +96,10 @@ void audio_update (int size)
if (filter & 1) if (filter & 1)
{ {
/* single-pole low-pass filter (6 dB/octave) */ /* single-pole low-pass filter (6 dB/octave) */
l = (ll + l) >> 1; ll = (ll + l) >> 1;
r = (rr + r) >> 1; rr = (rr + r) >> 1;
ll = l; l = ll;
rr = r; r = rr;
} }
else if (filter & 2) else if (filter & 2)
{ {
@ -174,7 +169,7 @@ int audio_init (int rate)
} }
/* 3 band EQ */ /* 3 band EQ */
audio_init_equalizer(); audio_set_equalizer();
/* Set audio enable flag */ /* Set audio enable flag */
snd.enabled = 1; snd.enabled = 1;

View File

@ -87,11 +87,10 @@ extern int32 current_z80;
extern uint8 system_hw; extern uint8 system_hw;
/* Function prototypes */ /* Function prototypes */
extern void audio_init_equalizer(void);
extern void audio_set_equalizer(void);
extern int audio_init (int rate); extern int audio_init (int rate);
extern void audio_shutdown (void); extern void audio_shutdown (void);
extern void audio_update (int len); extern void audio_update (int len);
extern void audio_set_equalizer(void);
extern void system_init (void); extern void system_init (void);
extern void system_reset (void); extern void system_reset (void);
extern void system_shutdown (void); extern void system_shutdown (void);