mirror of
https://github.com/pevans/erc-c.git
synced 2025-01-26 01:30:53 +00:00
Set carry if the right-most bit is 1
Don't consider the left-most bit
This commit is contained in:
parent
5d8403aaa7
commit
3206332a7d
@ -97,8 +97,17 @@ DEFINE_INST(lsr)
|
||||
{
|
||||
SET_RESULT(oper >> 1);
|
||||
|
||||
// MOS_NEGATIVE is intentionally not included here.
|
||||
mos6502_modify_status(cpu, MOS_ZC, oper, result);
|
||||
// Set ZERO if it should apply
|
||||
mos6502_modify_status(cpu, MOS_ZERO, oper, result);
|
||||
|
||||
// However, we handle carry a bit differently here. The carry bit
|
||||
// should be 1 if oper & 0x1; that is, when we shift right, we want
|
||||
// the right-most bit to be captured in carry, in just the same way
|
||||
// we want the left-most bit to be captured in carry for ASL.
|
||||
cpu->P &= ~MOS_CARRY;
|
||||
if (oper & 0x1) {
|
||||
cpu->P |= MOS_CARRY;
|
||||
}
|
||||
|
||||
if (cpu->eff_addr) {
|
||||
mos6502_set(cpu, cpu->eff_addr, result & 0xff);
|
||||
|
Loading…
x
Reference in New Issue
Block a user