ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/cebix/BasiliskII/src/emul_op.cpp
(Generate patch)

Comparing BasiliskII/src/emul_op.cpp (file contents):
Revision 1.2 by cebix, 1999-10-05T14:59:43Z vs.
Revision 1.10 by cebix, 1999-10-27T16:59:34Z

# Line 39 | Line 39
39   #include "video.h"
40   #include "audio.h"
41   #include "ether.h"
42 + #include "extfs.h"
43   #include "emul_op.h"
44  
45 + #if ENABLE_MON
46 + #include "mon.h"
47 + #endif
48 +
49   #define DEBUG 0
50   #include "debug.h"
51  
# Line 63 | Line 68 | void EmulOp(uint16 opcode, M68kRegisters
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 + #if ENABLE_MON
72 +                        char *arg[2] = {"rmon", NULL};
73 +                        mon(1, arg);
74 + #endif
75                          QuitEmulator();
76                          break;
77                  }
# Line 295 | Line 304 | void EmulOp(uint16 opcode, M68kRegisters
304                          break;
305  
306                  case M68K_EMUL_OP_VIDEO_OPEN:           // Video driver functions
307 <                        r->d[0] = VideoOpen(r->a[0], r->a[1]);
307 >                        r->d[0] = VideoDriverOpen(r->a[0], r->a[1]);
308                          break;
309  
310                  case M68K_EMUL_OP_VIDEO_CONTROL:
311 <                        r->d[0] = VideoControl(r->a[0], r->a[1]);
311 >                        r->d[0] = VideoDriverControl(r->a[0], r->a[1]);
312                          break;
313  
314                  case M68K_EMUL_OP_VIDEO_STATUS:
315 <                        r->d[0] = VideoStatus(r->a[0], r->a[1]);
315 >                        r->d[0] = VideoDriverStatus(r->a[0], r->a[1]);
316                          break;
317  
318                  case M68K_EMUL_OP_SERIAL_OPEN:          // Serial driver functions
# Line 421 | Line 430 | void EmulOp(uint16 opcode, M68kRegisters
430                                          r->d[0] = 0;
431                                          break;
432                                  default:
433 <                                        printf("FATAL: MemoryDispatch(%d): illegal selector\n", sel);
433 >                                        printf("WARNING: MemoryDispatch(%d): unimplemented selector\n", sel);
434                                          r->d[0] = (uint32)-502;
435                                          break;
436                          }
# Line 434 | Line 443 | void EmulOp(uint16 opcode, M68kRegisters
443                                  ClearInterruptFlag(INTFLAG_60HZ);
444                                  if (HasMacStarted()) {
445  
446 <                                        // Mac has started, execute video, ADB and Time Manager interrupt functions
446 >                                        // Mac has started, execute all 60Hz interrupt functions
447                                          ADBInterrupt();
448                                          TimerInterrupt();
449                                          VideoInterrupt();
450 +                                        SonyInterrupt();
451 +                                        DiskInterrupt();
452 +                                        CDROMInterrupt();
453  
454                                          // Call DoVBLTask(0)
455                                          if (ROMVersion == ROM_VERSION_32) {
# Line 489 | Line 501 | void EmulOp(uint16 opcode, M68kRegisters
501                          r->d[0] = AudioDispatch(r->a[3], r->a[4]);
502                          break;
503  
504 + #if SUPPORTS_EXTFS
505 +                case M68K_EMUL_OP_EXTFS_COMM:           // External file system routines
506 +                        WriteMacInt16(r->a[7] + 14, ExtFSComm(ReadMacInt16(r->a[7] + 12), ReadMacInt32(r->a[7] + 8), ReadMacInt32(r->a[7] + 4)));
507 +                        break;
508 +
509 +                case M68K_EMUL_OP_EXTFS_HFS:
510 +                        WriteMacInt16(r->a[7] + 20, ExtFSHFS(ReadMacInt32(r->a[7] + 16), ReadMacInt16(r->a[7] + 14), ReadMacInt32(r->a[7] + 10), ReadMacInt32(r->a[7] + 6), ReadMacInt16(r->a[7] + 4)));
511 +                        break;
512 + #endif
513 +
514 +                case M68K_EMUL_OP_BLOCK_MOVE:           // BlockMove() replacement
515 +                        memmove(Mac2HostAddr(r->a[1]), Mac2HostAddr(r->a[0]), r->d[0]);
516 +                        break;
517 +
518                  default:
519                          printf("FATAL: EMUL_OP called with bogus opcode %08x\n", opcode);
520                          printf("d0 %08lx d1 %08lx d2 %08lx d3 %08lx\n"
# Line 499 | Line 525 | void EmulOp(uint16 opcode, M68kRegisters
525                                     r->d[0], r->d[1], r->d[2], r->d[3], r->d[4], r->d[5], r->d[6], r->d[7],
526                                     r->a[0], r->a[1], r->a[2], r->a[3], r->a[4], r->a[5], r->a[6], r->a[7],
527                                     r->sr);
528 + #if ENABLE_MON
529 +                        char *arg[2] = {"rmon", NULL};
530 +                        mon(1, arg);
531 + #endif
532                          QuitEmulator();
533                          break;
534          }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines