2016-02-04 10:29:08 +00:00
|
|
|
//9e sahf
|
|
|
|
auto V30MZ::opStoreFlagsAcc() {
|
|
|
|
wait(3);
|
|
|
|
r.f = (r.f & 0xff00) | r.ah;
|
|
|
|
}
|
|
|
|
|
|
|
|
//9f lahf
|
|
|
|
auto V30MZ::opLoadAccFlags() {
|
|
|
|
wait(1);
|
|
|
|
r.ah = (r.f & 0x00ff);
|
|
|
|
}
|
|
|
|
|
|
|
|
//f5 cmc
|
|
|
|
auto V30MZ::opComplementCarry() {
|
|
|
|
wait(3);
|
|
|
|
r.f.c = !r.f.c;
|
|
|
|
}
|
|
|
|
|
2016-06-08 22:26:35 +00:00
|
|
|
auto V30MZ::opClearFlag(uint bit) {
|
2016-02-04 10:29:08 +00:00
|
|
|
wait(3);
|
2016-06-08 22:26:35 +00:00
|
|
|
r.f &= ~(1 << bit);
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|
|
|
|
|
2016-06-08 22:26:35 +00:00
|
|
|
auto V30MZ::opSetFlag(uint bit) {
|
2016-02-04 10:29:08 +00:00
|
|
|
wait(3);
|
2016-06-08 22:26:35 +00:00
|
|
|
r.f |= 1 << bit;
|
|
|
|
if(bit == r.f.i.bit) state.poll = false;
|
2016-02-04 10:29:08 +00:00
|
|
|
}
|