2 Skelton for retropc emulator
5 Author : Takeda.Toshiya
10 #if defined(_MSC_VER) && (_MSC_VER >= 1400)
11 #pragma warning( disable : 4996 )
15 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
20 #include "mc6800_consts.h"
21 #include "mc6801_consts.h"
23 /****************************************************************************/
25 /****************************************************************************/
27 uint32_t MC6801::RM(uint32_t Addr)
29 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
31 return mc6801_io_r(Addr);
32 } else if(Addr >= 0x80 && Addr < 0x100 && (ram_ctrl & 0x40)) {
33 return ram[Addr & 0x7f];
36 return d_mem->read_data8(Addr);
39 void MC6801::WM(uint32_t Addr, uint32_t Value)
41 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
43 mc6801_io_w(Addr, Value);
44 } else if(Addr >= 0x80 && Addr < 0x100 && (ram_ctrl & 0x40)) {
45 ram[Addr & 0x7f] = Value;
48 d_mem->write_data8(Addr, Value);
50 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
52 uint32_t MC6801::mc6801_io_r(uint32_t offset)
56 // port1 data direction register
59 // port2 data direction register
62 // port1 data register
63 return (port[0].rreg & ~port[0].ddr) | (port[0].wreg & port[0].ddr);
65 // port2 data register
66 return (port[1].rreg & ~port[1].ddr) | (port[1].wreg & port[1].ddr);
68 // port3 data direction register (write only???)
71 // port4 data direction register
74 // port3 data register
75 if(p3csr_is3_flag_read) {
76 p3csr_is3_flag_read = false;
77 p3csr &= ~P3CSR_IS3_FLAG;
80 port[2].latched = false;
81 return (port[2].latched_data & ~port[2].ddr) | (port[2].wreg & port[2].ddr);
83 return (port[2].rreg & ~port[2].ddr) | (port[2].wreg & port[2].ddr);
85 // port4 data register
86 return (port[3].rreg & ~port[3].ddr) | (port[3].wreg & port[3].ddr);
88 // timer control register
92 // free running counter (msb)
93 if(!(pending_tcsr & TCSR_TOF)) {
98 // free running counter (lsb)
101 // output compare register (msb)
102 if(!(pending_tcsr & TCSR_OCF)) {
105 return output_compare.b.h;
107 // output compare register (lsb)
108 if(!(pending_tcsr & TCSR_OCF)) {
111 return output_compare.b.l;
113 // input capture register (msb)
114 if(!(pending_tcsr & TCSR_ICF)) {
117 return (input_capture >> 0) & 0xff;
119 // input capture register (lsb)
120 return (input_capture >> 8) & 0xff;
122 // port3 control/status register
123 p3csr_is3_flag_read = true;
126 // rate and mode control register
129 if(trcsr & TRCSR_TDRE) {
130 trcsr_read_tdre = true;
132 if(trcsr & TRCSR_ORFE) {
133 trcsr_read_orfe = true;
135 if(trcsr & TRCSR_RDRF) {
136 trcsr_read_rdrf = true;
140 // receive data register
141 if(trcsr_read_orfe) {
142 trcsr_read_orfe = false;
143 trcsr &= ~TRCSR_ORFE;
145 if(trcsr_read_rdrf) {
146 trcsr_read_rdrf = false;
147 trcsr &= ~TRCSR_RDRF;
151 // transmit data register
154 // ram control register
155 return (ram_ctrl & 0x40) | 0x3f;
160 void MC6801::mc6801_io_w(uint32_t offset, uint32_t data)
164 // port1 data direction register
168 // port2 data direction register
172 // port1 data register
173 if(port[0].wreg != data || port[0].first_write) {
174 write_signals(&port[0].outputs, data);
176 port[0].first_write = false;
180 // port2 data register
181 if(port[1].wreg != data || port[1].first_write) {
182 write_signals(&port[1].outputs, data);
184 port[1].first_write = false;
188 // port3 data direction register
192 // port4 data direction register
196 // port3 data register
197 if(p3csr_is3_flag_read) {
198 p3csr_is3_flag_read = false;
199 p3csr &= ~P3CSR_IS3_FLAG;
201 if(port[2].wreg != data || port[2].first_write) {
202 write_signals(&port[2].outputs, data);
204 port[2].first_write = false;
208 // port4 data register
209 if(port[3].wreg != data || port[3].first_write) {
210 write_signals(&port[3].outputs, data);
212 port[3].first_write = false;
216 // timer control/status register
218 pending_tcsr &= tcsr;
221 // free running counter (msb)
223 // latch09 = data & 0xff;
231 // // free running counter (lsb)
232 // CT = (latch09 << 8) | (data & 0xff);
234 // MODIFIED_counters;
238 // output compare register (msb)
239 if(output_compare.b.h != data) {
240 output_compare.b.h = data;
246 // output compare register (lsb)
247 if(output_compare.b.l != data) {
248 output_compare.b.l = data;
254 // port3 control/status register
255 p3csr = (p3csr & P3CSR_IS3_FLAG) | (data & ~P3CSR_IS3_FLAG);
258 // rate and mode control register
262 // transmit/receive control/status register
263 trcsr = (trcsr & 0xe0) | (data & 0x1f);
266 // transmit data register
267 if(trcsr_read_tdre) {
268 trcsr_read_tdre = false;
269 trcsr &= ~TRCSR_TDRE;
274 // ram control register
280 void MC6801::increment_counter(int amount)
282 total_icount += amount;
286 if((CTD += amount) >= timer_next) {
289 OCH++; // next IRQ point
291 pending_tcsr |= TCSR_OCF;
295 TOH++; // next IRQ point
297 pending_tcsr |= TCSR_TOF;
304 if((sio_counter -= amount) <= 0) {
305 if((trcsr & TRCSR_TE) && !(trcsr & TRCSR_TDRE)) {
306 write_signals(&outputs_sio, tdr);
309 if((trcsr & TRCSR_RE) && !recv_buffer->empty()) {
310 if(trcsr & TRCSR_WU) {
314 } else if(!(trcsr & TRCSR_RDRF)) {
315 // note: wait reveived data is read by cpu, so overrun framing error never occurs
316 rdr = recv_buffer->read();
320 sio_counter += RMCR_SS[rmcr & 3];
326 void MC6801::initialize()
328 MC6800::initialize();
330 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
331 recv_buffer = new FIFO(0x10000);
334 //#ifdef USE_DEBUGGER
336 d_mem_stored = d_mem;
337 d_debugger->set_context_mem(d_mem);
341 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
342 void MC6801::release()
344 recv_buffer->release();
352 SEI; /* IRQ disabled */
361 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
362 for(int i = 0; i < 4; i++) {
364 port[i].first_write = true;
365 port[i].latched = false;
368 p3csr_is3_flag_read = false;
369 sc1_state = sc2_state = false;
371 tcsr = pending_tcsr = 0x00;
376 recv_buffer->clear();
378 trcsr_read_tdre = trcsr_read_orfe = trcsr_read_rdrf = false;
380 sio_counter = RMCR_SS[rmcr & 3];
386 void MC6801::write_signal(int id, uint32_t data, uint32_t mask)
391 int_state |= INT_REQ_BIT;
393 int_state &= ~INT_REQ_BIT;
398 int_state |= NMI_REQ_BIT;
400 int_state &= ~NMI_REQ_BIT;
403 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
404 case SIG_MC6801_PORT_1:
405 port[0].rreg = (port[0].rreg & ~mask) | (data & mask);
407 case SIG_MC6801_PORT_2:
408 if((mask & 1) && (port[1].rreg & 1) != (data & 1) && (tcsr & 2) == ((data << 1) & 2)) {
409 // active TIN edge in
411 pending_tcsr |= TCSR_ICF;
414 port[1].rreg = (port[1].rreg & ~mask) | (data & mask);
416 case SIG_MC6801_PORT_3:
417 port[2].rreg = (port[2].rreg & ~mask) | (data & mask);
419 case SIG_MC6801_PORT_4:
420 port[3].rreg = (port[3].rreg & ~mask) | (data & mask);
422 case SIG_MC6801_PORT_3_SC1:
423 if(sc1_state && !(data & mask)) {
425 if(!port[2].latched && (p3csr & P3CSR_LE)) {
426 port[2].latched_data = port[2].rreg;
427 port[2].latched = true;
428 p3csr |= P3CSR_IS3_FLAG;
431 sc1_state = ((data & mask) != 0);
433 case SIG_MC6801_PORT_3_SC2:
434 sc2_state = ((data & mask) != 0);
436 case SIG_MC6801_SIO_RECV:
437 recv_buffer->write(data & mask);
443 int MC6801::run(int clock)
447 // run only one opcode
455 /* run cpu while given clocks */
460 int first_icount = icount;
465 return first_icount - icount;
469 void MC6801::run_one_opecode()
471 if(wai_state & (MC6800_WAI | HD6301_SLP)) {
472 increment_counter(1);
475 one_more_insn = false;
477 bool now_debugging = d_debugger->now_debugging;
479 d_debugger->check_break_points(PC);
480 if(d_debugger->now_suspended) {
481 d_debugger->now_waiting = true;
482 emu->start_waiting_in_debugger();
483 while(d_debugger->now_debugging && d_debugger->now_suspended) {
484 emu->process_waiting_in_debugger();
486 emu->finish_waiting_in_debugger();
487 d_debugger->now_waiting = false;
489 if(d_debugger->now_debugging) {
492 now_debugging = false;
495 d_debugger->add_cpu_trace(PC);
496 uint8_t ireg = M_RDOP(PCD);
500 increment_counter(cycles[ireg]);
503 if(!d_debugger->now_going) {
504 d_debugger->now_suspended = true;
506 d_mem = d_mem_stored;
509 if(__USE_DEBUGGER) d_debugger->add_cpu_trace(PC);
510 uint8_t ireg = M_RDOP(PCD);
514 increment_counter(cycles[ireg]);
517 uint8_t ireg = M_RDOP(PCD);
521 increment_counter(cycles[ireg]);
523 } while(one_more_insn);
527 if(int_state & NMI_REQ_BIT) {
528 wai_state &= ~HD6301_SLP;
529 int_state &= ~NMI_REQ_BIT;
530 enter_interrupt(0xfffc);
531 } else if(int_state & INT_REQ_BIT) {
532 wai_state &= ~HD6301_SLP;
534 int_state &= ~INT_REQ_BIT;
535 enter_interrupt(0xfff8);
537 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
538 } else if((tcsr & (TCSR_EICI | TCSR_ICF)) == (TCSR_EICI | TCSR_ICF)) {
539 wai_state &= ~HD6301_SLP;
543 } else if((tcsr & (TCSR_EOCI | TCSR_OCF)) == (TCSR_EOCI | TCSR_OCF)) {
544 wai_state &= ~HD6301_SLP;
548 } else if((tcsr & (TCSR_ETOI | TCSR_TOF)) == (TCSR_ETOI | TCSR_TOF)) {
549 wai_state &= ~HD6301_SLP;
553 } else if(((trcsr & (TRCSR_RIE | TRCSR_RDRF)) == (TRCSR_RIE | TRCSR_RDRF)) ||
554 ((trcsr & (TRCSR_RIE | TRCSR_ORFE)) == (TRCSR_RIE | TRCSR_ORFE)) ||
555 ((trcsr & (TRCSR_TIE | TRCSR_TDRE)) == (TRCSR_TIE | TRCSR_TDRE))) {
556 wai_state &= ~HD6301_SLP;
564 int MC6801::debug_dasm_with_userdata(uint32_t pc, _TCHAR *buffer, size_t buffer_len, uint32_t userdata)
567 for(int i = 0; i < 4; i++) {
569 ops[i] = d_mem_stored->read_data8w(pc + i, &wait);
571 return Dasm680x(6801, buffer, pc, ops, ops, d_debugger->first_symbol);
575 void MC6801::insn(uint8_t code)
578 case 0x00: illegal(); break;
579 case 0x01: nop(); break;
580 case 0x02: illegal(); break;
581 case 0x03: illegal(); break;
582 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
583 case 0x04: lsrd(); break;
584 case 0x05: asld(); break;
586 // case 0x04: illegal(); break;
587 // case 0x05: illegal(); break;
589 case 0x06: tap(); break;
590 case 0x07: tpa(); break;
591 case 0x08: inx(); break;
592 case 0x09: dex(); break;
593 case 0x0a: clv(); break;
594 case 0x0b: sev(); break;
595 case 0x0c: clc(); break;
596 case 0x0d: sec(); break;
597 case 0x0e: cli(); break;
598 case 0x0f: sei(); break;
599 case 0x10: sba(); break;
600 case 0x11: cba(); break;
601 //#if defined(HAS_HD6301)
602 // case 0x12: undoc1(); break;
603 // case 0x13: undoc2(); break;
605 case 0x12: illegal(); break;
606 case 0x13: illegal(); break;
608 case 0x14: illegal(); break;
609 case 0x15: illegal(); break;
610 case 0x16: tab(); break;
611 case 0x17: tba(); break;
612 //#if defined(HAS_HD6301)
613 // case 0x18: xgdx(); break;
615 case 0x18: illegal(); break;
617 case 0x19: daa(); break;
618 //#if defined(HAS_HD6301)
619 // case 0x1a: slp(); break;
621 case 0x1a: illegal(); break;
623 case 0x1b: aba(); break;
624 case 0x1c: illegal(); break;
625 case 0x1d: illegal(); break;
626 case 0x1e: illegal(); break;
627 case 0x1f: illegal(); break;
628 case 0x20: bra(); break;
629 case 0x21: brn(); break;
630 case 0x22: bhi(); break;
631 case 0x23: bls(); break;
632 case 0x24: bcc(); break;
633 case 0x25: bcs(); break;
634 case 0x26: bne(); break;
635 case 0x27: beq(); break;
636 case 0x28: bvc(); break;
637 case 0x29: bvs(); break;
638 case 0x2a: bpl(); break;
639 case 0x2b: bmi(); break;
640 case 0x2c: bge(); break;
641 case 0x2d: blt(); break;
642 case 0x2e: bgt(); break;
643 case 0x2f: ble(); break;
644 case 0x30: tsx(); break;
645 case 0x31: ins(); break;
646 case 0x32: pula(); break;
647 case 0x33: pulb(); break;
648 case 0x34: des(); break;
649 case 0x35: txs(); break;
650 case 0x36: psha(); break;
651 case 0x37: pshb(); break;
652 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
653 case 0x38: pulx(); break;
655 // case 0x38: illegal(); break;
657 case 0x39: rts(); break;
658 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
659 case 0x3a: abx(); break;
661 // case 0x3a: illegal(); break;
663 case 0x3b: rti(); break;
664 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
665 case 0x3c: pshx(); break;
666 case 0x3d: mul(); break;
668 // case 0x3c: illegal(); break;
669 // case 0x3d: illegal(); break;
671 case 0x3e: wai(); break;
672 case 0x3f: swi(); break;
673 case 0x40: nega(); break;
674 case 0x41: illegal(); break;
675 case 0x42: illegal(); break;
676 case 0x43: coma(); break;
677 case 0x44: lsra(); break;
678 case 0x45: illegal(); break;
679 case 0x46: rora(); break;
680 case 0x47: asra(); break;
681 case 0x48: asla(); break;
682 case 0x49: rola(); break;
683 case 0x4a: deca(); break;
684 case 0x4b: illegal(); break;
685 case 0x4c: inca(); break;
686 case 0x4d: tsta(); break;
687 case 0x4e: illegal(); break;
688 case 0x4f: clra(); break;
689 case 0x50: negb(); break;
690 case 0x51: illegal(); break;
691 case 0x52: illegal(); break;
692 case 0x53: comb(); break;
693 case 0x54: lsrb(); break;
694 case 0x55: illegal(); break;
695 case 0x56: rorb(); break;
696 case 0x57: asrb(); break;
697 case 0x58: aslb(); break;
698 case 0x59: rolb(); break;
699 case 0x5a: decb(); break;
700 case 0x5b: illegal(); break;
701 case 0x5c: incb(); break;
702 case 0x5d: tstb(); break;
703 case 0x5e: illegal(); break;
704 case 0x5f: clrb(); break;
705 case 0x60: neg_ix(); break;
706 //#if defined(HAS_HD6301)
707 // case 0x61: aim_ix(); break;
708 // case 0x62: oim_ix(); break;
710 case 0x61: illegal(); break;
711 case 0x62: illegal(); break;
713 case 0x63: com_ix(); break;
714 case 0x64: lsr_ix(); break;
715 //#if defined(HAS_HD6301)
716 // case 0x65: eim_ix(); break;
718 case 0x65: illegal(); break;
720 case 0x66: ror_ix(); break;
721 case 0x67: asr_ix(); break;
722 case 0x68: asl_ix(); break;
723 case 0x69: rol_ix(); break;
724 case 0x6a: dec_ix(); break;
725 //#if defined(HAS_HD6301)
726 // case 0x6b: tim_ix(); break;
728 case 0x6b: illegal(); break;
730 case 0x6c: inc_ix(); break;
731 case 0x6d: tst_ix(); break;
732 case 0x6e: jmp_ix(); break;
733 case 0x6f: clr_ix(); break;
734 case 0x70: neg_ex(); break;
735 //#if defined(HAS_HD6301)
736 // case 0x71: aim_di(); break;
737 // case 0x72: oim_di(); break;
738 //#elif defined(HAS_MB8861)
739 // case 0x71: nim_ix(); break;
740 // case 0x72: oim_ix_mb8861(); break;
742 case 0x71: illegal(); break;
743 case 0x72: illegal(); break;
745 case 0x73: com_ex(); break;
746 case 0x74: lsr_ex(); break;
747 //#if defined(HAS_HD6301)
748 // case 0x75: eim_di(); break;
749 //#elif defined(HAS_MB8861)
750 // case 0x75: xim_ix(); break;
752 case 0x75: illegal(); break;
754 case 0x76: ror_ex(); break;
755 case 0x77: asr_ex(); break;
756 case 0x78: asl_ex(); break;
757 case 0x79: rol_ex(); break;
758 case 0x7a: dec_ex(); break;
759 //#if defined(HAS_HD6301)
760 // case 0x7b: tim_di(); break;
761 //#elif defined(HAS_MB8861)
762 // case 0x7b: tmm_ix(); break;
764 case 0x7b: illegal(); break;
766 case 0x7c: inc_ex(); break;
767 case 0x7d: tst_ex(); break;
768 case 0x7e: jmp_ex(); break;
769 case 0x7f: clr_ex(); break;
770 case 0x80: suba_im(); break;
771 case 0x81: cmpa_im(); break;
772 case 0x82: sbca_im(); break;
773 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
774 case 0x83: subd_im(); break;
776 // case 0x83: illegal(); break;
778 case 0x84: anda_im(); break;
779 case 0x85: bita_im(); break;
780 case 0x86: lda_im(); break;
781 case 0x87: sta_im(); break;
782 case 0x88: eora_im(); break;
783 case 0x89: adca_im(); break;
784 case 0x8a: ora_im(); break;
785 case 0x8b: adda_im(); break;
786 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
787 case 0x8c: cpx_im (); break;
789 // case 0x8c: cmpx_im(); break;
791 case 0x8d: bsr(); break;
792 case 0x8e: lds_im(); break;
793 case 0x8f: sts_im(); break;
794 case 0x90: suba_di(); break;
795 case 0x91: cmpa_di(); break;
796 case 0x92: sbca_di(); break;
797 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
798 case 0x93: subd_di(); break;
800 // case 0x93: illegal(); break;
802 case 0x94: anda_di(); break;
803 case 0x95: bita_di(); break;
804 case 0x96: lda_di(); break;
805 case 0x97: sta_di(); break;
806 case 0x98: eora_di(); break;
807 case 0x99: adca_di(); break;
808 case 0x9a: ora_di(); break;
809 case 0x9b: adda_di(); break;
810 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
811 case 0x9c: cpx_di (); break;
813 // case 0x9c: cmpx_di(); break;
815 case 0x9d: jsr_di(); break;
816 case 0x9e: lds_di(); break;
817 case 0x9f: sts_di(); break;
818 case 0xa0: suba_ix(); break;
819 case 0xa1: cmpa_ix(); break;
820 case 0xa2: sbca_ix(); break;
821 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
822 case 0xa3: subd_ix(); break;
824 // case 0xa3: illegal(); break;
826 case 0xa4: anda_ix(); break;
827 case 0xa5: bita_ix(); break;
828 case 0xa6: lda_ix(); break;
829 case 0xa7: sta_ix(); break;
830 case 0xa8: eora_ix(); break;
831 case 0xa9: adca_ix(); break;
832 case 0xaa: ora_ix(); break;
833 case 0xab: adda_ix(); break;
834 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
835 case 0xac: cpx_ix (); break;
837 // case 0xac: cmpx_ix(); break;
839 case 0xad: jsr_ix(); break;
840 case 0xae: lds_ix(); break;
841 case 0xaf: sts_ix(); break;
842 case 0xb0: suba_ex(); break;
843 case 0xb1: cmpa_ex(); break;
844 case 0xb2: sbca_ex(); break;
845 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
846 case 0xb3: subd_ex(); break;
848 // case 0xb3: illegal(); break;
850 case 0xb4: anda_ex(); break;
851 case 0xb5: bita_ex(); break;
852 case 0xb6: lda_ex(); break;
853 case 0xb7: sta_ex(); break;
854 case 0xb8: eora_ex(); break;
855 case 0xb9: adca_ex(); break;
856 case 0xba: ora_ex(); break;
857 case 0xbb: adda_ex(); break;
858 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
859 case 0xbc: cpx_ex (); break;
861 // case 0xbc: cmpx_ex(); break;
863 case 0xbd: jsr_ex(); break;
864 case 0xbe: lds_ex(); break;
865 case 0xbf: sts_ex(); break;
866 case 0xc0: subb_im(); break;
867 case 0xc1: cmpb_im(); break;
868 case 0xc2: sbcb_im(); break;
869 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
870 case 0xc3: addd_im(); break;
872 // case 0xc3: illegal(); break;
874 case 0xc4: andb_im(); break;
875 case 0xc5: bitb_im(); break;
876 case 0xc6: ldb_im(); break;
877 case 0xc7: stb_im(); break;
878 case 0xc8: eorb_im(); break;
879 case 0xc9: adcb_im(); break;
880 case 0xca: orb_im(); break;
881 case 0xcb: addb_im(); break;
882 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
883 case 0xcc: ldd_im(); break;
884 case 0xcd: std_im(); break;
886 // case 0xcc: illegal(); break;
887 // case 0xcd: illegal(); break;
889 case 0xce: ldx_im(); break;
890 case 0xcf: stx_im(); break;
891 case 0xd0: subb_di(); break;
892 case 0xd1: cmpb_di(); break;
893 case 0xd2: sbcb_di(); break;
894 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
895 case 0xd3: addd_di(); break;
897 // case 0xd3: illegal(); break;
899 case 0xd4: andb_di(); break;
900 case 0xd5: bitb_di(); break;
901 case 0xd6: ldb_di(); break;
902 case 0xd7: stb_di(); break;
903 case 0xd8: eorb_di(); break;
904 case 0xd9: adcb_di(); break;
905 case 0xda: orb_di(); break;
906 case 0xdb: addb_di(); break;
907 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
908 case 0xdc: ldd_di(); break;
909 case 0xdd: std_di(); break;
911 // case 0xdc: illegal(); break;
912 // case 0xdd: illegal(); break;
914 case 0xde: ldx_di(); break;
915 case 0xdf: stx_di(); break;
916 case 0xe0: subb_ix(); break;
917 case 0xe1: cmpb_ix(); break;
918 case 0xe2: sbcb_ix(); break;
919 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
920 case 0xe3: addd_ix(); break;
922 // case 0xe3: illegal(); break;
924 case 0xe4: andb_ix(); break;
925 case 0xe5: bitb_ix(); break;
926 case 0xe6: ldb_ix(); break;
927 case 0xe7: stb_ix(); break;
928 case 0xe8: eorb_ix(); break;
929 case 0xe9: adcb_ix(); break;
930 case 0xea: orb_ix(); break;
931 case 0xeb: addb_ix(); break;
932 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
933 case 0xec: ldd_ix(); break;
934 case 0xed: std_ix(); break;
935 //#elif defined(HAS_MB8861)
936 // case 0xec: adx_im(); break;
937 // case 0xed: illegal(); break;
939 // case 0xec: illegal(); break;
940 // case 0xed: illegal(); break;
942 case 0xee: ldx_ix(); break;
943 case 0xef: stx_ix(); break;
944 case 0xf0: subb_ex(); break;
945 case 0xf1: cmpb_ex(); break;
946 case 0xf2: sbcb_ex(); break;
947 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
948 case 0xf3: addd_ex(); break;
950 // case 0xf3: illegal(); break;
952 case 0xf4: andb_ex(); break;
953 case 0xf5: bitb_ex(); break;
954 case 0xf6: ldb_ex(); break;
955 case 0xf7: stb_ex(); break;
956 case 0xf8: eorb_ex(); break;
957 case 0xf9: adcb_ex(); break;
958 case 0xfa: orb_ex(); break;
959 case 0xfb: addb_ex(); break;
960 //#if defined(HAS_MC6801) || defined(HAS_HD6301)
961 case 0xfc: ldd_ex(); break;
962 case 0xfd: std_ex(); break;
963 //#elif defined(HAS_MB8861)
964 // case 0xfc: adx_ex(); break;
965 // case 0xfd: illegal(); break;
967 // case 0xfc: illegal(); break;
968 // case 0xfd: illegal(); break;
970 case 0xfe: ldx_ex(); break;
971 case 0xff: stx_ex(); break;
972 #if defined(_MSC_VER) && (_MSC_VER >= 1200)
973 default: __assume(0);
978 /* $04 LSRD inherent -0*-* */
990 /* $05 ASLD inherent ?**** */
998 SET_FLAGS16(t, t, r);
1001 /* $38 PULX inherent ----- */
1007 /* $3a ABX inherent ----- */
1012 /* $3c PSHX inherent ----- */
1018 /* $3d MUL inherent --*-@ */
1027 /* $83 SUBD immediate -**** */
1028 void MC6801::subd_im()
1036 SET_FLAGS16(d, b.d, r);
1040 /* $8c CPX immediate -**** (6801) */
1041 void MC6801::cpx_im()
1049 SET_FLAGS16(d, b.d, r);
1052 /* $93 SUBD direct -**** */
1053 void MC6801::subd_di()
1061 SET_FLAGS16(d, b.d, r);
1065 /* $9c CPX direct -**** (6801) */
1066 void MC6801::cpx_di()
1074 SET_FLAGS16(d, b.d, r);
1076 /* $a3 SUBD indexed -**** */
1077 void MC6801::subd_ix()
1085 SET_FLAGS16(d, b.d, r);
1089 /* $ac CPX indexed -**** (6801)*/
1090 void MC6801::cpx_ix()
1098 SET_FLAGS16(d, b.d, r);
1101 /* $b3 SUBD extended -**** */
1102 void MC6801::subd_ex()
1110 SET_FLAGS16(d, b.d, r);
1114 /* $bc CPX extended -**** (6801) */
1115 void MC6801::cpx_ex()
1123 SET_FLAGS16(d, b.d, r);
1126 /* $c3 ADDD immediate -**** */
1127 void MC6801::addd_im()
1135 SET_FLAGS16(d, b.d, r);
1139 /* $CC LDD immediate -**0- */
1140 void MC6801::ldd_im()
1147 /* is this a legal instruction? */
1148 /* $cd STD immediate -**0- */
1149 void MC6801::std_im()
1157 /* $d3 ADDD direct -**** */
1158 void MC6801::addd_di()
1166 SET_FLAGS16(d, b.d, r);
1170 /* $dc LDD direct -**0- */
1171 void MC6801::ldd_di()
1178 /* $dd STD direct -**0- */
1179 void MC6801::std_di()
1187 /* $e3 ADDD indexed -**** */
1188 void MC6801::addd_ix()
1196 SET_FLAGS16(d, b.d, r);
1200 /* $ec LDD indexed -**0- */
1201 void MC6801::ldd_ix()
1208 /* $ed STD indexed -**0- */
1209 void MC6801::std_ix()
1217 /* $f3 ADDD extended -**** */
1218 void MC6801::addd_ex()
1226 SET_FLAGS16(d, b.d, r);
1230 /* $fc LDD extended -**0- */
1231 void MC6801::ldd_ex()
1238 /* $fd STD extended -**0- */
1239 void MC6801::std_ex()
1247 #define STATE_VERSION 2
1249 bool MC6801::process_state(FILEIO* state_fio, bool loading)
1251 if(!state_fio->StateCheckUint32(STATE_VERSION)) {
1254 if(!state_fio->StateCheckInt32(this_device_id)) {
1257 state_fio->StateValue(pc.d);
1258 state_fio->StateValue(prevpc);
1259 state_fio->StateValue(sp.d);
1260 state_fio->StateValue(ix.d);
1261 state_fio->StateValue(acc_d.d);
1262 state_fio->StateValue(ea.d);
1263 state_fio->StateValue(cc);
1264 state_fio->StateValue(wai_state);
1265 state_fio->StateValue(int_state);
1266 if(__USE_DEBUGGER) {
1267 state_fio->StateValue(total_icount);
1269 state_fio->StateValue(icount);
1270 // #if defined(HAS_MC6801) || defined(HAS_HD6301)
1271 for(int i = 0; i < 4; i++) {
1272 state_fio->StateValue(port[i].wreg);
1273 state_fio->StateValue(port[i].rreg);
1274 state_fio->StateValue(port[i].ddr);
1275 state_fio->StateValue(port[i].latched_data);
1276 state_fio->StateValue(port[i].latched);
1277 state_fio->StateValue(port[i].first_write);
1279 state_fio->StateValue(p3csr);
1280 state_fio->StateValue(p3csr_is3_flag_read);
1281 state_fio->StateValue(sc1_state);
1282 state_fio->StateValue(sc2_state);
1283 state_fio->StateValue(counter.d);
1284 state_fio->StateValue(output_compare.d);
1285 state_fio->StateValue(timer_over.d);
1286 state_fio->StateValue(tcsr);
1287 state_fio->StateValue(pending_tcsr);
1288 state_fio->StateValue(input_capture);
1289 state_fio->StateValue(timer_next);
1290 if(!recv_buffer->process_state((void *)state_fio, loading)) {
1293 state_fio->StateValue(trcsr);
1294 state_fio->StateValue(rdr);
1295 state_fio->StateValue(tdr);
1296 state_fio->StateValue(trcsr_read_tdre);
1297 state_fio->StateValue(trcsr_read_orfe);
1298 state_fio->StateValue(trcsr_read_rdrf);
1299 state_fio->StateValue(rmcr);
1300 state_fio->StateValue(sio_counter);
1301 state_fio->StateValue(ram_ctrl);
1302 state_fio->StateArray(ram, sizeof(ram), 1);
1306 if(__USE_DEBUGGER) {
1308 prev_total_icount = total_icount;