~ubuntu-branches/ubuntu/lucid/sdlmame/lucid

« back to all changes in this revision

Viewing changes to src/emu/cpu/minx/minxops.h

  • Committer: Bazaar Package Importer
  • Author(s): Cesare Falco
  • Date: 2009-11-03 17:10:15 UTC
  • mfrom: (1.1.5 upstream)
  • Revision ID: james.westby@ubuntu.com-20091103171015-6hop4ory5lxnumpn
Tags: 0.135-0ubuntu1
* New upstream release - Closes (LP: #403212)
* debian/watch: unstable releases are no longer detected
* mame.ini: added the cheat subdirectories to cheatpath so zipped
  cheatfiles will be searched too
* renamed crsshair subdirectory to crosshair to reflect upstream change
* mame.ini: renamed references to crosshair subdirectory (see above)

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
#undef OP
2
 
#define OP(nn) INLINE void minx_##nn(void)
3
 
 
4
 
OP(00) { regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
5
 
OP(01) { regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
6
 
OP(02) { regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), rdop() ); }
7
 
OP(03) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
8
 
OP(04) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
9
 
OP(05) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
10
 
OP(06) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
11
 
OP(07) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | ADD8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
12
 
OP(08) { regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
13
 
OP(09) { regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
14
 
OP(0A) { regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), rdop() ); }
15
 
OP(0B) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
16
 
OP(0C) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
17
 
OP(0D) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
18
 
OP(0E) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
19
 
OP(0F) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | ADDC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
20
 
 
21
 
OP(10) { regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
22
 
OP(11) { regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
23
 
OP(12) { regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), rdop() ); }
24
 
OP(13) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
25
 
OP(14) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
26
 
OP(15) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
27
 
OP(16) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
28
 
OP(17) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
29
 
OP(18) { regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
30
 
OP(19) { regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
31
 
OP(1A) { regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), rdop() ); }
32
 
OP(1B) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
33
 
OP(1C) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
34
 
OP(1D) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
35
 
OP(1E) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
36
 
OP(1F) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | SUBC8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
37
 
 
38
 
OP(20) { regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
39
 
OP(21) { regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
40
 
OP(22) { regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), rdop() ); }
41
 
OP(23) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
42
 
OP(24) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
43
 
OP(25) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
44
 
OP(26) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
45
 
OP(27) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | AND8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
46
 
OP(28) { regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
47
 
OP(29) { regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
48
 
OP(2A) { regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), rdop() ); }
49
 
OP(2B) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
50
 
OP(2C) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
51
 
OP(2D) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
52
 
OP(2E) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
53
 
OP(2F) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | OR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
54
 
 
55
 
OP(30) { SUB8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
56
 
OP(31) { SUB8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
57
 
OP(32) { SUB8( ( regs.BA & 0x00FF ), rdop() ); }
58
 
OP(33) { AD2_IHL; SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
59
 
OP(34) { AD2_IN8; SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
60
 
OP(35) { AD2_I16; SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
61
 
OP(36) { AD2_XIX; SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
62
 
OP(37) { AD2_YIY; SUB8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
63
 
OP(38) { regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), ( regs.BA & 0xFF ) ); }
64
 
OP(39) { regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ); }
65
 
OP(3A) { regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), rdop() ); }
66
 
OP(3B) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
67
 
OP(3C) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
68
 
OP(3D) { AD2_I16; regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
69
 
OP(3E) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
70
 
OP(3F) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | XOR8( ( regs.BA & 0x00FF ), RD( addr2 ) ); }
71
 
 
72
 
OP(40) { regs.BA = ( regs.BA & 0xFF00 ) | ( regs.BA & 0x00FF); }
73
 
OP(41) { regs.BA = ( regs.BA & 0xFF00 ) | ( regs.BA >> 8 ); }
74
 
OP(42) { regs.BA = ( regs.BA & 0xFF00 ) | ( regs.HL & 0x00FF); }
75
 
OP(43) { regs.BA = ( regs.BA & 0xFF00 ) | ( regs.HL >> 8 ); }
76
 
OP(44) { AD2_IN8; regs.BA = ( regs.BA & 0xFF00 ) | RD( addr2 ); }
77
 
OP(45) { AD2_IHL; regs.BA = ( regs.BA & 0xFF00 ) | RD( addr2 ); }
78
 
OP(46) { AD2_XIX; regs.BA = ( regs.BA & 0xFF00 ) | RD( addr2 ); }
79
 
OP(47) { AD2_YIY; regs.BA = ( regs.BA & 0xFF00 ) | RD( addr2 ); }
80
 
OP(48) { regs.BA = ( regs.BA & 0x00FF ) | ( ( regs.BA & 0x00FF) << 8 ); }
81
 
OP(49) { regs.BA = ( regs.BA & 0x00FF ) | ( ( regs.BA >> 8 ) << 8 ); }
82
 
OP(4A) { regs.BA = ( regs.BA & 0x00FF ) | ( ( regs.HL & 0x00FF) << 8 ); }
83
 
OP(4B) { regs.BA = ( regs.BA & 0x00FF ) | ( ( regs.HL >> 8 ) << 8 ); }
84
 
OP(4C) { AD2_IN8; regs.BA = ( regs.BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
85
 
OP(4D) { AD2_IHL; regs.BA = ( regs.BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
86
 
OP(4E) { AD2_XIX; regs.BA = ( regs.BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
87
 
OP(4F) { AD2_YIY; regs.BA = ( regs.BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
88
 
 
89
 
OP(50) { regs.HL = ( regs.HL & 0xFF00 ) | ( regs.BA & 0x00FF); }
90
 
OP(51) { regs.HL = ( regs.HL & 0xFF00 ) | ( regs.BA >> 8 ); }
91
 
OP(52) { regs.HL = ( regs.HL & 0xFF00 ) | ( regs.HL & 0x00FF); }
92
 
OP(53) { regs.HL = ( regs.HL & 0xFF00 ) | ( regs.HL >> 8 ); }
93
 
OP(54) { AD2_IN8; regs.HL = ( regs.HL & 0xFF00 ) | RD( addr2 ); }
94
 
OP(55) { AD2_IHL; regs.HL = ( regs.HL & 0xFF00 ) | RD( addr2 ); }
95
 
OP(56) { AD2_XIX; regs.HL = ( regs.HL & 0xFF00 ) | RD( addr2 ); }
96
 
OP(57) { AD2_YIY; regs.HL = ( regs.HL & 0xFF00 ) | RD( addr2 ); }
97
 
OP(58) { regs.HL = ( regs.HL & 0x00FF ) | ( ( regs.BA & 0x00FF) << 8 ); }
98
 
OP(59) { regs.HL = ( regs.HL & 0x00FF ) | ( ( regs.BA >> 8 ) << 8 ); }
99
 
OP(5A) { regs.HL = ( regs.HL & 0x00FF ) | ( ( regs.HL & 0x00FF) << 8 ); }
100
 
OP(5B) { regs.HL = ( regs.HL & 0x00FF ) | ( ( regs.HL >> 8 ) << 8 ); }
101
 
OP(5C) { AD2_IN8; regs.HL = ( regs.HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
102
 
OP(5D) { AD2_IHL; regs.HL = ( regs.HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
103
 
OP(5E) { AD2_XIX; regs.HL = ( regs.HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
104
 
OP(5F) { AD2_YIY; regs.HL = ( regs.HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
105
 
 
106
 
OP(60) { AD1_XIX; WR( addr1, ( regs.BA & 0x00FF ) ); }
107
 
OP(61) { AD1_XIX; WR( addr1, ( regs.BA >> 8 ) ); }
108
 
OP(62) { AD1_XIX; WR( addr1, ( regs.HL & 0x00FF ) ); }
109
 
OP(63) { AD1_XIX; WR( addr1, ( regs.HL >> 8 ) ); }
 
2
#define OP(nn) INLINE void minx_##nn(minx_state *minx)
 
3
 
 
4
OP(00) { minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
5
OP(01) { minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
6
OP(02) { minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
7
OP(03) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
8
OP(04) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
9
OP(05) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
10
OP(06) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
11
OP(07) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | ADD8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
12
OP(08) { minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
13
OP(09) { minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
14
OP(0A) { minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
15
OP(0B) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
16
OP(0C) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
17
OP(0D) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
18
OP(0E) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
19
OP(0F) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | ADDC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
20
 
 
21
OP(10) { minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
22
OP(11) { minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
23
OP(12) { minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
24
OP(13) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
25
OP(14) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
26
OP(15) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
27
OP(16) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
28
OP(17) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
29
OP(18) { minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
30
OP(19) { minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
31
OP(1A) { minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
32
OP(1B) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
33
OP(1C) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
34
OP(1D) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
35
OP(1E) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
36
OP(1F) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | SUBC8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
37
 
 
38
OP(20) { minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
39
OP(21) { minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
40
OP(22) { minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
41
OP(23) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
42
OP(24) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
43
OP(25) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
44
OP(26) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
45
OP(27) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | AND8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
46
OP(28) { minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
47
OP(29) { minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
48
OP(2A) { minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
49
OP(2B) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
50
OP(2C) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
51
OP(2D) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
52
OP(2E) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
53
OP(2F) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | OR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
54
 
 
55
OP(30) { SUB8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
56
OP(31) { SUB8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
57
OP(32) { SUB8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
58
OP(33) { AD2_IHL; SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
59
OP(34) { AD2_IN8; SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
60
OP(35) { AD2_I16; SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
61
OP(36) { AD2_XIX; SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
62
OP(37) { AD2_YIY; SUB8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
63
OP(38) { minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), ( minx->BA & 0xFF ) ); }
 
64
OP(39) { minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ); }
 
65
OP(3A) { minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), rdop(minx) ); }
 
66
OP(3B) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
67
OP(3C) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
68
OP(3D) { AD2_I16; minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
69
OP(3E) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
70
OP(3F) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | XOR8( minx, ( minx->BA & 0x00FF ), RD( addr2 ) ); }
 
71
 
 
72
OP(40) { minx->BA = ( minx->BA & 0xFF00 ) | ( minx->BA & 0x00FF); }
 
73
OP(41) { minx->BA = ( minx->BA & 0xFF00 ) | ( minx->BA >> 8 ); }
 
74
OP(42) { minx->BA = ( minx->BA & 0xFF00 ) | ( minx->HL & 0x00FF); }
 
75
OP(43) { minx->BA = ( minx->BA & 0xFF00 ) | ( minx->HL >> 8 ); }
 
76
OP(44) { AD2_IN8; minx->BA = ( minx->BA & 0xFF00 ) | RD( addr2 ); }
 
77
OP(45) { AD2_IHL; minx->BA = ( minx->BA & 0xFF00 ) | RD( addr2 ); }
 
78
OP(46) { AD2_XIX; minx->BA = ( minx->BA & 0xFF00 ) | RD( addr2 ); }
 
79
OP(47) { AD2_YIY; minx->BA = ( minx->BA & 0xFF00 ) | RD( addr2 ); }
 
80
OP(48) { minx->BA = ( minx->BA & 0x00FF ) | ( ( minx->BA & 0x00FF) << 8 ); }
 
81
OP(49) { minx->BA = ( minx->BA & 0x00FF ) | ( ( minx->BA >> 8 ) << 8 ); }
 
82
OP(4A) { minx->BA = ( minx->BA & 0x00FF ) | ( ( minx->HL & 0x00FF) << 8 ); }
 
83
OP(4B) { minx->BA = ( minx->BA & 0x00FF ) | ( ( minx->HL >> 8 ) << 8 ); }
 
84
OP(4C) { AD2_IN8; minx->BA = ( minx->BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
85
OP(4D) { AD2_IHL; minx->BA = ( minx->BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
86
OP(4E) { AD2_XIX; minx->BA = ( minx->BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
87
OP(4F) { AD2_YIY; minx->BA = ( minx->BA & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
88
 
 
89
OP(50) { minx->HL = ( minx->HL & 0xFF00 ) | ( minx->BA & 0x00FF); }
 
90
OP(51) { minx->HL = ( minx->HL & 0xFF00 ) | ( minx->BA >> 8 ); }
 
91
OP(52) { minx->HL = ( minx->HL & 0xFF00 ) | ( minx->HL & 0x00FF); }
 
92
OP(53) { minx->HL = ( minx->HL & 0xFF00 ) | ( minx->HL >> 8 ); }
 
93
OP(54) { AD2_IN8; minx->HL = ( minx->HL & 0xFF00 ) | RD( addr2 ); }
 
94
OP(55) { AD2_IHL; minx->HL = ( minx->HL & 0xFF00 ) | RD( addr2 ); }
 
95
OP(56) { AD2_XIX; minx->HL = ( minx->HL & 0xFF00 ) | RD( addr2 ); }
 
96
OP(57) { AD2_YIY; minx->HL = ( minx->HL & 0xFF00 ) | RD( addr2 ); }
 
97
OP(58) { minx->HL = ( minx->HL & 0x00FF ) | ( ( minx->BA & 0x00FF) << 8 ); }
 
98
OP(59) { minx->HL = ( minx->HL & 0x00FF ) | ( ( minx->BA >> 8 ) << 8 ); }
 
99
OP(5A) { minx->HL = ( minx->HL & 0x00FF ) | ( ( minx->HL & 0x00FF) << 8 ); }
 
100
OP(5B) { minx->HL = ( minx->HL & 0x00FF ) | ( ( minx->HL >> 8 ) << 8 ); }
 
101
OP(5C) { AD2_IN8; minx->HL = ( minx->HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
102
OP(5D) { AD2_IHL; minx->HL = ( minx->HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
103
OP(5E) { AD2_XIX; minx->HL = ( minx->HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
104
OP(5F) { AD2_YIY; minx->HL = ( minx->HL & 0x00FF ) | ( RD( addr2 ) << 8 ); }
 
105
 
 
106
OP(60) { AD1_XIX; WR( addr1, ( minx->BA & 0x00FF ) ); }
 
107
OP(61) { AD1_XIX; WR( addr1, ( minx->BA >> 8 ) ); }
 
108
OP(62) { AD1_XIX; WR( addr1, ( minx->HL & 0x00FF ) ); }
 
109
OP(63) { AD1_XIX; WR( addr1, ( minx->HL >> 8 ) ); }
110
110
OP(64) { AD1_XIX; AD2_IN8; WR( addr1, RD( addr2 ) ); }
111
111
OP(65) { AD1_XIX; AD2_IHL; WR( addr1, RD( addr2 ) ); }
112
112
OP(66) { AD1_XIX; AD2_XIX; WR( addr1, RD( addr2 ) ); }
113
113
OP(67) { AD1_XIX; AD2_YIY; WR( addr1, RD( addr2 ) ); }
114
 
OP(68) { AD1_IHL; WR( addr1, ( regs.BA & 0x00FF ) ); }
115
 
OP(69) { AD1_IHL; WR( addr1, ( regs.BA >> 8 ) ); }
116
 
OP(6A) { AD1_IHL; WR( addr1, ( regs.HL & 0x00FF ) ); }
117
 
OP(6B) { AD1_IHL; WR( addr1, ( regs.HL >> 8 ) ); }
 
114
OP(68) { AD1_IHL; WR( addr1, ( minx->BA & 0x00FF ) ); }
 
115
OP(69) { AD1_IHL; WR( addr1, ( minx->BA >> 8 ) ); }
 
116
OP(6A) { AD1_IHL; WR( addr1, ( minx->HL & 0x00FF ) ); }
 
117
OP(6B) { AD1_IHL; WR( addr1, ( minx->HL >> 8 ) ); }
118
118
OP(6C) { AD1_IHL; AD2_IN8; WR( addr1, RD( addr2 ) ); }
119
119
OP(6D) { AD1_IHL; AD2_IHL; WR( addr1, RD( addr2 ) ); }
120
120
OP(6E) { AD1_IHL; AD2_XIX; WR( addr1, RD( addr2 ) ); }
121
121
OP(6F) { AD1_IHL; AD2_YIY; WR( addr1, RD( addr2 ) ); }
122
122
 
123
 
OP(70) { AD1_YIY; WR( addr1, ( regs.BA & 0x00FF ) ); }
124
 
OP(71) { AD1_YIY; WR( addr1, ( regs.BA >> 8 ) ); }
125
 
OP(72) { AD1_YIY; WR( addr1, ( regs.HL & 0x00FF ) ); }
126
 
OP(73) { AD1_YIY; WR( addr1, ( regs.HL >> 8 ) ); }
 
123
OP(70) { AD1_YIY; WR( addr1, ( minx->BA & 0x00FF ) ); }
 
124
OP(71) { AD1_YIY; WR( addr1, ( minx->BA >> 8 ) ); }
 
125
OP(72) { AD1_YIY; WR( addr1, ( minx->HL & 0x00FF ) ); }
 
126
OP(73) { AD1_YIY; WR( addr1, ( minx->HL >> 8 ) ); }
127
127
OP(74) { AD1_YIY; AD2_IN8; WR( addr1, RD( addr2 ) ); }
128
128
OP(75) { AD1_YIY; AD2_IHL; WR( addr1, RD( addr2 ) ); }
129
129
OP(76) { AD1_YIY; AD2_XIX; WR( addr1, RD( addr2 ) ); }
130
130
OP(77) { AD1_YIY; AD2_YIY; WR( addr1, RD( addr2 ) ); }
131
 
OP(78) { AD1_IN8; WR( addr1, ( regs.BA & 0x00FF ) ); }
132
 
OP(79) { AD1_IN8; WR( addr1, ( regs.BA >> 8 ) ); }
133
 
OP(7A) { AD1_IN8; WR( addr1, ( regs.HL & 0x00FF ) ); }
134
 
OP(7B) { AD1_IN8; WR( addr1, ( regs.HL >> 8 ) ); }
 
131
OP(78) { AD1_IN8; WR( addr1, ( minx->BA & 0x00FF ) ); }
 
132
OP(79) { AD1_IN8; WR( addr1, ( minx->BA >> 8 ) ); }
 
133
OP(7A) { AD1_IN8; WR( addr1, ( minx->HL & 0x00FF ) ); }
 
134
OP(7B) { AD1_IN8; WR( addr1, ( minx->HL >> 8 ) ); }
135
135
OP(7C) { /* illegal operation? */ }
136
136
OP(7D) { AD1_IN8; AD2_IHL; WR( addr1, RD( addr2 ) ); }
137
137
OP(7E) { AD1_IN8; AD2_XIX; WR( addr1, RD( addr2 ) ); }
138
138
OP(7F) { AD1_IN8; AD2_YIY; WR( addr1, RD( addr2 ) ); }
139
139
 
140
 
OP(80) { regs.BA = ( regs.BA & 0xFF00 ) | INC8( regs.BA & 0x00FF ); }
141
 
OP(81) { regs.BA = ( regs.BA & 0x00FF ) | ( INC8( regs.BA >> 8 ) << 8 ); }
142
 
OP(82) { regs.HL = ( regs.HL & 0xFF00 ) | INC8( regs.HL & 0x00FF ); }
143
 
OP(83) { regs.HL = ( regs.HL & 0x00FF ) | ( INC8( regs.HL >> 8 ) << 8 ); }
144
 
OP(84) { regs.N = INC8( regs.N ); }
145
 
OP(85) { AD1_IN8; WR( addr1, INC8( RD( addr1 ) ) ); }
146
 
OP(86) { AD1_IHL; WR( addr1, INC8( RD( addr1 ) ) ); }
147
 
OP(87) { regs.SP = INC16( regs.SP ); }
148
 
OP(88) { regs.BA = ( regs.BA & 0xFF00 ) | DEC8( regs.BA & 0x00FF ); }
149
 
OP(89) { regs.BA = ( regs.BA & 0x00FF ) | ( DEC8( regs.BA >> 8 ) << 8 ); }
150
 
OP(8A) { regs.HL = ( regs.HL & 0xFF00 ) | DEC8( regs.HL & 0x00FF ); }
151
 
OP(8B) { regs.HL = ( regs.HL & 0x00FF ) | ( DEC8( regs.HL >> 8 ) << 8 ); }
152
 
OP(8C) { regs.N = DEC8( regs.N ); }
153
 
OP(8D) { AD1_IN8; WR( addr1, DEC8( RD( addr1 ) ) ); }
154
 
OP(8E) { AD1_IHL; WR( addr1, DEC8( RD( addr1 ) ) ); }
155
 
OP(8F) { regs.SP = DEC8( regs.SP ); }
156
 
 
157
 
OP(90) { regs.BA = INC16( regs.BA ); }
158
 
OP(91) { regs.HL = INC16( regs.HL ); }
159
 
OP(92) { regs.X = INC16( regs.X ); }
160
 
OP(93) { regs.Y = INC16( regs.Y ); }
161
 
OP(94) { regs.F = ( AND8( ( regs.BA & 0x00FF ), ( regs.BA >> 8 ) ) ) ? regs.F & ~FLAG_Z : regs.F | FLAG_Z;}
162
 
OP(95) { AD1_IHL; regs.F = ( AND8( RD( addr1 ), rdop() ) ) ? regs.F & ~FLAG_Z : regs.F | FLAG_Z; }
163
 
OP(96) { regs.F = ( AND8( ( regs.BA & 0x00FF ), rdop() ) ) ? regs.F & ~FLAG_Z : regs.F | FLAG_Z; }
164
 
OP(97) { regs.F = ( AND8( ( regs.BA >> 8 ), rdop() ) ) ? regs.F & ~FLAG_Z : regs.F | FLAG_Z; }
165
 
OP(98) { regs.BA = DEC16( regs.BA ); }
166
 
OP(99) { regs.HL = DEC16( regs.HL ); }
167
 
OP(9A) { regs.X = DEC16( regs.X ); }
168
 
OP(9B) { regs.Y = DEC16( regs.Y ); }
169
 
OP(9C) { regs.F = regs.F & rdop(); }
170
 
OP(9D) { regs.F = regs.F | rdop(); }
171
 
OP(9E) { regs.F = regs.F ^ rdop(); }
172
 
OP(9F) { regs.F = rdop(); }
173
 
 
174
 
OP(A0) { PUSH16( regs.BA ); }
175
 
OP(A1) { PUSH16( regs.HL ); }
176
 
OP(A2) { PUSH16( regs.X ); }
177
 
OP(A3) { PUSH16( regs.Y ); }
178
 
OP(A4) { PUSH8( regs.N ); }
179
 
OP(A5) { PUSH8( regs.I ); }
180
 
OP(A6) { PUSH8( regs.XI ); PUSH8( regs.YI ); }
181
 
OP(A7) { PUSH8( regs.F ); }
182
 
OP(A8) { regs.BA = POP16(); }
183
 
OP(A9) { regs.HL = POP16();}
184
 
OP(AA) { regs.X = POP16(); }
185
 
OP(AB) { regs.Y = POP16(); }
186
 
OP(AC) { regs.N = POP8(); }
187
 
OP(AD) { regs.I = POP8(); }
188
 
OP(AE) { regs.YI = POP8(); regs.XI = POP8(); }
189
 
OP(AF) { regs.F = POP8(); }
190
 
 
191
 
OP(B0) { UINT8 op = rdop(); regs.BA = ( regs.BA & 0xFF00 ) | op; }
192
 
OP(B1) { UINT8 op = rdop(); regs.BA = ( regs.BA & 0x00FF ) | ( op << 8 ); }
193
 
OP(B2) { UINT8 op = rdop(); regs.HL = ( regs.HL & 0xFF00 ) | op; }
194
 
OP(B3) { UINT8 op = rdop(); regs.HL = ( regs.HL & 0x00FF ) | ( op << 8 ); }
195
 
OP(B4) { UINT8 op = rdop(); regs.N = op; }
196
 
OP(B5) { AD1_IHL; UINT8 op = rdop(); WR( addr1, op); }
197
 
OP(B6) { AD1_XIX; UINT8 op = rdop(); WR( addr1, op ); }
198
 
OP(B7) { AD1_YIY; UINT8 op = rdop(); WR( addr1, op ); }
199
 
OP(B8) { AD2_I16; regs.BA = rd16( addr2 ); }
200
 
OP(B9) { AD2_I16; regs.HL = rd16( addr2 ); }
201
 
OP(BA) { AD2_I16; regs.X = rd16( addr2 ); }
202
 
OP(BB) { AD2_I16; regs.Y = rd16( addr2 ); }
203
 
OP(BC) { AD1_I16; wr16( addr1, regs.BA ); }
204
 
OP(BD) { AD1_I16; wr16( addr1, regs.HL ); }
205
 
OP(BE) { AD1_I16; wr16( addr1, regs.X ); }
206
 
OP(BF) { AD1_I16; wr16( addr1, regs.Y ); }
207
 
 
208
 
OP(C0) { regs.BA = ADD16( regs.BA, rdop16() ); }
209
 
OP(C1) { regs.HL = ADD16( regs.HL, rdop16() ); }
210
 
OP(C2) { regs.X = ADD16( regs.X, rdop16() ); }
211
 
OP(C3) { regs.Y = ADD16( regs.Y, rdop16() ); }
212
 
OP(C4) { regs.BA = rdop16(); }
213
 
OP(C5) { regs.HL = rdop16(); }
214
 
OP(C6) { regs.X = rdop16(); }
215
 
OP(C7) { regs.Y = rdop16(); }
216
 
OP(C8) { UINT16 t = regs.BA; regs.BA = regs.HL; regs.HL = t; }
217
 
OP(C9) { UINT16 t = regs.BA; regs.BA = regs.X; regs.X = t; }
218
 
OP(CA) { UINT16 t = regs.BA; regs.BA = regs.Y; regs.Y = t; }
219
 
OP(CB) { UINT16 t = regs.BA; regs.BA = regs.SP; regs.SP = t; }
220
 
OP(CC) { regs.BA = ( regs.BA >> 8 ) | ( ( regs.BA & 0x00FF ) << 8 ); }
221
 
OP(CD) { UINT8 t; AD2_IHL; t = RD( addr2 ); WR( addr2, ( regs.BA & 0x00FF ) ); regs.BA = ( regs.BA & 0xFF00 ) | t; }
222
 
OP(CE) { UINT8 op = rdop(); insnminx_CE[op](); minx_icount -= insnminx_cycles_CE[op]; }
223
 
OP(CF) { UINT8 op = rdop(); insnminx_CF[op](); minx_icount -= insnminx_cycles_CF[op]; }
224
 
 
225
 
OP(D0) { regs.BA = SUB16( regs.BA, rdop16() ); }
226
 
OP(D1) { regs.HL = SUB16( regs.HL, rdop16() ); }
227
 
OP(D2) { regs.X = SUB16( regs.X, rdop16() ); }
228
 
OP(D3) { regs.Y = SUB16( regs.Y, rdop16() ); }
229
 
OP(D4) { SUB16( regs.BA, rdop16() ); }
230
 
OP(D5) { SUB16( regs.HL, rdop16() ); }
231
 
OP(D6) { SUB16( regs.X, rdop16() ); }
232
 
OP(D7) { SUB16( regs.Y, rdop16() ); }
233
 
OP(D8) { AD1_IN8; WR( addr1, AND8( RD( addr1 ), rdop() ) ); }
234
 
OP(D9) { AD1_IN8; WR( addr1, OR8( RD( addr1 ), rdop() ) ); }
235
 
OP(DA) { AD1_IN8; WR( addr1, XOR8( RD( addr1 ), rdop() ) ); }
236
 
OP(DB) { AD1_IN8; SUB8( RD( addr1 ), rdop() ); }
237
 
OP(DC) { AD1_IN8; regs.F = ( AND8( RD( addr1 ), rdop() ) ) ? regs.F & ~FLAG_Z : regs.F | FLAG_Z; }
238
 
OP(DD) { AD1_IN8; WR( addr1, rdop() ); }
239
 
OP(DE) { regs.BA = ( regs.BA & 0xFF00 ) | ( ( regs.BA & 0x000F ) | ( ( regs.BA & 0x0F00 ) >> 4 ) ); }
240
 
OP(DF) { regs.BA = ( ( regs.BA & 0x0080 ) ? 0xFF00 : 0x0000 ) | ( regs.BA & 0x000F ); }
241
 
 
242
 
OP(E0) { INT8 d8 = rdop(); if ( regs.F & FLAG_C ) { CALL( regs.PC + d8 - 1 ); minx_icount -= 12; } }
243
 
OP(E1) { INT8 d8 = rdop(); if ( ! ( regs.F & FLAG_C ) ) { CALL( regs.PC + d8- 1  ); minx_icount -= 12; } }
244
 
OP(E2) { INT8 d8 = rdop(); if ( regs.F & FLAG_Z ) { CALL( regs.PC + d8 - 1 ); minx_icount -= 12; } }
245
 
OP(E3) { INT8 d8 = rdop(); if ( ! ( regs.F & FLAG_Z ) ) { CALL( regs.PC + d8 - 1 ); minx_icount -= 12; } }
246
 
OP(E4) { INT8 d8 = rdop(); if ( regs.F & FLAG_C ) { JMP( regs.PC + d8 - 1 ); } }
247
 
OP(E5) { INT8 d8 = rdop(); if ( ! ( regs.F & FLAG_C ) ) { JMP( regs.PC + d8 - 1 ); } }
248
 
OP(E6) { INT8 d8 = rdop(); if ( regs.F & FLAG_Z ) { JMP( regs.PC + d8 - 1 ); } }
249
 
OP(E7) { INT8 d8 = rdop(); if ( ! ( regs.F & FLAG_Z ) ) { JMP( regs.PC + d8 - 1 ); } }
250
 
OP(E8) { UINT16 d16 = rdop16(); if ( regs.F & FLAG_C ) { CALL( regs.PC + d16 - 1 ); minx_icount -= 12; } }
251
 
OP(E9) { UINT16 d16 = rdop16(); if ( ! ( regs.F & FLAG_C ) ) { CALL( regs.PC + d16 - 1 ); minx_icount -= 12; } }
252
 
OP(EA) { UINT16 d16 = rdop16(); if ( regs.F & FLAG_Z ) { CALL( regs.PC + d16 - 1 ); minx_icount -= 12; } }
253
 
OP(EB) { UINT16 d16 = rdop16(); if ( ! ( regs.F & FLAG_Z ) ) { CALL( regs.PC + d16 - 1 ); minx_icount -= 12; } }
254
 
OP(EC) { UINT16 d16 = rdop16(); if ( regs.F & FLAG_C ) { JMP( regs.PC + d16 - 1 ); } }
255
 
OP(ED) { UINT16 d16 = rdop16(); if ( ! ( regs.F & FLAG_C ) ) { JMP( regs.PC + d16 - 1 ); } }
256
 
OP(EE) { UINT16 d16 = rdop16(); if ( regs.F & FLAG_Z ) { JMP( regs.PC + d16 - 1 ); } }
257
 
OP(EF) { UINT16 d16 = rdop16(); if ( ! ( regs.F & FLAG_Z ) ) { JMP( regs.PC + d16 - 1 ); } }
258
 
 
259
 
OP(F0) { INT8 d8 = rdop(); CALL( regs.PC + d8 - 1 ); }
260
 
OP(F1) { INT8 d8 = rdop(); JMP( regs.PC + d8 - 1 ); }
261
 
OP(F2) { UINT16 d16 = rdop16(); CALL( regs.PC + d16 - 1 ); }
262
 
OP(F3) { UINT16 d16 = rdop16(); JMP( regs.PC + d16 - 1 ); }
263
 
OP(F4) { JMP( regs.HL ); }
264
 
OP(F5) { INT8 d8 = rdop(); regs.BA = regs.BA - 0x0100; if ( regs.BA & 0xFF00 ) { JMP( regs.PC + d8 - 1 ); } }
265
 
OP(F6) { regs.BA = ( regs.BA & 0xFF00 ) | ( ( regs.BA & 0x00F0 ) >> 4 ) | ( ( regs.BA & 0x000F ) << 4 ); }
 
140
OP(80) { minx->BA = ( minx->BA & 0xFF00 ) | INC8( minx, minx->BA & 0x00FF ); }
 
141
OP(81) { minx->BA = ( minx->BA & 0x00FF ) | ( INC8( minx, minx->BA >> 8 ) << 8 ); }
 
142
OP(82) { minx->HL = ( minx->HL & 0xFF00 ) | INC8( minx, minx->HL & 0x00FF ); }
 
143
OP(83) { minx->HL = ( minx->HL & 0x00FF ) | ( INC8( minx, minx->HL >> 8 ) << 8 ); }
 
144
OP(84) { minx->N = INC8( minx, minx->N ); }
 
145
OP(85) { AD1_IN8; WR( addr1, INC8( minx, RD( addr1 ) ) ); }
 
146
OP(86) { AD1_IHL; WR( addr1, INC8( minx, RD( addr1 ) ) ); }
 
147
OP(87) { minx->SP = INC16( minx, minx->SP ); }
 
148
OP(88) { minx->BA = ( minx->BA & 0xFF00 ) | DEC8( minx, minx->BA & 0x00FF ); }
 
149
OP(89) { minx->BA = ( minx->BA & 0x00FF ) | ( DEC8( minx, minx->BA >> 8 ) << 8 ); }
 
150
OP(8A) { minx->HL = ( minx->HL & 0xFF00 ) | DEC8( minx, minx->HL & 0x00FF ); }
 
151
OP(8B) { minx->HL = ( minx->HL & 0x00FF ) | ( DEC8( minx, minx->HL >> 8 ) << 8 ); }
 
152
OP(8C) { minx->N = DEC8( minx, minx->N ); }
 
153
OP(8D) { AD1_IN8; WR( addr1, DEC8( minx, RD( addr1 ) ) ); }
 
154
OP(8E) { AD1_IHL; WR( addr1, DEC8( minx, RD( addr1 ) ) ); }
 
155
OP(8F) { minx->SP = DEC8( minx, minx->SP ); }
 
156
 
 
157
OP(90) { minx->BA = INC16( minx, minx->BA ); }
 
158
OP(91) { minx->HL = INC16( minx, minx->HL ); }
 
159
OP(92) { minx->X = INC16( minx, minx->X ); }
 
160
OP(93) { minx->Y = INC16( minx, minx->Y ); }
 
161
OP(94) { minx->F = ( AND8( minx, ( minx->BA & 0x00FF ), ( minx->BA >> 8 ) ) ) ? minx->F & ~FLAG_Z : minx->F | FLAG_Z;}
 
162
OP(95) { AD1_IHL; minx->F = ( AND8( minx, RD( addr1 ), rdop(minx) ) ) ? minx->F & ~FLAG_Z : minx->F | FLAG_Z; }
 
163
OP(96) { minx->F = ( AND8( minx, ( minx->BA & 0x00FF ), rdop(minx) ) ) ? minx->F & ~FLAG_Z : minx->F | FLAG_Z; }
 
164
OP(97) { minx->F = ( AND8( minx, ( minx->BA >> 8 ), rdop(minx) ) ) ? minx->F & ~FLAG_Z : minx->F | FLAG_Z; }
 
165
OP(98) { minx->BA = DEC16( minx, minx->BA ); }
 
166
OP(99) { minx->HL = DEC16( minx, minx->HL ); }
 
167
OP(9A) { minx->X = DEC16( minx, minx->X ); }
 
168
OP(9B) { minx->Y = DEC16( minx, minx->Y ); }
 
169
OP(9C) { minx->F = minx->F & rdop(minx); }
 
170
OP(9D) { minx->F = minx->F | rdop(minx); }
 
171
OP(9E) { minx->F = minx->F ^ rdop(minx); }
 
172
OP(9F) { minx->F = rdop(minx); }
 
173
 
 
174
OP(A0) { PUSH16( minx, minx->BA ); }
 
175
OP(A1) { PUSH16( minx, minx->HL ); }
 
176
OP(A2) { PUSH16( minx, minx->X ); }
 
177
OP(A3) { PUSH16( minx, minx->Y ); }
 
178
OP(A4) { PUSH8( minx, minx->N ); }
 
179
OP(A5) { PUSH8( minx, minx->I ); }
 
180
OP(A6) { PUSH8( minx, minx->XI ); PUSH8( minx, minx->YI ); }
 
181
OP(A7) { PUSH8( minx, minx->F ); }
 
182
OP(A8) { minx->BA = POP16(minx); }
 
183
OP(A9) { minx->HL = POP16(minx);}
 
184
OP(AA) { minx->X = POP16(minx); }
 
185
OP(AB) { minx->Y = POP16(minx); }
 
186
OP(AC) { minx->N = POP8(minx); }
 
187
OP(AD) { minx->I = POP8(minx); }
 
188
OP(AE) { minx->YI = POP8(minx); minx->XI = POP8(minx); }
 
189
OP(AF) { minx->F = POP8(minx); }
 
190
 
 
191
OP(B0) { UINT8 op = rdop(minx); minx->BA = ( minx->BA & 0xFF00 ) | op; }
 
192
OP(B1) { UINT8 op = rdop(minx); minx->BA = ( minx->BA & 0x00FF ) | ( op << 8 ); }
 
193
OP(B2) { UINT8 op = rdop(minx); minx->HL = ( minx->HL & 0xFF00 ) | op; }
 
194
OP(B3) { UINT8 op = rdop(minx); minx->HL = ( minx->HL & 0x00FF ) | ( op << 8 ); }
 
195
OP(B4) { UINT8 op = rdop(minx); minx->N = op; }
 
196
OP(B5) { AD1_IHL; UINT8 op = rdop(minx); WR( addr1, op); }
 
197
OP(B6) { AD1_XIX; UINT8 op = rdop(minx); WR( addr1, op ); }
 
198
OP(B7) { AD1_YIY; UINT8 op = rdop(minx); WR( addr1, op ); }
 
199
OP(B8) { AD2_I16; minx->BA = rd16( minx, addr2 ); }
 
200
OP(B9) { AD2_I16; minx->HL = rd16( minx, addr2 ); }
 
201
OP(BA) { AD2_I16; minx->X = rd16( minx, addr2 ); }
 
202
OP(BB) { AD2_I16; minx->Y = rd16( minx, addr2 ); }
 
203
OP(BC) { AD1_I16; wr16( minx, addr1, minx->BA ); }
 
204
OP(BD) { AD1_I16; wr16( minx, addr1, minx->HL ); }
 
205
OP(BE) { AD1_I16; wr16( minx, addr1, minx->X ); }
 
206
OP(BF) { AD1_I16; wr16( minx, addr1, minx->Y ); }
 
207
 
 
208
OP(C0) { minx->BA = ADD16( minx, minx->BA, rdop16(minx) ); }
 
209
OP(C1) { minx->HL = ADD16( minx, minx->HL, rdop16(minx) ); }
 
210
OP(C2) { minx->X = ADD16( minx, minx->X, rdop16(minx) ); }
 
211
OP(C3) { minx->Y = ADD16( minx, minx->Y, rdop16(minx) ); }
 
212
OP(C4) { minx->BA = rdop16(minx); }
 
213
OP(C5) { minx->HL = rdop16(minx); }
 
214
OP(C6) { minx->X = rdop16(minx); }
 
215
OP(C7) { minx->Y = rdop16(minx); }
 
216
OP(C8) { UINT16 t = minx->BA; minx->BA = minx->HL; minx->HL = t; }
 
217
OP(C9) { UINT16 t = minx->BA; minx->BA = minx->X; minx->X = t; }
 
218
OP(CA) { UINT16 t = minx->BA; minx->BA = minx->Y; minx->Y = t; }
 
219
OP(CB) { UINT16 t = minx->BA; minx->BA = minx->SP; minx->SP = t; }
 
220
OP(CC) { minx->BA = ( minx->BA >> 8 ) | ( ( minx->BA & 0x00FF ) << 8 ); }
 
221
OP(CD) { UINT8 t; AD2_IHL; t = RD( addr2 ); WR( addr2, ( minx->BA & 0x00FF ) ); minx->BA = ( minx->BA & 0xFF00 ) | t; }
 
222
OP(CE) { UINT8 op = rdop(minx); insnminx_CE[op](minx); minx->icount -= insnminx_cycles_CE[op]; }
 
223
OP(CF) { UINT8 op = rdop(minx); insnminx_CF[op](minx); minx->icount -= insnminx_cycles_CF[op]; }
 
224
 
 
225
OP(D0) { minx->BA = SUB16( minx, minx->BA, rdop16(minx) ); }
 
226
OP(D1) { minx->HL = SUB16( minx, minx->HL, rdop16(minx) ); }
 
227
OP(D2) { minx->X = SUB16( minx, minx->X, rdop16(minx) ); }
 
228
OP(D3) { minx->Y = SUB16( minx, minx->Y, rdop16(minx) ); }
 
229
OP(D4) { SUB16( minx, minx->BA, rdop16(minx) ); }
 
230
OP(D5) { SUB16( minx, minx->HL, rdop16(minx) ); }
 
231
OP(D6) { SUB16( minx, minx->X, rdop16(minx) ); }
 
232
OP(D7) { SUB16( minx, minx->Y, rdop16(minx) ); }
 
233
OP(D8) { AD1_IN8; WR( addr1, AND8( minx, RD( addr1 ), rdop(minx) ) ); }
 
234
OP(D9) { AD1_IN8; WR( addr1, OR8( minx, RD( addr1 ), rdop(minx) ) ); }
 
235
OP(DA) { AD1_IN8; WR( addr1, XOR8( minx, RD( addr1 ), rdop(minx) ) ); }
 
236
OP(DB) { AD1_IN8; SUB8( minx, RD( addr1 ), rdop(minx) ); }
 
237
OP(DC) { AD1_IN8; minx->F = ( AND8( minx, RD( addr1 ), rdop(minx) ) ) ? minx->F & ~FLAG_Z : minx->F | FLAG_Z; }
 
238
OP(DD) { AD1_IN8; WR( addr1, rdop(minx) ); }
 
239
OP(DE) { minx->BA = ( minx->BA & 0xFF00 ) | ( ( minx->BA & 0x000F ) | ( ( minx->BA & 0x0F00 ) >> 4 ) ); }
 
240
OP(DF) { minx->BA = ( ( minx->BA & 0x0080 ) ? 0xFF00 : 0x0000 ) | ( minx->BA & 0x000F ); }
 
241
 
 
242
OP(E0) { INT8 d8 = rdop(minx); if ( minx->F & FLAG_C ) { CALL( minx, minx->PC + d8 - 1 ); minx->icount -= 12; } }
 
243
OP(E1) { INT8 d8 = rdop(minx); if ( ! ( minx->F & FLAG_C ) ) { CALL( minx, minx->PC + d8- 1  ); minx->icount -= 12; } }
 
244
OP(E2) { INT8 d8 = rdop(minx); if ( minx->F & FLAG_Z ) { CALL( minx, minx->PC + d8 - 1 ); minx->icount -= 12; } }
 
245
OP(E3) { INT8 d8 = rdop(minx); if ( ! ( minx->F & FLAG_Z ) ) { CALL( minx, minx->PC + d8 - 1 ); minx->icount -= 12; } }
 
246
OP(E4) { INT8 d8 = rdop(minx); if ( minx->F & FLAG_C ) { JMP( minx, minx->PC + d8 - 1 ); } }
 
247
OP(E5) { INT8 d8 = rdop(minx); if ( ! ( minx->F & FLAG_C ) ) { JMP( minx, minx->PC + d8 - 1 ); } }
 
248
OP(E6) { INT8 d8 = rdop(minx); if ( minx->F & FLAG_Z ) { JMP( minx, minx->PC + d8 - 1 ); } }
 
249
OP(E7) { INT8 d8 = rdop(minx); if ( ! ( minx->F & FLAG_Z ) ) { JMP( minx, minx->PC + d8 - 1 ); } }
 
250
OP(E8) { UINT16 d16 = rdop16(minx); if ( minx->F & FLAG_C ) { CALL( minx, minx->PC + d16 - 1 ); minx->icount -= 12; } }
 
251
OP(E9) { UINT16 d16 = rdop16(minx); if ( ! ( minx->F & FLAG_C ) ) { CALL( minx, minx->PC + d16 - 1 ); minx->icount -= 12; } }
 
252
OP(EA) { UINT16 d16 = rdop16(minx); if ( minx->F & FLAG_Z ) { CALL( minx, minx->PC + d16 - 1 ); minx->icount -= 12; } }
 
253
OP(EB) { UINT16 d16 = rdop16(minx); if ( ! ( minx->F & FLAG_Z ) ) { CALL( minx, minx->PC + d16 - 1 ); minx->icount -= 12; } }
 
254
OP(EC) { UINT16 d16 = rdop16(minx); if ( minx->F & FLAG_C ) { JMP( minx, minx->PC + d16 - 1 ); } }
 
255
OP(ED) { UINT16 d16 = rdop16(minx); if ( ! ( minx->F & FLAG_C ) ) { JMP( minx, minx->PC + d16 - 1 ); } }
 
256
OP(EE) { UINT16 d16 = rdop16(minx); if ( minx->F & FLAG_Z ) { JMP( minx, minx->PC + d16 - 1 ); } }
 
257
OP(EF) { UINT16 d16 = rdop16(minx); if ( ! ( minx->F & FLAG_Z ) ) { JMP( minx, minx->PC + d16 - 1 ); } }
 
258
 
 
259
OP(F0) { INT8 d8 = rdop(minx); CALL( minx, minx->PC + d8 - 1 ); }
 
260
OP(F1) { INT8 d8 = rdop(minx); JMP( minx, minx->PC + d8 - 1 ); }
 
261
OP(F2) { UINT16 d16 = rdop16(minx); CALL( minx, minx->PC + d16 - 1 ); }
 
262
OP(F3) { UINT16 d16 = rdop16(minx); JMP( minx, minx->PC + d16 - 1 ); }
 
263
OP(F4) { JMP( minx, minx->HL ); }
 
264
OP(F5) { INT8 d8 = rdop(minx); minx->BA = minx->BA - 0x0100; if ( minx->BA & 0xFF00 ) { JMP( minx, minx->PC + d8 - 1 ); } }
 
265
OP(F6) { minx->BA = ( minx->BA & 0xFF00 ) | ( ( minx->BA & 0x00F0 ) >> 4 ) | ( ( minx->BA & 0x000F ) << 4 ); }
266
266
OP(F7) { UINT8 d; AD1_IHL; d = RD( addr1 ); WR( addr1, ( ( d & 0xF0 ) >> 4 ) | ( ( d & 0x0F ) << 4 ) ); }
267
 
OP(F8) { regs.PC = POP16(); regs.V = POP8(); regs.U = regs.V; }
268
 
OP(F9) { regs.F = POP8(); regs.PC = POP16(); regs.V = POP8(); regs.U = regs.V; }
269
 
OP(FA) { regs.PC = POP16() + 2; regs.V = POP8(); regs.U = regs.V; }
270
 
OP(FB) { AD1_I16; CALL( rd16( addr1 ) ); }
271
 
OP(FC) { UINT8 i = rdop() & 0xFE; CALL( rd16(i) ); PUSH8( regs.F ); }
272
 
OP(FD) { UINT8 i = rdop() & 0xFE; JMP( rd16(i) ); /* PUSH8( regs.F );?? */ }
 
267
OP(F8) { minx->PC = POP16(minx); minx->V = POP8(minx); minx->U = minx->V; }
 
268
OP(F9) { minx->F = POP8(minx); minx->PC = POP16(minx); minx->V = POP8(minx); minx->U = minx->V; }
 
269
OP(FA) { minx->PC = POP16(minx) + 2; minx->V = POP8(minx); minx->U = minx->V; }
 
270
OP(FB) { AD1_I16; CALL( minx, rd16( minx, addr1 ) ); }
 
271
OP(FC) { UINT8 i = rdop(minx) & 0xFE; CALL( minx, rd16( minx, i ) ); PUSH8( minx, minx->F ); }
 
272
OP(FD) { UINT8 i = rdop(minx) & 0xFE; JMP( minx, rd16( minx, i ) ); /* PUSH8( minx, minx->F );?? */ }
273
273
OP(FE) { /* illegal operation? */ }
274
274
OP(FF) { }
275
275
 
276
 
static void (*const insnminx[256])(void) = {
 
276
static void (*const insnminx[256])(minx_state *minx) = {
277
277
        minx_00, minx_01, minx_02, minx_03, minx_04, minx_05, minx_06, minx_07,
278
278
        minx_08, minx_09, minx_0A, minx_0B, minx_0C, minx_0D, minx_0E, minx_0F,
279
279
        minx_10, minx_11, minx_12, minx_13, minx_14, minx_15, minx_16, minx_17,