Corrected the emulated DAC’s range
This commit is contained in:
parent
0c231db9e7
commit
fc35111ae7
@ -21,7 +21,7 @@ static void refresh_channel(GB_gameboy_t *gb, unsigned index, unsigned cycles_of
|
|||||||
gb->apu_output.last_update[index] = gb->apu_output.cycles_since_render + cycles_offset;
|
gb->apu_output.last_update[index] = gb->apu_output.cycles_since_render + cycles_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void update_sample(GB_gameboy_t *gb, unsigned index, uint8_t value, unsigned cycles_offset)
|
static void update_sample(GB_gameboy_t *gb, unsigned index, int8_t value, unsigned cycles_offset)
|
||||||
{
|
{
|
||||||
gb->apu.samples[index] = value;
|
gb->apu.samples[index] = value;
|
||||||
if (gb->apu.is_active[index] && gb->apu_output.sample_rate) {
|
if (gb->apu.is_active[index] && gb->apu_output.sample_rate) {
|
||||||
@ -33,7 +33,7 @@ static void update_sample(GB_gameboy_t *gb, unsigned index, uint8_t value, unsig
|
|||||||
if (gb->io_registers[GB_IO_NR51] & (0x10 << index)) {
|
if (gb->io_registers[GB_IO_NR51] & (0x10 << index)) {
|
||||||
right_volume = ((gb->io_registers[GB_IO_NR50] >> 4) & 7) + 1;
|
right_volume = ((gb->io_registers[GB_IO_NR50] >> 4) & 7) + 1;
|
||||||
}
|
}
|
||||||
GB_sample_t output = {(0xf - value) * left_volume, (0xf - value) * right_volume};
|
GB_sample_t output = {(0xf - value * 2) * left_volume, (0xf - value * 2) * right_volume};
|
||||||
if (*(uint32_t *)&(gb->apu_output.current_sample[index]) != *(uint32_t *)&output) {
|
if (*(uint32_t *)&(gb->apu_output.current_sample[index]) != *(uint32_t *)&output) {
|
||||||
refresh_channel(gb, index, cycles_offset);
|
refresh_channel(gb, index, cycles_offset);
|
||||||
gb->apu_output.current_sample[index] = output;
|
gb->apu_output.current_sample[index] = output;
|
||||||
@ -51,9 +51,9 @@ static void render(GB_gameboy_t *gb)
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
refresh_channel(gb, i, 0);
|
refresh_channel(gb, i, 0);
|
||||||
output.left += (unsigned) gb->apu_output.summed_samples[i].left * CH_STEP
|
output.left += (signed long) gb->apu_output.summed_samples[i].left * CH_STEP
|
||||||
/ gb->apu_output.cycles_since_render;
|
/ gb->apu_output.cycles_since_render;
|
||||||
output.right += (unsigned) gb->apu_output.summed_samples[i].right * CH_STEP
|
output.right += (signed long) gb->apu_output.summed_samples[i].right * CH_STEP
|
||||||
/ gb->apu_output.cycles_since_render;
|
/ gb->apu_output.cycles_since_render;
|
||||||
gb->apu_output.summed_samples[i] = (GB_sample_t){0, 0};
|
gb->apu_output.summed_samples[i] = (GB_sample_t){0, 0};
|
||||||
}
|
}
|
||||||
|
@ -9,9 +9,9 @@
|
|||||||
/* Divides nicely and never overflows with 4 channels and 8 (1-8) volume levels */
|
/* Divides nicely and never overflows with 4 channels and 8 (1-8) volume levels */
|
||||||
#ifdef WIIU
|
#ifdef WIIU
|
||||||
/* Todo: Remove this hack once https://github.com/libretro/RetroArch/issues/6252 is fixed*/
|
/* Todo: Remove this hack once https://github.com/libretro/RetroArch/issues/6252 is fixed*/
|
||||||
#define MAX_CH_AMP (0x1FE0 / 4)
|
#define MAX_CH_AMP (0xFF0 / 2)
|
||||||
#else
|
#else
|
||||||
#define MAX_CH_AMP 0x1FE0
|
#define MAX_CH_AMP 0xFF0
|
||||||
#endif
|
#endif
|
||||||
#define CH_STEP (MAX_CH_AMP/0xF/8)
|
#define CH_STEP (MAX_CH_AMP/0xF/8)
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user