Fantasy 8Bit system (F8), is a fantasy 8bit console and a set of libraries for creating fantasy 8bit consoles.
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

unit.src.MOS6502.cpu.spec.js 4.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. const expect = require('chai').expect;
  2. const CPU = require('../src/MOS6502/cpu.js');
  3. const Mem = require('../src/memory');
  4. describe("Testing MOS6502 CPU...", function(){
  5. var cpu = new CPU();
  6. var tick = cpu.clk();
  7. cpu.memory = new Mem.Memory.RAM(256);
  8. cpu.memory.load(0xFFFC, [0x00, 0x00]);
  9. it("Resetting (IRQ Disabled flag must be on", function(){
  10. cpu.reset = true;
  11. tick(); // One tick to handle resets.
  12. expect(cpu.I).to.equal(1);
  13. expect(cpu.PC).to.equal(0); // Test program counter set to the vector stored at 0xFFFC - 0xFFFD
  14. });
  15. describe("Testing flag set/clear calls...", function(){
  16. it("CLC / SEC", function(){
  17. cpu.memory.clearPage(0);
  18. cpu.memory.load(0, [0x18, 0x38]);
  19. cpu.reset = true;
  20. tick(); // reset.
  21. tick(); tick(); // Two ticks to process opcode.
  22. expect(cpu.C).to.equal(0);
  23. tick(); tick();
  24. expect(cpu.C).to.equal(1);
  25. });
  26. it("CLI / SEI", function(){
  27. cpu.memory.clearPage(0);
  28. cpu.memory.load(0, [0x58, 0x78]);
  29. cpu.reset = true;
  30. tick();
  31. tick(); tick();
  32. expect(cpu.I).to.equal(0);
  33. tick(); tick();
  34. expect(cpu.I).to.equal(1);
  35. });
  36. it("CLD / SED", function(){
  37. cpu.memory.clearPage(0);
  38. cpu.memory.load(0, [0xD8, 0xF8]);
  39. cpu.reset = true;
  40. tick();
  41. tick(); tick();
  42. expect(cpu.D).to.equal(0);
  43. tick(); tick();
  44. expect(cpu.D).to.equal(1);
  45. });
  46. it("CLV", function(){
  47. cpu.memory.clearPage(0);
  48. cpu.memory.load(0, [0xB8]);
  49. cpu.reset = true;
  50. tick();
  51. tick(); tick();
  52. expect(cpu.V).to.equal(0);
  53. });
  54. });
  55. describe("Testing LDA...", function(){
  56. it("LDA Immediate", function(){
  57. cpu.memory.clearPage(0);
  58. cpu.memory.load(0, [0xA9, 0x01, 0xA9, 0xBB]);
  59. cpu.reset = true;
  60. tick();
  61. tick();
  62. tick();
  63. expect(cpu.A).to.equal(0x01);
  64. tick();
  65. expect(cpu.A).to.equal(0x01);
  66. tick();
  67. expect(cpu.A).to.equal(0xBB);
  68. });
  69. it("LDA Zero Page");
  70. it("LDA Zero Page, X");
  71. it("LDA Absolute");
  72. it("LDA Absolute, X");
  73. it("LDA Absolute, Y");
  74. it("LDA Indirect, X");
  75. it("LDA Indirect, Y");
  76. });
  77. describe("Testing ADC...", function(){
  78. it("ADC Immediate", function(){
  79. cpu.memory.clearPage(0);
  80. // CLC
  81. // CLV
  82. // CLD
  83. // CLI
  84. // LDA $00
  85. // ADC $01
  86. // ADC $01
  87. cpu.memory.load(0, [0x18, 0xB8, 0xD8, 0x58, 0xA9, 0x00, 0x69, 0x01, 0x69, 0x01]);
  88. cpu.reset = true;
  89. tick();
  90. // Getting through the 4 clear flag calls. Each should take 2 ticks.
  91. tick(); tick(); tick(); tick(); tick(); tick(); tick(); tick();
  92. // Next two ticks for the LDA call
  93. tick(); tick();
  94. // Now processing the adds.
  95. expect(cpu.A).to.equal(0);
  96. tick();
  97. expect(cpu.A).to.equal(0);
  98. tick();
  99. expect(cpu.A).to.equal(1);
  100. tick();
  101. expect(cpu.A).to.equal(1);
  102. tick();
  103. expect(cpu.A).to.equal(2);
  104. });
  105. it("ADC Zero Page");
  106. it("ADC Zero Page, X");
  107. it("ADC Absolute");
  108. it("ADC Absolute, X");
  109. it("ADC Absolute, Y");
  110. it("ADC Indirect, X");
  111. it("ADC Indirect, Y");
  112. it ("ADC Test Zero flag"/*, function(){
  113. cpu.memory.clearPage(0);
  114. cpu.memory.load(0, [0x18, 0xB8, 0xD8, 0x58, 0x69, 0xFF, 0x69, 0x01]);
  115. // Getting through the 4 clear flag calls. Each should take 2 ticks.
  116. tick(); tick(); tick(); tick(); tick(); tick(); tick(); tick();
  117. // Now processing the adds.
  118. expect(cpu.A).to.equal(0);
  119. tick();
  120. expect(cpu.A).to.equal(0);
  121. tick();
  122. expect(cpu.A).to.equal(1);
  123. tick();
  124. expect(cpu.A).to.equal(1);
  125. tick();
  126. expect(cpu.A).to.equal(2);
  127. }*/);
  128. });
  129. describe("Testing SBC...", function(){
  130. it("SBC Immediate", function(){
  131. cpu.memory.clearPage(0);
  132. // SEC
  133. // CLV
  134. // CLD
  135. // CLI
  136. // LDA $00
  137. // SBC $01
  138. // SBC $01
  139. cpu.memory.load(0, [0x38, 0xB8, 0xD8, 0x58, 0xA9, 0x00, 0xE9, 0x01, 0xE9, 0x01]);
  140. cpu.reset = true;
  141. tick();
  142. // Getting through the 1 set and 3 clear flag calls. Each should take 2 ticks.
  143. tick(); tick(); tick(); tick(); tick(); tick(); tick(); tick();
  144. // Next two ticks for the LDA call
  145. tick(); tick();
  146. // Now processing the subtractions.
  147. expect(cpu.A).to.equal(0);
  148. tick();
  149. expect(cpu.A).to.equal(0);
  150. tick();
  151. expect(cpu.A).to.equal(0xFF);
  152. tick();
  153. expect(cpu.A).to.equal(0xFF);
  154. tick();
  155. expect(cpu.A).to.equal(0xFE);
  156. });
  157. it("SBC Zero Page");
  158. it("SBC Zero Page, X");
  159. it("SBC Absolute");
  160. it("SBC Absolute, X");
  161. it("SBC Absolute, Y");
  162. it("SBC Indirect, X");
  163. it("SBC Indirect, Y");
  164. });
  165. });