1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#define FALSE 0
#define TRUE 1
enum Addressing {
eImmediate,
eAbsolute,
eZeroPage,
eImplied,
eIndirectAbsolute,
eAbsoluteIndexedX,
eAbsoluteIndexedY,
eZeroPageIndexedX,
eZeroPageIndexedY,
eIndexedIndirect,
eIndirectIndexed,
eRelative,
eAccumulator
};
typedef int Addressing;
int getLength(Addressing addr){
switch(addr){
case eAbsolute: case eAbsoluteIndexedX: case eAbsoluteIndexedY:
return 3;
case eAccumulator:
return 1;
default:
return 2;
}
}
/*
* Any addressing method which is single line commented out without definition
* implies that handling should be hard-coded in the switch case of the
* instruction from which it came.
*/
int fAddressing(Addressing addr, short x) {
switch(addr){
case eImmediate: return x;
case eAccumulator: return acc;
case eAbsolute: return Memory[x];
case eAbsoluteIndexedX: return Memory[(x + X)];
case eAbsoluteIndexedY: return Memory[(x + Y)];
case eZeroPage: return Memory[(x & 0x00FF)];
case eZeroPageIndexedX: return Memory[((x = X) & 0x00FF)];
case eZeroPageIndexedY: return Memory[((x = Y) & 0x00FF)];
case eIndexedIndirect: return Memory[((x + X) << 8) + ((x + X) + 1)];
case eIndirectIndexed: return ((Memory[x] + Memory[(x+1 << 8)]) + Y);
//case eImplied: No reference
//case eIndirectAbsolute: Only used in the JMP instruction
//case eRelative: Only used in branch instructions
}
}
|