Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
alexbevi
GitHub Repository: alexbevi/BizHawk
Path: blob/master/libsnes/bsnes/snes/cpu/core/registers.hpp
2 views
1
struct flag_t {
2
bool n, v, m, x, d, i, z, c;
3
4
inline operator unsigned() const {
5
return (n << 7) + (v << 6) + (m << 5) + (x << 4)
6
+ (d << 3) + (i << 2) + (z << 1) + (c << 0);
7
}
8
9
inline unsigned operator=(uint8 data) {
10
n = data & 0x80; v = data & 0x40; m = data & 0x20; x = data & 0x10;
11
d = data & 0x08; i = data & 0x04; z = data & 0x02; c = data & 0x01;
12
return data;
13
}
14
15
inline unsigned operator|=(unsigned data) { return operator=(operator unsigned() | data); }
16
inline unsigned operator^=(unsigned data) { return operator=(operator unsigned() ^ data); }
17
inline unsigned operator&=(unsigned data) { return operator=(operator unsigned() & data); }
18
19
flag_t() : n(0), v(0), m(0), x(0), d(0), i(0), z(0), c(0) {}
20
};
21
22
struct reg16_t {
23
union {
24
uint16 w;
25
struct { uint8 order_lsb2(l, h); };
26
};
27
28
inline operator unsigned() const { return w; }
29
inline unsigned operator = (unsigned i) { return w = i; }
30
inline unsigned operator |= (unsigned i) { return w |= i; }
31
inline unsigned operator ^= (unsigned i) { return w ^= i; }
32
inline unsigned operator &= (unsigned i) { return w &= i; }
33
inline unsigned operator <<= (unsigned i) { return w <<= i; }
34
inline unsigned operator >>= (unsigned i) { return w >>= i; }
35
inline unsigned operator += (unsigned i) { return w += i; }
36
inline unsigned operator -= (unsigned i) { return w -= i; }
37
inline unsigned operator *= (unsigned i) { return w *= i; }
38
inline unsigned operator /= (unsigned i) { return w /= i; }
39
inline unsigned operator %= (unsigned i) { return w %= i; }
40
41
reg16_t() : w(0) {}
42
};
43
44
struct reg24_t {
45
union {
46
uint32 d;
47
struct { uint16 order_lsb2(w, wh); };
48
struct { uint8 order_lsb4(l, h, b, bh); };
49
};
50
51
inline operator unsigned() const { return d; }
52
inline unsigned operator = (unsigned i) { return d = uclip<24>(i); }
53
inline unsigned operator |= (unsigned i) { return d = uclip<24>(d | i); }
54
inline unsigned operator ^= (unsigned i) { return d = uclip<24>(d ^ i); }
55
inline unsigned operator &= (unsigned i) { return d = uclip<24>(d & i); }
56
inline unsigned operator <<= (unsigned i) { return d = uclip<24>(d << i); }
57
inline unsigned operator >>= (unsigned i) { return d = uclip<24>(d >> i); }
58
inline unsigned operator += (unsigned i) { return d = uclip<24>(d + i); }
59
inline unsigned operator -= (unsigned i) { return d = uclip<24>(d - i); }
60
inline unsigned operator *= (unsigned i) { return d = uclip<24>(d * i); }
61
inline unsigned operator /= (unsigned i) { return d = uclip<24>(d / i); }
62
inline unsigned operator %= (unsigned i) { return d = uclip<24>(d % i); }
63
64
reg24_t() : d(0) {}
65
};
66
67
struct regs_t {
68
reg24_t pc;
69
reg16_t r[6], &a, &x, &y, &z, &s, &d;
70
flag_t p;
71
uint8 db;
72
bool e;
73
74
bool irq; //IRQ pin (0 = low, 1 = trigger)
75
bool wai; //raised during wai, cleared after interrupt triggered
76
uint8 mdr; //memory data register
77
uint16 vector; //interrupt vector address
78
79
regs_t():
80
a(r[0]), x(r[1]), y(r[2]), z(r[3]), s(r[4]), d(r[5]), db(0), e(false), irq(false), wai(false), mdr(0), vector(0) {
81
z = 0;
82
}
83
};
84
85