60 |
|
switch (opcode) { |
61 |
|
case M68K_EMUL_BREAK: { // Breakpoint |
62 |
|
printf("*** Breakpoint\n"); |
63 |
< |
printf("d0 %08x d1 %08x d2 %08x d3 %08x\n" |
64 |
< |
"d4 %08x d5 %08x d6 %08x d7 %08x\n" |
65 |
< |
"a0 %08x a1 %08x a2 %08x a3 %08x\n" |
66 |
< |
"a4 %08x a5 %08x a6 %08x a7 %08x\n" |
63 |
> |
printf("d0 %08lx d1 %08lx d2 %08lx d3 %08lx\n" |
64 |
> |
"d4 %08lx d5 %08lx d6 %08lx d7 %08lx\n" |
65 |
> |
"a0 %08lx a1 %08lx a2 %08lx a3 %08lx\n" |
66 |
> |
"a4 %08lx a5 %08lx a6 %08lx a7 %08lx\n" |
67 |
|
"sr %04x\n", |
68 |
|
r->d[0], r->d[1], r->d[2], r->d[3], r->d[4], r->d[5], r->d[6], r->d[7], |
69 |
|
r->a[0], r->a[1], r->a[2], r->a[3], r->a[4], r->a[5], r->a[6], r->a[7], |
70 |
|
r->sr); |
71 |
|
#ifdef ENABLE_MON |
72 |
< |
char *arg[2] = {"rmon", NULL}; |
73 |
< |
mon(1, arg); |
72 |
> |
char *arg[4] = {"mon", "-m", "-r", NULL}; |
73 |
> |
mon(3, arg); |
74 |
|
#endif |
75 |
|
QuitEmulator(); |
76 |
|
break; |
248 |
|
WriteMacInt8(asc_regs + 0x800, 0x0f); // Set ASC version number |
249 |
|
WriteMacInt32(0xcc0, asc_regs); // Set ASCBase |
250 |
|
} |
251 |
+ |
|
252 |
+ |
#if (REAL_ADDRESSING || DIRECT_ADDRESSING) && defined(USE_SCRATCHMEM_SUBTERFUGE) |
253 |
+ |
extern uint8 *ScratchMem; |
254 |
+ |
|
255 |
+ |
// Set VIA base address to scratch memory area |
256 |
+ |
D(bug("Patch VIA base address [0x%x] to ScratchMem\n", ReadMacInt32(0x1d4))); |
257 |
+ |
WriteMacInt32(0x1d4, Host2MacAddr(ScratchMem)); |
258 |
+ |
|
259 |
+ |
// Set SCCRd base address to scratch memory area |
260 |
+ |
D(bug("Patch SCCRd base address [0x%x] to ScratchMem\n", ReadMacInt32(0x1d8))); |
261 |
+ |
WriteMacInt32(0x1d8, Host2MacAddr(ScratchMem)); |
262 |
+ |
|
263 |
+ |
// Set SCCWr base address to scratch memory area |
264 |
+ |
D(bug("Patch SCCWr base address [0x%x] to ScratchMem\n", ReadMacInt32(0x1dc))); |
265 |
+ |
WriteMacInt32(0x1dc, Host2MacAddr(ScratchMem)); |
266 |
+ |
#endif |
267 |
|
break; |
268 |
|
} |
269 |
|
|
364 |
|
EtherReadPacket((uint8 **)&r->a[0], r->a[3], r->d[3], r->d[1]); |
365 |
|
break; |
366 |
|
|
367 |
+ |
case M68K_EMUL_OP_SOUNDIN_OPEN: // Sound input driver functions |
368 |
+ |
r->d[0] = SoundInOpen(r->a[0], r->a[1]); |
369 |
+ |
break; |
370 |
+ |
|
371 |
+ |
case M68K_EMUL_OP_SOUNDIN_PRIME: |
372 |
+ |
r->d[0] = SoundInPrime(r->a[0], r->a[1]); |
373 |
+ |
break; |
374 |
+ |
|
375 |
+ |
case M68K_EMUL_OP_SOUNDIN_CONTROL: |
376 |
+ |
r->d[0] = SoundInControl(r->a[0], r->a[1]); |
377 |
+ |
break; |
378 |
+ |
|
379 |
+ |
case M68K_EMUL_OP_SOUNDIN_STATUS: |
380 |
+ |
r->d[0] = SoundInStatus(r->a[0], r->a[1]); |
381 |
+ |
break; |
382 |
+ |
|
383 |
+ |
case M68K_EMUL_OP_SOUNDIN_CLOSE: |
384 |
+ |
r->d[0] = SoundInClose(r->a[0], r->a[1]); |
385 |
+ |
break; |
386 |
+ |
|
387 |
|
case M68K_EMUL_OP_SCSI_DISPATCH: { // SCSIDispatch() replacement |
388 |
|
uint32 ret = ReadMacInt32(r->a[7]); // Get return address |
389 |
|
uint16 sel = ReadMacInt16(r->a[7] + 4); // Get selector |
494 |
|
ClearInterruptFlag(INTFLAG_AUDIO); |
495 |
|
AudioInterrupt(); |
496 |
|
} |
497 |
+ |
|
498 |
+ |
if (InterruptFlags & INTFLAG_NMI) { |
499 |
+ |
ClearInterruptFlag(INTFLAG_NMI); |
500 |
+ |
if (HasMacStarted()) { |
501 |
+ |
TriggerNMI(); |
502 |
+ |
} |
503 |
+ |
} |
504 |
|
break; |
505 |
|
|
506 |
|
case M68K_EMUL_OP_PUT_SCRAP: { // PutScrap() patch |
539 |
|
break; |
540 |
|
#endif |
541 |
|
|
542 |
< |
case M68K_EMUL_OP_BLOCK_MOVE: // BlockMove() replacement |
543 |
< |
memmove(Mac2HostAddr(r->a[1]), Mac2HostAddr(r->a[0]), r->d[0]); |
542 |
> |
case M68K_EMUL_OP_BLOCK_MOVE: // BlockMove() cache flushing |
543 |
> |
FlushCodeCache(Mac2HostAddr(r->a[0]), r->a[1]); |
544 |
> |
break; |
545 |
> |
|
546 |
> |
case M68K_EMUL_OP_DEBUGUTIL: |
547 |
> |
// printf("DebugUtil d0=%08lx a5=%08lx\n", r->d[0], r->a[5]); |
548 |
> |
r->d[0] = DebugUtil(r->d[0]); |
549 |
|
break; |
550 |
|
|
551 |
|
default: |
552 |
< |
printf("FATAL: EMUL_OP called with bogus opcode %04x\n", opcode); |
553 |
< |
printf("d0 %08x d1 %08x d2 %08x d3 %08x\n" |
554 |
< |
"d4 %08x d5 %08x d6 %08x d7 %08x\n" |
555 |
< |
"a0 %08x a1 %08x a2 %08x a3 %08x\n" |
556 |
< |
"a4 %08x a5 %08x a6 %08x a7 %08x\n" |
552 |
> |
printf("FATAL: EMUL_OP called with bogus opcode %08x\n", opcode); |
553 |
> |
printf("d0 %08lx d1 %08lx d2 %08lx d3 %08lx\n" |
554 |
> |
"d4 %08lx d5 %08lx d6 %08lx d7 %08lx\n" |
555 |
> |
"a0 %08lx a1 %08lx a2 %08lx a3 %08lx\n" |
556 |
> |
"a4 %08lx a5 %08lx a6 %08lx a7 %08lx\n" |
557 |
|
"sr %04x\n", |
558 |
|
r->d[0], r->d[1], r->d[2], r->d[3], r->d[4], r->d[5], r->d[6], r->d[7], |
559 |
|
r->a[0], r->a[1], r->a[2], r->a[3], r->a[4], r->a[5], r->a[6], r->a[7], |
560 |
|
r->sr); |
561 |
|
#ifdef ENABLE_MON |
562 |
< |
char *arg[2] = {"rmon", NULL}; |
563 |
< |
mon(1, arg); |
562 |
> |
char *arg[4] = {"mon", "-m", "-r", NULL}; |
563 |
> |
mon(3, arg); |
564 |
|
#endif |
565 |
|
QuitEmulator(); |
566 |
|
break; |