Skip to content

Commit

Permalink
LSR
Browse files Browse the repository at this point in the history
  • Loading branch information
Shachar committed Sep 11, 2023
1 parent ac26d3c commit 681bd3b
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 0 deletions.
29 changes: 29 additions & 0 deletions c6502.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -85,17 +85,22 @@ void c6502::handleInstruction() {
case 0x40: op_rti( addrmode_stack() ); break;
case 0x41: op_eor( addrmode_zp_x_ind() ); break;
case 0x45: op_eor( addrmode_zp() ); break;
case 0x46: op_lsr( addrmode_zp() ); break;
case 0x48: op_pha( addrmode_stack() ); break;
case 0x49: op_eor( addrmode_immediate() ); break;
case 0x4a: op_lsrA(); break;
case 0x4c: op_jmp( addrmode_abs() ); break;
case 0x4d: op_eor( addrmode_abs() ); break;
case 0x4e: op_lsr( addrmode_abs() ); break;
case 0x50: op_bvc( addrmode_immediate() ); break;
case 0x51: op_eor( addrmode_zp_ind_y() ); break;
case 0x52: op_eor( addrmode_zp_ind() ); break;
case 0x55: op_eor( addrmode_zp_x() ); break;
case 0x56: op_lsr( addrmode_zp_x() ); break;
case 0x58: op_cli( addrmode_implicit() ); break;
case 0x59: op_eor( addrmode_abs_y() ); break;
case 0x5d: op_eor( addrmode_abs_x() ); break;
case 0x5e: op_lsr( addrmode_abs_x() ); break;
case 0x60: op_rts( addrmode_stack() ); break;
case 0x61: op_adc( addrmode_zp_x_ind() ); break;
case 0x65: op_adc( addrmode_zp() ); break;
Expand Down Expand Up @@ -652,6 +657,30 @@ void c6502::op_ldy(Addr addr) {
ccSet( CC::Negative, regY & 0x80 );
}

void c6502::op_lsr(Addr addr) {
uint8_t val = read(addr);
write(addr, val);

ccSet( CC::Carry, val&0x01 );
val >>= 1;

ccSet( CC::Negative, val&0x80 );
ccSet( CC::Zero, val==0 );

write(addr, val);
}

void c6502::op_lsrA() {
read( pc() );

ccSet( CC::Carry, regA&0x01 );

regA >>= 1;

ccSet( CC::Negative, regA&0x80 );
ccSet( CC::Zero, regA==0 );
}

void c6502::op_nop(Addr addr) {
}

Expand Down
2 changes: 2 additions & 0 deletions c6502.h
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,8 @@ class c6502 {
void op_lda(Addr addr);
void op_ldx(Addr addr);
void op_ldy(Addr addr);
void op_lsr(Addr addr);
void op_lsrA();
void op_nop(Addr addr);
void op_ora(Addr addr);
void op_pha(Addr addr);
Expand Down

0 comments on commit 681bd3b

Please sign in to comment.