|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- const expect = require('chai').expect;
- const CPU = require('../src/chip/MOS6502/cpu.js');
- const Mem = require('../src/memory');
-
-
- describe("Testing MOS6502 CPU...", function(){
- var cpu = new CPU();
- var tick = cpu.clk();
- cpu.memory = new Mem.Memory.RAM(64);
- cpu.memory.load(0xFFFC, [0x00, 0x00]);
-
- it("Resetting (IRQ Disabled flag must be on", function(){
- cpu.reset = true;
- tick(); // One tick to handle resets.
- expect(cpu.I).to.equal(1);
- expect(cpu.PC).to.equal(0); // Test program counter set to the vector stored at 0xFFFC - 0xFFFD
- });
-
- describe("Testing flag set/clear calls...", function(){
- it("CLC / SEC", function(){
- cpu.memory.clearPage(0);
- cpu.memory.load(0, [0x18, 0x38]);
- cpu.reset = true;
- tick(); // reset.
- tick(); tick(); // Two ticks to process opcode.
- console.log(cpu);
- expect(cpu.C).to.equal(0);
- tick(); tick();
- //console.log(cpu)
- expect(cpu.C).to.equal(1);
- });
-
- it("CLI / SEI", function(){
- cpu.memory.clearPage(0);
- cpu.memory.load(0, [0x58, 0x78]);
- cpu.reset = true;
- tick();
- tick(); tick();
- expect(cpu.I).to.equal(0);
- tick(); tick();
- expect(cpu.I).to.equal(1);
- });
-
- it("CLD / SED", function(){
- cpu.memory.clearPage(0);
- cpu.memory.load(0, [0xD8, 0xF8]);
- cpu.reset = true;
- tick();
- tick(); tick();
- expect(cpu.D).to.equal(0);
- tick(); tick();
- expect(cpu.D).to.equal(1);
- });
-
- it("CLV", function(){
- cpu.memory.clearPage(0);
- cpu.memory.load(0, [0xB8]);
- cpu.reset = true;
- tick();
- tick(); tick();
- expect(cpu.V).to.equal(0);
- });
- });
-
- describe("Testing LDA...", function(){
- it("LDA Immediate", function(){
- cpu.memory.clearPage(0);
- cpu.memory.load(0, [0xA9, 0x01, 0xA9, 0xBB]);
- cpu.reset = true;
- tick();
- tick();
- tick();
- expect(cpu.A).to.equal(0x01);
- tick();
- expect(cpu.A).to.equal(0x01);
- tick();
- expect(cpu.A).to.equal(0xBB);
- });
-
- it("LDA Zero Page");
- it("LDA Zero Page, X");
- it("LDA Absolute");
- it("LDA Absolute, X");
- it("LDA Absolute, Y");
- it("LDA Indirect, X");
- it("LDA Indirect, Y");
- });
-
- describe("Testing ADC...", function(){
- it("ADC Immediate", function(){
- cpu.memory.clearPage(0);
- // CLC
- // CLV
- // CLD
- // CLI
- // LDA $00
- // ADC $01
- // ADC $01
- cpu.memory.load(0, [0x18, 0xB8, 0xD8, 0x58, 0xA9, 0x00, 0x69, 0x01, 0x69, 0x01]);
- cpu.reset = true;
- tick();
- // Getting through the 4 clear flag calls. Each should take 2 ticks.
- tick(); tick(); tick(); tick(); tick(); tick(); tick(); tick();
- // Next two ticks for the LDA call
- tick(); tick();
- // Now processing the adds.
- expect(cpu.A).to.equal(0);
- tick();
- expect(cpu.A).to.equal(0);
- tick();
- expect(cpu.A).to.equal(1);
- tick();
- expect(cpu.A).to.equal(1);
- tick();
- expect(cpu.A).to.equal(2);
- });
-
- it("ADC Zero Page");
- it("ADC Zero Page, X");
- it("ADC Absolute");
- it("ADC Absolute, X");
- it("ADC Absolute, Y");
- it("ADC Indirect, X");
- it("ADC Indirect, Y");
-
- it ("ADC Test Zero flag"/*, function(){
- cpu.memory.clearPage(0);
- cpu.memory.load(0, [0x18, 0xB8, 0xD8, 0x58, 0x69, 0xFF, 0x69, 0x01]);
- // Getting through the 4 clear flag calls. Each should take 2 ticks.
- tick(); tick(); tick(); tick(); tick(); tick(); tick(); tick();
- // Now processing the adds.
- expect(cpu.A).to.equal(0);
- tick();
- expect(cpu.A).to.equal(0);
- tick();
- expect(cpu.A).to.equal(1);
- tick();
- expect(cpu.A).to.equal(1);
- tick();
- expect(cpu.A).to.equal(2);
- }*/);
- });
-
- describe("Testing SBC...", function(){
- it("SBC Immediate", function(){
- cpu.memory.clearPage(0);
- // SEC
- // CLV
- // CLD
- // CLI
- // LDA $00
- // SBC $01
- // SBC $01
- cpu.memory.load(0, [0x38, 0xB8, 0xD8, 0x58, 0xA9, 0x00, 0xE9, 0x01, 0xE9, 0x01]);
- cpu.reset = true;
- tick();
- // Getting through the 1 set and 3 clear flag calls. Each should take 2 ticks.
- tick(); tick(); tick(); tick(); tick(); tick(); tick(); tick();
- // Next two ticks for the LDA call
- tick(); tick();
- // Now processing the subtractions.
- expect(cpu.A).to.equal(0);
- tick();
- expect(cpu.A).to.equal(0);
- tick();
- expect(cpu.A).to.equal(0xFF);
- tick();
- expect(cpu.A).to.equal(0xFF);
- tick();
- expect(cpu.A).to.equal(0xFE);
- });
-
- it("SBC Zero Page");
- it("SBC Zero Page, X");
- it("SBC Absolute");
- it("SBC Absolute, X");
- it("SBC Absolute, Y");
- it("SBC Indirect, X");
- it("SBC Indirect, Y");
- });
- });
-
-
|