Another 32x bug-fix

This commit is contained in:
Angelo Salese 2010-09-30 01:16:24 +00:00
parent 8d4b357fa9
commit 4a74bdbf24

View File

@ -638,7 +638,7 @@ static UINT16 vdp_get_word_from_68k_mem_default(running_machine *machine, UINT32
{ {
source -= 2; // the SVP introduces some kind of DMA 'lag', which we have to compensate for, this is obvious even on gfx DMAd from ROM (the Speedometer) source -= 2; // the SVP introduces some kind of DMA 'lag', which we have to compensate for, this is obvious even on gfx DMAd from ROM (the Speedometer)
} }
return space68k->read_word(source); return space68k->read_word(source);
} }
else if (( source >= 0xe00000 ) && ( source <= 0xffffff )) else if (( source >= 0xe00000 ) && ( source <= 0xffffff ))
@ -2368,7 +2368,7 @@ static WRITE16_HANDLER( _32x_68k_a15112_w )
// incase we have a stalled DMA in progress, let the SH2 know there is data available // incase we have a stalled DMA in progress, let the SH2 know there is data available
sh2_notify_dma_data_available(space->machine->device("32x_master_sh2")); sh2_notify_dma_data_available(space->machine->device("32x_master_sh2"));
sh2_notify_dma_data_available(space->machine->device("32x_slave_sh2")); sh2_notify_dma_data_available(space->machine->device("32x_slave_sh2"));
} }
current_fifo_write_pos = 0; current_fifo_write_pos = 0;
} }
@ -2428,7 +2428,7 @@ static WRITE16_HANDLER( _32x_68k_a15106_w )
if (a15106_reg & 0x1) /* NBA Jam TE relies on this */ if (a15106_reg & 0x1) /* NBA Jam TE relies on this */
{ {
// install the game rom in the normal 0x000000-0x03fffff space used by the genesis - this allows VDP DMA operations to work as they have to be from this area or RAM // install the game rom in the normal 0x000000-0x03fffff space used by the genesis - this allows VDP DMA operations to work as they have to be from this area or RAM
// it should also UNMAP the banked rom area... // it should also UNMAP the banked rom area...
memory_install_rom(space, 0x0000100, 0x03fffff, 0, 0, memory_region(space->machine, "gamecart") + 0x100); memory_install_rom(space, 0x0000100, 0x03fffff, 0, 0, memory_region(space->machine, "gamecart") + 0x100);
@ -2436,12 +2436,12 @@ static WRITE16_HANDLER( _32x_68k_a15106_w )
else else
{ {
// we should be careful and map back any rom overlay (hint) and backup ram too I think... // we should be careful and map back any rom overlay (hint) and backup ram too I think...
// this is actually blank / nop area // this is actually blank / nop area
// we should also map the banked area back (we don't currently unmap it tho) // we should also map the banked area back (we don't currently unmap it tho)
memory_install_rom(space, 0x0000100, 0x03fffff, 0, 0, memory_region(space->machine, "maincpu")+0x100); memory_install_rom(space, 0x0000100, 0x03fffff, 0, 0, memory_region(space->machine, "maincpu")+0x100);
} }
//printf("_32x_68k_a15106_w %04x\n", data); //printf("_32x_68k_a15106_w %04x\n", data);
/* /*
if (a15106_reg & 0x4) if (a15106_reg & 0x4)
@ -2583,7 +2583,7 @@ static WRITE16_HANDLER( _32x_68k_a15100_w )
memory_install_rom(space, 0x0880000, 0x08fffff, 0, 0, memory_region(space->machine, "gamecart")); // 'fixed' 512kb rom bank memory_install_rom(space, 0x0880000, 0x08fffff, 0, 0, memory_region(space->machine, "gamecart")); // 'fixed' 512kb rom bank
memory_install_read_bank(space, 0x0900000, 0x09fffff, 0, 0, "bank12"); // 'bankable' 1024kb rom bank memory_install_read_bank(space, 0x0900000, 0x09fffff, 0, 0, "bank12"); // 'bankable' 1024kb rom bank
memory_set_bankptr(space->machine, "bank12", memory_region(space->machine, "gamecart") ); memory_set_bankptr(space->machine, "bank12", memory_region(space->machine, "gamecart")+((_32x_68k_a15104_reg&0x3)*0x100000) );
memory_install_rom(space, 0x0000000, 0x03fffff, 0, 0, memory_region(space->machine, "32x_68k_bios")); memory_install_rom(space, 0x0000000, 0x03fffff, 0, 0, memory_region(space->machine, "32x_68k_bios"));
@ -2778,12 +2778,12 @@ static READ16_HANDLER( _32x_common_vdp_regs_r )
// printf("_32x_68k_a15180_r (a15180) %04x\n",mem_mask); // printf("_32x_68k_a15180_r (a15180) %04x\n",mem_mask);
// read needs authorization too I think, undefined behavior otherwise // read needs authorization too I think, undefined behavior otherwise
switch (offset) switch (offset)
{ {
case 0x00: case 0x00:
// the flag is inverted compared to the megadrive // the flag is inverted compared to the megadrive
int ntsc; int ntsc;
if (megadrive_region_pal) ntsc = 0; if (megadrive_region_pal) ntsc = 0;
@ -2793,21 +2793,21 @@ static READ16_HANDLER( _32x_common_vdp_regs_r )
(_32x_videopriority << 7 ) | (_32x_videopriority << 7 ) |
( _32x_240mode << 6 ) | ( _32x_240mode << 6 ) |
( _32x_displaymode << 0 ); ( _32x_displaymode << 0 );
case 0x02/2: case 0x02/2:
return _32x_screenshift; return _32x_screenshift;
case 0x04/2: case 0x04/2:
return _32x_autofill_length; return _32x_autofill_length;
case 0x06/2: case 0x06/2:
return _32x_autofill_address; return _32x_autofill_address;
case 0x08/2: case 0x08/2:
return _32x_autofill_data; return _32x_autofill_data;
case 0x0a/2: case 0x0a/2:
UINT16 retdata = _32x_a1518a_reg; UINT16 retdata = _32x_a1518a_reg;
UINT16 hpos = get_hposition(); UINT16 hpos = get_hposition();
@ -2826,7 +2826,7 @@ static READ16_HANDLER( _32x_common_vdp_regs_r )
return retdata; return retdata;
} }
return 0x0000; return 0x0000;
} }
@ -2835,7 +2835,7 @@ static READ16_HANDLER( _32x_common_vdp_regs_r )
static WRITE16_HANDLER( _32x_common_vdp_regs_w ) static WRITE16_HANDLER( _32x_common_vdp_regs_w )
{ {
// what happens if the z80 accesses it, what authorization do we use? which address space do we get?? the z80 *can* write here and to the framebuffer via the window // what happens if the z80 accesses it, what authorization do we use? which address space do we get?? the z80 *can* write here and to the framebuffer via the window
address_space* _68kspace = cputag_get_address_space(space->machine, "maincpu", ADDRESS_SPACE_PROGRAM); address_space* _68kspace = cputag_get_address_space(space->machine, "maincpu", ADDRESS_SPACE_PROGRAM);
if (space!= _68kspace) if (space!= _68kspace)
@ -2849,14 +2849,14 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
if (_32x_access_auth!=0) if (_32x_access_auth!=0)
return; return;
} }
switch (offset) switch (offset)
{ {
case 0x00: case 0x00:
printf("_32x_68k_a15180_w (a15180) %04x %04x source _32x_access_auth %04x\n",data,mem_mask, _32x_access_auth); printf("_32x_68k_a15180_w (a15180) %04x %04x source _32x_access_auth %04x\n",data,mem_mask, _32x_access_auth);
if (ACCESSING_BITS_0_7) if (ACCESSING_BITS_0_7)
{ {
_32x_videopriority = (data & 0x80) >> 7; _32x_videopriority = (data & 0x80) >> 7;
@ -2864,7 +2864,7 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
_32x_displaymode = (data & 0x03) >> 0; _32x_displaymode = (data & 0x03) >> 0;
} }
break; break;
case 0x02/2: case 0x02/2:
if (ACCESSING_BITS_0_7) if (ACCESSING_BITS_0_7)
{ {
@ -2875,7 +2875,7 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
} }
break; break;
case 0x04/2: case 0x04/2:
if (ACCESSING_BITS_0_7) if (ACCESSING_BITS_0_7)
{ {
@ -2887,7 +2887,7 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
} }
break; break;
case 0x06/2: case 0x06/2:
if (ACCESSING_BITS_0_7) if (ACCESSING_BITS_0_7)
{ {
@ -2899,7 +2899,7 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
_32x_autofill_address = (_32x_autofill_address & 0x00ff) | (data & 0xff00); _32x_autofill_address = (_32x_autofill_address & 0x00ff) | (data & 0xff00);
} }
break; break;
case 0x08/2: case 0x08/2:
if (ACCESSING_BITS_0_7) if (ACCESSING_BITS_0_7)
{ {
@ -2921,7 +2921,7 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
} }
} }
break; break;
case 0x0a/2: case 0x0a/2:
// bit 0 is the framebuffer select; // bit 0 is the framebuffer select;
_32x_a1518a_reg = (_32x_a1518a_reg & 0xfffe) | (data & 1); _32x_a1518a_reg = (_32x_a1518a_reg & 0xfffe) | (data & 1);
@ -2937,11 +2937,11 @@ static WRITE16_HANDLER( _32x_common_vdp_regs_w )
_32x_access_dram = _32x_dram1; _32x_access_dram = _32x_dram1;
} }
break; break;
} }
} }
@ -2999,7 +2999,7 @@ static WRITE16_HANDLER( _32x_sh2_master_4000_w )
if (sh2_master_hint_enable) printf("sh2_master_hint_enable enable!\n"); if (sh2_master_hint_enable) printf("sh2_master_hint_enable enable!\n");
//if (sh2_master_pwmint_enable) printf("sh2_master_pwn_enable enable!\n"); //if (sh2_master_pwmint_enable) printf("sh2_master_pwn_enable enable!\n");
_32x_check_irqs(space->machine); _32x_check_irqs(space->machine);
} }
} }
@ -5354,11 +5354,11 @@ static void genesis_render_videobuffer_to_screenbuffer(running_machine *machine,
{ {
lineptr[x] = _32x_linerender[x]&0x7fff; lineptr[x] = _32x_linerender[x]&0x7fff;
drawn = 1; drawn = 1;
} }
} }
} }
if (drawn==0) if (drawn==0)
{ {
if (dat&0x10000) if (dat&0x10000)
@ -5366,14 +5366,14 @@ static void genesis_render_videobuffer_to_screenbuffer(running_machine *machine,
else else
lineptr[x] = megadrive_vdp_palette_lookup[(dat&0x0f) | segac2_bg_pal_lookup[(dat&0x30)>>4]]; lineptr[x] = megadrive_vdp_palette_lookup[(dat&0x0f) | segac2_bg_pal_lookup[(dat&0x30)>>4]];
} }
} }
} }
else else
{ {
for (x=0;x<320;x++) for (x=0;x<320;x++)
{ {
UINT32 dat; UINT32 dat;
@ -5398,11 +5398,11 @@ static void genesis_render_videobuffer_to_screenbuffer(running_machine *machine,
{ {
lineptr[x] = _32x_linerender[x]&0x7fff; lineptr[x] = _32x_linerender[x]&0x7fff;
drawn = 1; drawn = 1;
} }
} }
} }
if (drawn==0) if (drawn==0)
{ {
/* Verify my handling.. I'm not sure all cases are correct */ /* Verify my handling.. I'm not sure all cases are correct */
@ -5442,9 +5442,9 @@ static void genesis_render_videobuffer_to_screenbuffer(running_machine *machine,
break; break;
} }
} }
} }
} }
@ -5790,7 +5790,7 @@ void _32x_check_irqs(running_machine* machine)
else cpu_set_input_line(_32x_master_cpu,SH2_VINT_IRQ_LEVEL,CLEAR_LINE); else cpu_set_input_line(_32x_master_cpu,SH2_VINT_IRQ_LEVEL,CLEAR_LINE);
if (sh2_slave_vint_enable && sh2_slave_vint_pending) cpu_set_input_line(_32x_slave_cpu,SH2_VINT_IRQ_LEVEL,ASSERT_LINE); if (sh2_slave_vint_enable && sh2_slave_vint_pending) cpu_set_input_line(_32x_slave_cpu,SH2_VINT_IRQ_LEVEL,ASSERT_LINE);
else cpu_set_input_line(_32x_slave_cpu,SH2_VINT_IRQ_LEVEL,CLEAR_LINE); else cpu_set_input_line(_32x_slave_cpu,SH2_VINT_IRQ_LEVEL,CLEAR_LINE);
} }
@ -5825,9 +5825,9 @@ static TIMER_DEVICE_CALLBACK( scanline_timer_callback )
// 32x interrupt! // 32x interrupt!
if (_32x_is_connected) if (_32x_is_connected)
{ {
sh2_master_vint_pending = 1; sh2_master_vint_pending = 1;
sh2_slave_vint_pending = 1; sh2_slave_vint_pending = 1;
_32x_check_irqs(timer.machine); _32x_check_irqs(timer.machine);
} }
} }