Path: blob/master/libsnes/bsnes/snes/cpu/core/registers.hpp
2 views
struct flag_t {1bool n, v, m, x, d, i, z, c;23inline operator unsigned() const {4return (n << 7) + (v << 6) + (m << 5) + (x << 4)5+ (d << 3) + (i << 2) + (z << 1) + (c << 0);6}78inline unsigned operator=(uint8 data) {9n = data & 0x80; v = data & 0x40; m = data & 0x20; x = data & 0x10;10d = data & 0x08; i = data & 0x04; z = data & 0x02; c = data & 0x01;11return data;12}1314inline unsigned operator|=(unsigned data) { return operator=(operator unsigned() | data); }15inline unsigned operator^=(unsigned data) { return operator=(operator unsigned() ^ data); }16inline unsigned operator&=(unsigned data) { return operator=(operator unsigned() & data); }1718flag_t() : n(0), v(0), m(0), x(0), d(0), i(0), z(0), c(0) {}19};2021struct reg16_t {22union {23uint16 w;24struct { uint8 order_lsb2(l, h); };25};2627inline operator unsigned() const { return w; }28inline unsigned operator = (unsigned i) { return w = i; }29inline unsigned operator |= (unsigned i) { return w |= i; }30inline unsigned operator ^= (unsigned i) { return w ^= i; }31inline unsigned operator &= (unsigned i) { return w &= i; }32inline unsigned operator <<= (unsigned i) { return w <<= i; }33inline unsigned operator >>= (unsigned i) { return w >>= i; }34inline unsigned operator += (unsigned i) { return w += i; }35inline unsigned operator -= (unsigned i) { return w -= i; }36inline unsigned operator *= (unsigned i) { return w *= i; }37inline unsigned operator /= (unsigned i) { return w /= i; }38inline unsigned operator %= (unsigned i) { return w %= i; }3940reg16_t() : w(0) {}41};4243struct reg24_t {44union {45uint32 d;46struct { uint16 order_lsb2(w, wh); };47struct { uint8 order_lsb4(l, h, b, bh); };48};4950inline operator unsigned() const { return d; }51inline unsigned operator = (unsigned i) { return d = uclip<24>(i); }52inline unsigned operator |= (unsigned i) { return d = uclip<24>(d | i); }53inline unsigned operator ^= (unsigned i) { return d = uclip<24>(d ^ i); }54inline unsigned operator &= (unsigned i) { return d = uclip<24>(d & i); }55inline unsigned operator <<= (unsigned i) { return d = uclip<24>(d << i); }56inline unsigned operator >>= (unsigned i) { return d = uclip<24>(d >> i); }57inline unsigned operator += (unsigned i) { return d = uclip<24>(d + i); }58inline unsigned operator -= (unsigned i) { return d = uclip<24>(d - i); }59inline unsigned operator *= (unsigned i) { return d = uclip<24>(d * i); }60inline unsigned operator /= (unsigned i) { return d = uclip<24>(d / i); }61inline unsigned operator %= (unsigned i) { return d = uclip<24>(d % i); }6263reg24_t() : d(0) {}64};6566struct regs_t {67reg24_t pc;68reg16_t r[6], &a, &x, &y, &z, &s, &d;69flag_t p;70uint8 db;71bool e;7273bool irq; //IRQ pin (0 = low, 1 = trigger)74bool wai; //raised during wai, cleared after interrupt triggered75uint8 mdr; //memory data register76uint16 vector; //interrupt vector address7778regs_t():79a(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) {80z = 0;81}82};838485