mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-02-02 21:22:40 +01:00
This commit is contained in:
parent
16cdbc33d2
commit
0f863ec61b
@ -50,6 +50,7 @@ void m68k_run (int cyc)
|
|||||||
/* interrupt handling */
|
/* interrupt handling */
|
||||||
if (vint_pending && (reg[1] & 0x20)) m68k_set_irq(6);
|
if (vint_pending && (reg[1] & 0x20)) m68k_set_irq(6);
|
||||||
else if (hint_pending && (reg[0] & 0x10)) m68k_set_irq(4);
|
else if (hint_pending && (reg[0] & 0x10)) m68k_set_irq(4);
|
||||||
|
else m68k_set_irq(0);
|
||||||
if (cyc_do > 0) m68k_execute(cyc_do);
|
if (cyc_do > 0) m68k_execute(cyc_do);
|
||||||
count_m68k += cyc_do;
|
count_m68k += cyc_do;
|
||||||
vint_pending = 0;
|
vint_pending = 0;
|
||||||
|
@ -469,10 +469,17 @@ void vdp_reg_w (uint8 r, uint8 d)
|
|||||||
switch (r)
|
switch (r)
|
||||||
{
|
{
|
||||||
case 0x00: /* CTRL #1 */
|
case 0x00: /* CTRL #1 */
|
||||||
|
/* update IRQ level */
|
||||||
|
if (!vint_pending && !(d & 0x10)) m68k_set_irq(0);
|
||||||
|
|
||||||
|
/* latch HVC */
|
||||||
if (!(d & 0x02)) hc_latch = -1;
|
if (!(d & 0x02)) hc_latch = -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x01: /* CTRL #2 */
|
case 0x01: /* CTRL #2 */
|
||||||
|
/* update IRQ level */
|
||||||
|
if (!hint_pending && !(d & 0x20)) m68k_set_irq(0);
|
||||||
|
|
||||||
/* Change the frame timing */
|
/* Change the frame timing */
|
||||||
frame_end = (d & 8) ? 0xF0 : 0xE0;
|
frame_end = (d & 8) ? 0xF0 : 0xE0;
|
||||||
|
|
||||||
@ -590,6 +597,5 @@ int vdp_int_ack_callback (int int_level)
|
|||||||
{
|
{
|
||||||
if (vint_pending) vint_pending = 0;
|
if (vint_pending) vint_pending = 0;
|
||||||
else hint_pending = 0;
|
else hint_pending = 0;
|
||||||
if (!hint_pending && !vint_pending) m68k_set_irq(0);
|
|
||||||
return M68K_INT_ACK_AUTOVECTOR;
|
return M68K_INT_ACK_AUTOVECTOR;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user