mirror of
https://github.com/jscrane/r65emu.git
synced 2025-01-23 10:31:03 +00:00
parity table
This commit is contained in:
parent
4063ecaba5
commit
bdd84b908c
46
z80.cpp
46
z80.cpp
@ -136,7 +136,7 @@ void z80::daa() {
|
|||||||
else
|
else
|
||||||
_add(a);
|
_add(a);
|
||||||
flags.C = c;
|
flags.C = c;
|
||||||
flags.P = parity_table[A];
|
flags.P = parity_table(A);
|
||||||
}
|
}
|
||||||
|
|
||||||
void z80::_step_idx(OP_IDX ops[]) {
|
void z80::_step_idx(OP_IDX ops[]) {
|
||||||
@ -641,7 +641,7 @@ void z80::ed() {
|
|||||||
c = b + C + 1;
|
c = b + C + 1;
|
||||||
flags.N = (b & 0x80) != 0;
|
flags.N = (b & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
break;
|
break;
|
||||||
case 0xa3:
|
case 0xa3:
|
||||||
@ -653,7 +653,7 @@ void z80::ed() {
|
|||||||
c = b + L;
|
c = b + L;
|
||||||
flags.N = (b & 0x80) != 0;
|
flags.N = (b & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
break;
|
break;
|
||||||
case 0xa8:
|
case 0xa8:
|
||||||
@ -694,7 +694,7 @@ void z80::ed() {
|
|||||||
c = b + C - 1;
|
c = b + C - 1;
|
||||||
flags.N = (b & 0x80) != 0;
|
flags.N = (b & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
break;
|
break;
|
||||||
case 0xab:
|
case 0xab:
|
||||||
@ -706,7 +706,7 @@ void z80::ed() {
|
|||||||
c = b + L;
|
c = b + L;
|
||||||
flags.N = (b & 0x80) != 0;
|
flags.N = (b & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
break;
|
break;
|
||||||
case 0xb0:
|
case 0xb0:
|
||||||
@ -758,7 +758,7 @@ void z80::ed() {
|
|||||||
c = b + flags.C + 1;
|
c = b + flags.C + 1;
|
||||||
flags.N = (c & 0x80) != 0;
|
flags.N = (c & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
if (B) {
|
if (B) {
|
||||||
_mc(HL, 1); _mc(HL, 1); _mc(HL, 1);
|
_mc(HL, 1); _mc(HL, 1); _mc(HL, 1);
|
||||||
@ -776,7 +776,7 @@ void z80::ed() {
|
|||||||
c = b + L;
|
c = b + L;
|
||||||
flags.N = (b & 0x80) != 0;
|
flags.N = (b & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
if (B) {
|
if (B) {
|
||||||
_mc(BC, 1); _mc(BC, 1); _mc(BC, 1);
|
_mc(BC, 1); _mc(BC, 1); _mc(BC, 1);
|
||||||
@ -829,7 +829,7 @@ void z80::ed() {
|
|||||||
c = b + flags.C + 1;
|
c = b + flags.C + 1;
|
||||||
flags.N = (c & 0x80) != 0;
|
flags.N = (c & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
if (B) {
|
if (B) {
|
||||||
_mc(HL, 1); _mc(HL, 1); _mc(HL, 1);
|
_mc(HL, 1); _mc(HL, 1); _mc(HL, 1);
|
||||||
@ -847,7 +847,7 @@ void z80::ed() {
|
|||||||
c = b + L;
|
c = b + L;
|
||||||
flags.N = (b & 0x80) != 0;
|
flags.N = (b & 0x80) != 0;
|
||||||
flags.C = flags.H = (c < b);
|
flags.C = flags.H = (c < b);
|
||||||
flags.P = parity_table[(c & 0x07) ^ B];
|
flags.P = parity_table((c & 0x07) ^ B);
|
||||||
_sz35(B);
|
_sz35(B);
|
||||||
if (B) {
|
if (B) {
|
||||||
_mc(BC, 1); _mc(BC, 1); _mc(BC, 1);
|
_mc(BC, 1); _mc(BC, 1); _mc(BC, 1);
|
||||||
@ -858,25 +858,19 @@ void z80::ed() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int z80::parity_table[] = {
|
const uint8_t partab[] PROGMEM = {
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
0x69, 0x96, 0x96, 0x69, 0x96, 0x69, 0x69, 0x96,
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
0x96, 0x69, 0x69, 0x96, 0x69, 0x96, 0x96, 0x69,
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
0x96, 0x69, 0x69, 0x96, 0x69, 0x96, 0x96, 0x69,
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
0x69, 0x96, 0x96, 0x69, 0x96, 0x69, 0x69, 0x96,
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
||||||
0, 1, 1, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0,
|
|
||||||
1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0, 1,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
uint8_t z80::parity_table(uint8_t r) {
|
||||||
|
uint8_t i = r / 8, b = pgm_read_byte(partab + i);
|
||||||
|
uint8_t m = (1 << (r % 8));
|
||||||
|
return m == (b & m);
|
||||||
|
}
|
||||||
|
|
||||||
z80::z80(Memory &m, PortDevice<z80> &ports): CPU(m)
|
z80::z80(Memory &m, PortDevice<z80> &ports): CPU(m)
|
||||||
{
|
{
|
||||||
_ports = &ports;
|
_ports = &ports;
|
||||||
|
4
z80.h
4
z80.h
@ -144,7 +144,7 @@ private:
|
|||||||
OP _ops[256], _cb[256];
|
OP _ops[256], _cb[256];
|
||||||
OP_IDX _ddcb[256], _fdcb[256];
|
OP_IDX _ddcb[256], _fdcb[256];
|
||||||
|
|
||||||
static int parity_table[256];
|
uint8_t parity_table(uint8_t);
|
||||||
|
|
||||||
inline uint8_t _rb(Memory::address a) {
|
inline uint8_t _rb(Memory::address a) {
|
||||||
#if defined(CPU_DEBUG)
|
#if defined(CPU_DEBUG)
|
||||||
@ -211,7 +211,7 @@ private:
|
|||||||
|
|
||||||
inline void _szp35(uint8_t r) {
|
inline void _szp35(uint8_t r) {
|
||||||
_sz35(r);
|
_sz35(r);
|
||||||
flags.P = parity_table[r];
|
flags.P = parity_table(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void _inc(uint8_t &b) {
|
inline void _inc(uint8_t &b) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user