mirror of
https://github.com/pevans/erc-c.git
synced 2025-01-18 10:30:37 +00:00
978ad1faaf
But weird forms. In most cases they basically are NOPs, except with different opcodes. In other cases, we call them NP2 and NP3s, and do so because they consume 2 or 3 bytes respectively (vs. just 1 with NOP). We had to teach some arcane magic to the emulator for this to work. We may want to refactor to decouple the number of bytes consumed from the address mode.
78 lines
1.6 KiB
C
78 lines
1.6 KiB
C
#include <criterion/criterion.h>
|
|
|
|
#include "mos6502.h"
|
|
#include "mos6502.enums.h"
|
|
#include "mos6502.tests.h"
|
|
|
|
TestSuite(mos6502_exec, .init = setup, .fini = teardown);
|
|
|
|
Test(mos6502_exec, brk)
|
|
{
|
|
// Start out with the decimal bit high so we can test it gets turned
|
|
// off; this assignment also guarantees the I bit is low, and that
|
|
// should be set high by the handler as well.
|
|
cpu->P = MOS_DECIMAL;
|
|
|
|
vm_8bit orig_P = cpu->P;
|
|
|
|
cpu->PC = 123;
|
|
mos6502_handle_brk(cpu, 0);
|
|
cr_assert_eq(cpu->PC, 125);
|
|
cr_assert_eq(cpu->P & MOS_INTERRUPT, MOS_INTERRUPT);
|
|
cr_assert_eq(cpu->P & MOS_DECIMAL, 0);
|
|
|
|
cr_assert_eq(mos6502_pop_stack(cpu), orig_P);
|
|
cr_assert_eq(mos6502_pop_stack(cpu), 123);
|
|
}
|
|
|
|
Test(mos6502_exec, jmp)
|
|
{
|
|
cpu->PC = 123;
|
|
cpu->eff_addr = 234;
|
|
mos6502_handle_jmp(cpu, 0);
|
|
|
|
cr_assert_eq(cpu->PC, 234);
|
|
}
|
|
|
|
Test(mos6502_exec, jsr)
|
|
{
|
|
cpu->PC = 123;
|
|
cpu->eff_addr = 235;
|
|
mos6502_handle_jsr(cpu, 0);
|
|
|
|
cr_assert_eq(cpu->PC, 235);
|
|
|
|
cr_assert_eq(mos6502_pop_stack(cpu), 125);
|
|
}
|
|
|
|
/*
|
|
* In addition to nop, we also have np2 and np3 which also do nothing.
|
|
* We're just passing on those.
|
|
*
|
|
* Test(mos6502_exec, np2)
|
|
* Test(mos6502_exec, np3)
|
|
*/
|
|
Test(mos6502_exec, nop)
|
|
{
|
|
// currently this test does nothing -- we _should_ test to see if we
|
|
// pass the right number of cycles, though.
|
|
}
|
|
|
|
Test(mos6502_exec, rti)
|
|
{
|
|
mos6502_push_stack(cpu, 222);
|
|
mos6502_push_stack(cpu, cpu->P);
|
|
|
|
mos6502_handle_rti(cpu, 0);
|
|
|
|
cr_assert_eq(cpu->PC, 222);
|
|
}
|
|
|
|
Test(mos6502_exec, rts)
|
|
{
|
|
mos6502_push_stack(cpu, 233);
|
|
mos6502_handle_rts(cpu, 0);
|
|
|
|
cr_assert_eq(cpu->PC, 234);
|
|
}
|