mirror of
https://github.com/MoleskiCoder/EightBit.git
synced 2025-01-11 17:29:57 +00:00
Rearrange some of the shift/rotate code a little to make it easier to read.
Signed-off-by: Adrian.Conlon <adrian.conlon@gmail.com>
This commit is contained in:
parent
54ab96ea38
commit
039545bd08
@ -220,54 +220,50 @@ void EightBit::LR35902::compare(uint8_t& f, uint8_t check, uint8_t value) {
|
|||||||
uint8_t EightBit::LR35902::rlc(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::rlc(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
setFlag(f, CF, operand & Bit7);
|
setFlag(f, CF, operand & Bit7);
|
||||||
operand = _rotl8(operand, 1);
|
return _rotl8(operand, 1);
|
||||||
return operand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::rrc(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::rrc(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
setFlag(f, CF, operand & Bit0);
|
setFlag(f, CF, operand & Bit0);
|
||||||
operand = _rotr8(operand, 1);
|
return _rotr8(operand, 1);
|
||||||
return operand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::rl(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::rl(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
const auto carry = (f & CF) >> 4;
|
const auto carry = f & CF;
|
||||||
setFlag(f, CF, operand & Bit7);
|
setFlag(f, CF, operand & Bit7);
|
||||||
operand = (operand << 1) | carry;
|
return (operand << 1) | (carry >> 4); // CF at Bit4
|
||||||
return operand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::rr(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::rr(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
const auto carry = (f & CF) >> 4;
|
const auto carry = f & CF;
|
||||||
setFlag(f, CF, operand & Bit0);
|
setFlag(f, CF, operand & Bit0);
|
||||||
operand = (operand >> 1) | (carry << 7);
|
return (operand >> 1) | (carry << 3); // CF at Bit4
|
||||||
return operand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::sla(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::sla(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
setFlag(f, CF, operand & Bit7);
|
setFlag(f, CF, operand & Bit7);
|
||||||
operand <<= 1;
|
return operand << 1;
|
||||||
return operand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::sra(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::sra(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
setFlag(f, CF, operand & Bit0);
|
setFlag(f, CF, operand & Bit0);
|
||||||
operand = (operand >> 1) | operand & Bit7;
|
return (operand >> 1) | (operand & Bit7);
|
||||||
return operand;
|
}
|
||||||
|
|
||||||
|
uint8_t EightBit::LR35902::swap(uint8_t& f, uint8_t operand) {
|
||||||
|
clearFlag(f, NF | HC | CF);
|
||||||
|
return promoteNibble(operand) | demoteNibble(operand);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::srl(uint8_t& f, uint8_t operand) {
|
uint8_t EightBit::LR35902::srl(uint8_t& f, uint8_t operand) {
|
||||||
clearFlag(f, NF | HC | ZF);
|
clearFlag(f, NF | HC | ZF);
|
||||||
setFlag(f, CF, operand & Bit0);
|
setFlag(f, CF, operand & Bit0);
|
||||||
operand = (operand >> 1) & ~Bit7;
|
return (operand >> 1) & ~Bit7;
|
||||||
return operand;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#pragma endregion Shift and rotate
|
#pragma endregion Shift and rotate
|
||||||
@ -332,15 +328,6 @@ void EightBit::LR35902::ccf(uint8_t& a, uint8_t& f) {
|
|||||||
clearFlag(f, CF, f & CF);
|
clearFlag(f, CF, f & CF);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t EightBit::LR35902::swap(uint8_t& f, uint8_t operand) {
|
|
||||||
auto low = lowNibble(operand);
|
|
||||||
auto high = highNibble(operand);
|
|
||||||
operand = promoteNibble(low) | high;
|
|
||||||
adjustZero<LR35902>(f, operand);
|
|
||||||
clearFlag(f, NF | HC | CF);
|
|
||||||
return operand;
|
|
||||||
}
|
|
||||||
|
|
||||||
#pragma endregion Miscellaneous instructions
|
#pragma endregion Miscellaneous instructions
|
||||||
|
|
||||||
int EightBit::LR35902::step() {
|
int EightBit::LR35902::step() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user