1
/*****************************************************************************
5
* Intel 4004 CPU Disassembly
7
* Initial version by Miodrag Milanovic
9
*****************************************************************************/
13
#define OP(A) oprom[(A) - PC]
14
#define ARG(A) opram[(A) - PC]
16
CPU_DISASSEMBLE( i4004 )
21
UINT16 page = PC & 0x0f00;
22
switch (op = OP(pc++))
24
case 0x00: sprintf (buffer,"nop"); break;
25
case 0x11: sprintf (buffer,"jnt $%03x",page | ARG(pc)); pc++; break;
26
case 0x12: sprintf (buffer,"jc $%03x",page | ARG(pc)); pc++; break;
27
case 0x14: sprintf (buffer,"jz $%03x",page | ARG(pc)); pc++; break;
28
case 0x19: sprintf (buffer,"jt $%03x",page | ARG(pc)); pc++; break;
29
case 0x1a: sprintf (buffer,"jnc $%03x",page | ARG(pc)); pc++; break;
30
case 0x1c: sprintf (buffer,"jnz $%03x",page | ARG(pc)); pc++; break;
31
case 0x10: case 0x13: case 0x15: case 0x16:
32
case 0x17: case 0x18: case 0x1b: case 0x1d:
34
sprintf (buffer,"jcn $%01x,$%03x",op & 0x0f,page | ARG(pc)); pc++; break;
35
case 0x20: case 0x22: case 0x24: case 0x26:
36
case 0x28: case 0x2a: case 0x2c: case 0x2e:
37
sprintf (buffer,"fim $%01x,$%02x",op & 0x0f,OP(pc)); pc++; break;
38
case 0x21: case 0x23: case 0x25: case 0x27:
39
case 0x29: case 0x2b: case 0x2d: case 0x2f:
40
sprintf (buffer,"src $%01x",(op & 0x0f)-1); break;
41
case 0x30: case 0x32: case 0x34: case 0x36:
42
case 0x38: case 0x3a: case 0x3c: case 0x3e:
43
sprintf (buffer,"fin $%01x",op & 0x0f); break;
44
case 0x31: case 0x33: case 0x35: case 0x37:
45
case 0x39: case 0x3b: case 0x3d: case 0x3f:
46
sprintf (buffer,"jin $%01x",(op & 0x0f)-1); break;
47
case 0x40: case 0x41: case 0x42: case 0x43:
48
case 0x44: case 0x45: case 0x46: case 0x47:
49
case 0x48: case 0x49: case 0x4a: case 0x4b:
50
case 0x4c: case 0x4d: case 0x4e: case 0x4f:
51
sprintf (buffer,"jun $%01x%02x",op & 0x0f,ARG(pc)); pc++; break;
52
case 0x50: case 0x51: case 0x52: case 0x53:
53
case 0x54: case 0x55: case 0x56: case 0x57:
54
case 0x58: case 0x59: case 0x5a: case 0x5b:
55
case 0x5c: case 0x5d: case 0x5e: case 0x5f:
56
sprintf (buffer,"jms $%01x%02x",op & 0x0f,ARG(pc)); pc++; break;
57
case 0x60: case 0x61: case 0x62: case 0x63:
58
case 0x64: case 0x65: case 0x66: case 0x67:
59
case 0x68: case 0x69: case 0x6a: case 0x6b:
60
case 0x6c: case 0x6d: case 0x6e: case 0x6f:
61
sprintf (buffer,"inc $%01x",op & 0x0f); break;
62
case 0x70: case 0x71: case 0x72: case 0x73:
63
case 0x74: case 0x75: case 0x76: case 0x77:
64
case 0x78: case 0x79: case 0x7a: case 0x7b:
65
case 0x7c: case 0x7d: case 0x7e: case 0x7f:
66
sprintf (buffer,"isz $%01x,%03x",op & 0x0f,page | ARG(pc)); pc++; break;
67
case 0x80: case 0x81: case 0x82: case 0x83:
68
case 0x84: case 0x85: case 0x86: case 0x87:
69
case 0x88: case 0x89: case 0x8a: case 0x8b:
70
case 0x8c: case 0x8d: case 0x8e: case 0x8f:
71
sprintf (buffer,"add $%01x",op & 0x0f); break;
72
case 0x90: case 0x91: case 0x92: case 0x93:
73
case 0x94: case 0x95: case 0x96: case 0x97:
74
case 0x98: case 0x99: case 0x9a: case 0x9b:
75
case 0x9c: case 0x9d: case 0x9e: case 0x9f:
76
sprintf (buffer,"sub $%01x",op & 0x0f); break;
77
case 0xa0: case 0xa1: case 0xa2: case 0xa3:
78
case 0xa4: case 0xa5: case 0xa6: case 0xa7:
79
case 0xa8: case 0xa9: case 0xaa: case 0xab:
80
case 0xac: case 0xad: case 0xae: case 0xaf:
81
sprintf (buffer,"ld $%01x",op & 0x0f); break;
82
case 0xb0: case 0xb1: case 0xb2: case 0xb3:
83
case 0xb4: case 0xb5: case 0xb6: case 0xb7:
84
case 0xb8: case 0xb9: case 0xba: case 0xbb:
85
case 0xbc: case 0xbd: case 0xbe: case 0xbf:
86
sprintf (buffer,"xch $%01x",op & 0x0f); break;
87
case 0xc0: case 0xc1: case 0xc2: case 0xc3:
88
case 0xc4: case 0xc5: case 0xc6: case 0xc7:
89
case 0xc8: case 0xc9: case 0xca: case 0xcb:
90
case 0xcc: case 0xcd: case 0xce: case 0xcf:
91
sprintf (buffer,"bbl $%01x",op & 0x0f); break;
92
case 0xd0: case 0xd1: case 0xd2: case 0xd3:
93
case 0xd4: case 0xd5: case 0xd6: case 0xd7:
94
case 0xd8: case 0xd9: case 0xda: case 0xdb:
95
case 0xdc: case 0xdd: case 0xde: case 0xdf:
96
sprintf (buffer,"ldm $%01x",op & 0x0f); break;
98
case 0xe0: sprintf (buffer,"wrm"); break;
99
case 0xe1: sprintf (buffer,"wmp"); break;
100
case 0xe2: sprintf (buffer,"wrr"); break;
101
case 0xe3: sprintf (buffer,"wpm"); break;
102
case 0xe4: sprintf (buffer,"wr0"); break;
103
case 0xe5: sprintf (buffer,"wr1"); break;
104
case 0xe6: sprintf (buffer,"wr2"); break;
105
case 0xe7: sprintf (buffer,"wr3"); break;
106
case 0xe8: sprintf (buffer,"sbm"); break;
107
case 0xe9: sprintf (buffer,"rdm"); break;
108
case 0xea: sprintf (buffer,"rdr"); break;
109
case 0xeb: sprintf (buffer,"adm"); break;
110
case 0xec: sprintf (buffer,"rd0"); break;
111
case 0xed: sprintf (buffer,"rd1"); break;
112
case 0xee: sprintf (buffer,"rd2"); break;
113
case 0xef: sprintf (buffer,"rd3"); break;
115
case 0xf0: sprintf (buffer,"clb"); break;
116
case 0xf1: sprintf (buffer,"clc"); break;
117
case 0xf2: sprintf (buffer,"iac"); break;
118
case 0xf3: sprintf (buffer,"cmc"); break;
119
case 0xf4: sprintf (buffer,"cma"); break;
120
case 0xf5: sprintf (buffer,"ral"); break;
121
case 0xf6: sprintf (buffer,"rar"); break;
122
case 0xf7: sprintf (buffer,"tcc"); break;
123
case 0xf8: sprintf (buffer,"dac"); break;
124
case 0xf9: sprintf (buffer,"tcs"); break;
125
case 0xfa: sprintf (buffer,"stc"); break;
126
case 0xfb: sprintf (buffer,"daa"); break;
127
case 0xfc: sprintf (buffer,"kbp"); break;
128
case 0xfd: sprintf (buffer,"dcl"); break;
130
default : sprintf (buffer,"illegal"); break;
132
return (pc - PC) | flags | DASMFLAG_SUPPORTED;