ac6502 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (115) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +261 -0
  3. package/dist/components/CPU.js +1170 -0
  4. package/dist/components/CPU.js.map +1 -0
  5. package/dist/components/Cart.js +23 -0
  6. package/dist/components/Cart.js.map +1 -0
  7. package/dist/components/IO/Empty.js +19 -0
  8. package/dist/components/IO/Empty.js.map +1 -0
  9. package/dist/components/IO/GPIOAttachments/GPIOAttachment.js +71 -0
  10. package/dist/components/IO/GPIOAttachments/GPIOAttachment.js.map +1 -0
  11. package/dist/components/IO/GPIOAttachments/GPIOJoystickAttachment.js +90 -0
  12. package/dist/components/IO/GPIOAttachments/GPIOJoystickAttachment.js.map +1 -0
  13. package/dist/components/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.js +489 -0
  14. package/dist/components/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.js.map +1 -0
  15. package/dist/components/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.js +274 -0
  16. package/dist/components/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.js.map +1 -0
  17. package/dist/components/IO/GPIOCard.js +597 -0
  18. package/dist/components/IO/GPIOCard.js.map +1 -0
  19. package/dist/components/IO/InputBoard.js +19 -0
  20. package/dist/components/IO/InputBoard.js.map +1 -0
  21. package/dist/components/IO/LCDCard.js +19 -0
  22. package/dist/components/IO/LCDCard.js.map +1 -0
  23. package/dist/components/IO/RAMCard.js +63 -0
  24. package/dist/components/IO/RAMCard.js.map +1 -0
  25. package/dist/components/IO/RTCCard.js +483 -0
  26. package/dist/components/IO/RTCCard.js.map +1 -0
  27. package/dist/components/IO/SerialCard.js +282 -0
  28. package/dist/components/IO/SerialCard.js.map +1 -0
  29. package/dist/components/IO/SoundCard.js +620 -0
  30. package/dist/components/IO/SoundCard.js.map +1 -0
  31. package/dist/components/IO/StorageCard.js +428 -0
  32. package/dist/components/IO/StorageCard.js.map +1 -0
  33. package/dist/components/IO/VGACard.js +9 -0
  34. package/dist/components/IO/VGACard.js.map +1 -0
  35. package/dist/components/IO/VideoCard.js +623 -0
  36. package/dist/components/IO/VideoCard.js.map +1 -0
  37. package/dist/components/IO.js +3 -0
  38. package/dist/components/IO.js.map +1 -0
  39. package/dist/components/Machine.js +310 -0
  40. package/dist/components/Machine.js.map +1 -0
  41. package/dist/components/RAM.js +24 -0
  42. package/dist/components/RAM.js.map +1 -0
  43. package/dist/components/ROM.js +23 -0
  44. package/dist/components/ROM.js.map +1 -0
  45. package/dist/index.js +441 -0
  46. package/dist/index.js.map +1 -0
  47. package/dist/tests/CPU.test.js +1626 -0
  48. package/dist/tests/CPU.test.js.map +1 -0
  49. package/dist/tests/Cart.test.js +119 -0
  50. package/dist/tests/Cart.test.js.map +1 -0
  51. package/dist/tests/IO/GPIOAttachments/GPIOAttachment.test.js +339 -0
  52. package/dist/tests/IO/GPIOAttachments/GPIOAttachment.test.js.map +1 -0
  53. package/dist/tests/IO/GPIOAttachments/GPIOJoystickAttachment.test.js +126 -0
  54. package/dist/tests/IO/GPIOAttachments/GPIOJoystickAttachment.test.js.map +1 -0
  55. package/dist/tests/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.test.js +779 -0
  56. package/dist/tests/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.test.js.map +1 -0
  57. package/dist/tests/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.test.js +355 -0
  58. package/dist/tests/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.test.js.map +1 -0
  59. package/dist/tests/IO/GPIOCard.test.js +503 -0
  60. package/dist/tests/IO/GPIOCard.test.js.map +1 -0
  61. package/dist/tests/IO/RAMCard.test.js +229 -0
  62. package/dist/tests/IO/RAMCard.test.js.map +1 -0
  63. package/dist/tests/IO/RTCCard.test.js +177 -0
  64. package/dist/tests/IO/RTCCard.test.js.map +1 -0
  65. package/dist/tests/IO/SerialCard.test.js +423 -0
  66. package/dist/tests/IO/SerialCard.test.js.map +1 -0
  67. package/dist/tests/IO/SoundCard.test.js +528 -0
  68. package/dist/tests/IO/SoundCard.test.js.map +1 -0
  69. package/dist/tests/IO/StorageCard.test.js +647 -0
  70. package/dist/tests/IO/StorageCard.test.js.map +1 -0
  71. package/dist/tests/IO/VideoCard.test.js +549 -0
  72. package/dist/tests/IO/VideoCard.test.js.map +1 -0
  73. package/dist/tests/Machine.test.js +383 -0
  74. package/dist/tests/Machine.test.js.map +1 -0
  75. package/dist/tests/RAM.test.js +160 -0
  76. package/dist/tests/RAM.test.js.map +1 -0
  77. package/dist/tests/ROM.test.js +123 -0
  78. package/dist/tests/ROM.test.js.map +1 -0
  79. package/jest.config.cjs +9 -0
  80. package/package.json +43 -0
  81. package/src/components/CPU.ts +1371 -0
  82. package/src/components/Cart.ts +20 -0
  83. package/src/components/IO/GPIOAttachments/GPIOAttachment.ts +189 -0
  84. package/src/components/IO/GPIOAttachments/GPIOJoystickAttachment.ts +99 -0
  85. package/src/components/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.ts +465 -0
  86. package/src/components/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.ts +287 -0
  87. package/src/components/IO/GPIOCard.ts +677 -0
  88. package/src/components/IO/RAMCard.ts +68 -0
  89. package/src/components/IO/RTCCard.ts +518 -0
  90. package/src/components/IO/SerialCard.ts +335 -0
  91. package/src/components/IO/SoundCard.ts +711 -0
  92. package/src/components/IO/StorageCard.ts +473 -0
  93. package/src/components/IO/VideoCard.ts +730 -0
  94. package/src/components/IO.ts +11 -0
  95. package/src/components/Machine.ts +364 -0
  96. package/src/components/RAM.ts +23 -0
  97. package/src/components/ROM.ts +19 -0
  98. package/src/index.ts +474 -0
  99. package/src/tests/CPU.test.ts +2045 -0
  100. package/src/tests/Cart.test.ts +149 -0
  101. package/src/tests/IO/GPIOAttachments/GPIOAttachment.test.ts +413 -0
  102. package/src/tests/IO/GPIOAttachments/GPIOJoystickAttachment.test.ts +147 -0
  103. package/src/tests/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.test.ts +961 -0
  104. package/src/tests/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.test.ts +449 -0
  105. package/src/tests/IO/GPIOCard.test.ts +644 -0
  106. package/src/tests/IO/RAMCard.test.ts +284 -0
  107. package/src/tests/IO/RTCCard.test.ts +222 -0
  108. package/src/tests/IO/SerialCard.test.ts +530 -0
  109. package/src/tests/IO/SoundCard.test.ts +659 -0
  110. package/src/tests/IO/StorageCard.test.ts +787 -0
  111. package/src/tests/IO/VideoCard.test.ts +668 -0
  112. package/src/tests/Machine.test.ts +437 -0
  113. package/src/tests/RAM.test.ts +196 -0
  114. package/src/tests/ROM.test.ts +154 -0
  115. package/tsconfig.json +12 -0
@@ -0,0 +1,229 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const RAMCard_1 = require("../../components/IO/RAMCard");
4
+ describe('RAMCard', () => {
5
+ let ramCard;
6
+ beforeEach(() => {
7
+ ramCard = new RAMCard_1.RAMCard();
8
+ });
9
+ describe('Static Properties', () => {
10
+ it('should have correct total size', () => {
11
+ expect(RAMCard_1.RAMCard.TOTAL_SIZE).toBe(256 * 1024);
12
+ });
13
+ it('should have correct bank size', () => {
14
+ expect(RAMCard_1.RAMCard.BANK_SIZE).toBe(1024);
15
+ });
16
+ it('should have correct number of banks', () => {
17
+ expect(RAMCard_1.RAMCard.NUM_BANKS).toBe(256);
18
+ });
19
+ it('should have correct bank control register address', () => {
20
+ expect(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER).toBe(0x3FF);
21
+ });
22
+ });
23
+ describe('Initialization', () => {
24
+ it('should initialize with all data as 0x00', () => {
25
+ for (let i = 0; i < RAMCard_1.RAMCard.TOTAL_SIZE; i++) {
26
+ expect(ramCard.data[i]).toBe(0x00);
27
+ }
28
+ });
29
+ it('should start on bank 0', () => {
30
+ expect(ramCard.currentBank).toBe(0);
31
+ });
32
+ it('should have IRQ and NMI callbacks', () => {
33
+ expect(typeof ramCard.raiseIRQ).toBe('function');
34
+ expect(typeof ramCard.raiseNMI).toBe('function');
35
+ });
36
+ });
37
+ describe('Reading', () => {
38
+ it('should read data from current bank', () => {
39
+ ramCard.data[100] = 0x42;
40
+ expect(ramCard.read(100)).toBe(0x42);
41
+ });
42
+ it('should read from address 0', () => {
43
+ ramCard.data[0] = 0xAB;
44
+ expect(ramCard.read(0)).toBe(0xAB);
45
+ });
46
+ it('should read from address 0x3FE (last data address)', () => {
47
+ ramCard.write(0x3FE, 0xCD);
48
+ expect(ramCard.read(0x3FE)).toBe(0xCD);
49
+ });
50
+ it('should read bank control register and return current bank', () => {
51
+ ramCard.currentBank = 0;
52
+ expect(ramCard.read(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER)).toBe(0);
53
+ ramCard.currentBank = 42;
54
+ expect(ramCard.read(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER)).toBe(42);
55
+ ramCard.currentBank = 255;
56
+ expect(ramCard.read(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER)).toBe(255);
57
+ });
58
+ });
59
+ describe('Writing', () => {
60
+ it('should write data to current bank', () => {
61
+ ramCard.write(100, 0x42);
62
+ expect(ramCard.data[100]).toBe(0x42);
63
+ });
64
+ it('should write to address 0', () => {
65
+ ramCard.write(0, 0xAB);
66
+ expect(ramCard.data[0]).toBe(0xAB);
67
+ });
68
+ it('should write to address 0x3FE', () => {
69
+ ramCard.write(0x3FE, 0xCD);
70
+ expect(ramCard.read(0x3FE)).toBe(0xCD);
71
+ });
72
+ it('should mask data to 0xFF', () => {
73
+ ramCard.write(100, 0x1FF);
74
+ expect(ramCard.data[100]).toBe(0xFF);
75
+ ramCard.write(101, 0x100);
76
+ expect(ramCard.data[101]).toBe(0x00);
77
+ ramCard.write(102, 0x142);
78
+ expect(ramCard.data[102]).toBe(0x42);
79
+ });
80
+ it('should switch banks via bank control register', () => {
81
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 5);
82
+ expect(ramCard.currentBank).toBe(5);
83
+ });
84
+ it('should mask bank number to 0xFF', () => {
85
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 0x1FF);
86
+ expect(ramCard.currentBank).toBe(0xFF);
87
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 0x100);
88
+ expect(ramCard.currentBank).toBe(0x00);
89
+ });
90
+ });
91
+ describe('Bank Switching', () => {
92
+ it('should isolate data between banks', () => {
93
+ // Write to address 50 in bank 0
94
+ ramCard.write(50, 0x11);
95
+ expect(ramCard.read(50)).toBe(0x11);
96
+ // Switch to bank 1
97
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 1);
98
+ expect(ramCard.read(50)).toBe(0x00);
99
+ // Write different value to address 50 in bank 1
100
+ ramCard.write(50, 0x22);
101
+ expect(ramCard.read(50)).toBe(0x22);
102
+ // Switch back to bank 0
103
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 0);
104
+ expect(ramCard.read(50)).toBe(0x11);
105
+ });
106
+ it('should persist data in each bank', () => {
107
+ // Bank 0
108
+ ramCard.write(100, 0xAA);
109
+ ramCard.write(200, 0xBB);
110
+ // Switch to bank 1
111
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 1);
112
+ ramCard.write(100, 0xCC);
113
+ ramCard.write(200, 0xDD);
114
+ // Switch to bank 2
115
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 2);
116
+ ramCard.write(100, 0xEE);
117
+ // Verify data in bank 2
118
+ expect(ramCard.read(100)).toBe(0xEE);
119
+ // Switch to bank 1
120
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 1);
121
+ expect(ramCard.read(100)).toBe(0xCC);
122
+ expect(ramCard.read(200)).toBe(0xDD);
123
+ // Switch to bank 0
124
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 0);
125
+ expect(ramCard.read(100)).toBe(0xAA);
126
+ expect(ramCard.read(200)).toBe(0xBB);
127
+ });
128
+ it('should switch between all 256 banks', () => {
129
+ // Write unique val to each bank at address 0
130
+ for (let bank = 0; bank < RAMCard_1.RAMCard.NUM_BANKS; bank++) {
131
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, bank);
132
+ ramCard.write(0, bank & 0xFF);
133
+ }
134
+ // Verify each bank has correct value
135
+ for (let bank = 0; bank < RAMCard_1.RAMCard.NUM_BANKS; bank++) {
136
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, bank);
137
+ expect(ramCard.read(0)).toBe(bank & 0xFF);
138
+ }
139
+ });
140
+ });
141
+ describe('Reset', () => {
142
+ it('should not reset on warm start', () => {
143
+ ramCard.write(100, 0x42);
144
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 42);
145
+ ramCard.reset(false);
146
+ expect(ramCard.data[100]).toBe(0x42);
147
+ expect(ramCard.currentBank).toBe(42);
148
+ });
149
+ it('should reset all data on cold start', () => {
150
+ ramCard.write(100, 0x42);
151
+ ramCard.write(500, 0xAB);
152
+ ramCard.write(RAMCard_1.RAMCard.TOTAL_SIZE - 1, 0xFF);
153
+ ramCard.reset(true);
154
+ expect(ramCard.data[100]).toBe(0x00);
155
+ expect(ramCard.data[500]).toBe(0x00);
156
+ expect(ramCard.data[RAMCard_1.RAMCard.TOTAL_SIZE - 1]).toBe(0x00);
157
+ });
158
+ it('should reset to bank 0 on cold start', () => {
159
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, 100);
160
+ expect(ramCard.currentBank).toBe(100);
161
+ ramCard.reset(true);
162
+ expect(ramCard.currentBank).toBe(0);
163
+ });
164
+ it('should clear all RAM on cold start', () => {
165
+ // Fill multiple banks with data
166
+ for (let bank = 0; bank < 10; bank++) {
167
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, bank);
168
+ for (let addr = 0; addr < RAMCard_1.RAMCard.BANK_SIZE; addr++) {
169
+ ramCard.write(addr, bank);
170
+ }
171
+ }
172
+ ramCard.reset(true);
173
+ // Verify all data is cleared
174
+ for (let i = 0; i < RAMCard_1.RAMCard.TOTAL_SIZE; i++) {
175
+ expect(ramCard.data[i]).toBe(0x00);
176
+ }
177
+ });
178
+ });
179
+ describe('Tick', () => {
180
+ it('should have tick method that does nothing', () => {
181
+ expect(() => {
182
+ ramCard.tick(1000000);
183
+ }).not.toThrow();
184
+ });
185
+ });
186
+ describe('IO Interface Implementation', () => {
187
+ it('should implement IO interface methods', () => {
188
+ expect(typeof ramCard.read).toBe('function');
189
+ expect(typeof ramCard.write).toBe('function');
190
+ expect(typeof ramCard.tick).toBe('function');
191
+ expect(typeof ramCard.reset).toBe('function');
192
+ });
193
+ it('should have raiseIRQ and raiseNMI callbacks', () => {
194
+ expect(ramCard.raiseIRQ()).toBeUndefined();
195
+ expect(ramCard.raiseNMI()).toBeUndefined();
196
+ });
197
+ });
198
+ describe('Integration', () => {
199
+ it('should allow multiple write/read cycles', () => {
200
+ const testValues = [0x00, 0x42, 0xFF, 0x80, 0x01];
201
+ for (const value of testValues) {
202
+ ramCard.write(250, value);
203
+ expect(ramCard.read(250)).toBe(value);
204
+ }
205
+ });
206
+ it('should handle rapid bank switches', () => {
207
+ for (let i = 0; i < 100; i++) {
208
+ ramCard.write(RAMCard_1.RAMCard.BANK_CONTROL_REGISTER, i % 256);
209
+ ramCard.write(0, i & 0xFF);
210
+ }
211
+ // Check final state (last iteration i=99)
212
+ expect(ramCard.currentBank).toBe(99 % 256);
213
+ expect(ramCard.read(0)).toBe(99 & 0xFF);
214
+ });
215
+ it('should handle boundary addresses correctly', () => {
216
+ // Test address 0
217
+ ramCard.write(0, 0x11);
218
+ expect(ramCard.read(0)).toBe(0x11);
219
+ // Test address 0x3FE
220
+ ramCard.write(0x3FE, 0x22);
221
+ expect(ramCard.read(0x3FE)).toBe(0x22);
222
+ // Test bank control register
223
+ ramCard.write(0x3FF, 5);
224
+ expect(ramCard.currentBank).toBe(5);
225
+ expect(ramCard.read(0x3FF)).toBe(5);
226
+ });
227
+ });
228
+ });
229
+ //# sourceMappingURL=RAMCard.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RAMCard.test.js","sourceRoot":"","sources":["../../../src/tests/IO/RAMCard.test.ts"],"names":[],"mappings":";;AAAA,yDAAqD;AAErD,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;IACvB,IAAI,OAAgB,CAAA;IAEpB,UAAU,CAAC,GAAG,EAAE;QACd,OAAO,GAAG,IAAI,iBAAO,EAAE,CAAA;IACzB,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;QACjC,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,MAAM,CAAC,iBAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAA;QAC7C,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;YACvC,MAAM,CAAC,iBAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;YAC7C,MAAM,CAAC,iBAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;YAC3D,MAAM,CAAC,iBAAO,CAAC,qBAAqB,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACnD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;YACjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC5C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,CAAC;QACH,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;YAChC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,MAAM,CAAC,OAAO,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAChD,MAAM,CAAC,OAAO,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAClD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;QACvB,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;YAC5C,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAA;YACxB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;YACpC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAA;YACtB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACpC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;YAC5D,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;YAC1B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACxC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;YACnE,OAAO,CAAC,WAAW,GAAG,CAAC,CAAA;YACvB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAO,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAE3D,OAAO,CAAC,WAAW,GAAG,EAAE,CAAA;YACxB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAO,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAE5D,OAAO,CAAC,WAAW,GAAG,GAAG,CAAA;YACzB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAO,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC/D,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;QACvB,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YACxB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;YACnC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YACtB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACpC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;YACvC,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;YAC1B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACxC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YAClC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;YACzB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEpC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;YACzB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEpC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;YACzB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;YACvD,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;YACzC,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,KAAK,CAAC,CAAA;YACnD,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEtC,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,KAAK,CAAC,CAAA;YACnD,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACxC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,gCAAgC;YAChC,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,CAAC,CAAA;YACvB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEnC,mBAAmB;YACnB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEnC,gDAAgD;YAChD,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,CAAC,CAAA;YACvB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEnC,wBAAwB;YACxB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;YAC1C,SAAS;YACT,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YACxB,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YAExB,mBAAmB;YACnB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YACxB,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YAExB,mBAAmB;YACnB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YAExB,wBAAwB;YACxB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEpC,mBAAmB;YACnB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEpC,mBAAmB;YACnB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;YAC/C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;YAC7C,6CAA6C;YAC7C,KAAK,IAAI,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,iBAAO,CAAC,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC;gBACpD,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,IAAI,CAAC,CAAA;gBAClD,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC,CAAA;YAC/B,CAAC;YAED,qCAAqC;YACrC,KAAK,IAAI,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,iBAAO,CAAC,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC;gBACpD,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,IAAI,CAAC,CAAA;gBAClD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,CAAA;YAC3C,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;QACrB,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;YACxC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YACxB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,EAAE,CAAC,CAAA;YAEhD,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;YAEpB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;YAC7C,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YACxB,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAA;YACxB,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,UAAU,GAAG,CAAC,EAAE,IAAI,CAAC,CAAA;YAE3C,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YAEnB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAO,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACzD,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC9C,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,GAAG,CAAC,CAAA;YACjD,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YAErC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YAEnB,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;YAC5C,gCAAgC;YAChC,KAAK,IAAI,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,EAAE,EAAE,IAAI,EAAE,EAAE,CAAC;gBACrC,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,IAAI,CAAC,CAAA;gBAClD,KAAK,IAAI,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,iBAAO,CAAC,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC;oBACpD,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;gBAC3B,CAAC;YACH,CAAC;YAED,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YAEnB,6BAA6B;YAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC5C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACpC,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE;QACpB,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;YACnD,MAAM,CAAC,GAAG,EAAE;gBACV,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YACvB,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAA;QAClB,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;QAC3C,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;YAC/C,MAAM,CAAC,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAC5C,MAAM,CAAC,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAC7C,MAAM,CAAC,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAC5C,MAAM,CAAC,OAAO,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAC/C,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;YACrD,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,aAAa,EAAE,CAAA;YAC1C,MAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,aAAa,EAAE,CAAA;QAC5C,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;QAC3B,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;YACjD,MAAM,UAAU,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAA;YAEjD,KAAK,MAAM,KAAK,IAAI,UAAU,EAAE,CAAC;gBAC/B,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;gBACzB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YACvC,CAAC;QACH,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC3C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC7B,OAAO,CAAC,KAAK,CAAC,iBAAO,CAAC,qBAAqB,EAAE,CAAC,GAAG,GAAG,CAAC,CAAA;gBACrD,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAA;YAC5B,CAAC;YAED,0CAA0C;YAC1C,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,CAAA;YAC1C,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,CAAA;QACzC,CAAC,CAAC,CAAA;QAEF,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;YACpD,iBAAiB;YACjB,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;YACtB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAElC,qBAAqB;YACrB,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;YAC1B,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAEtC,6BAA6B;YAC7B,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;YACvB,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACnC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACrC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const RTCCard_1 = require("../../components/IO/RTCCard");
4
+ const bcdToDecimal = (bcd) => (((bcd >> 4) & 0x0f) * 10) + (bcd & 0x0f);
5
+ const enableTransfers = (rtc) => {
6
+ rtc.write(0x0f, 0x80);
7
+ rtc.tick(1);
8
+ };
9
+ const setTime = (rtc, values) => {
10
+ enableTransfers(rtc);
11
+ rtc.write(0x00, values.seconds);
12
+ rtc.write(0x01, values.minutes);
13
+ rtc.write(0x02, values.hours);
14
+ rtc.write(0x03, values.dayOfWeek);
15
+ rtc.write(0x04, values.date);
16
+ rtc.write(0x05, values.month | 0x80);
17
+ rtc.write(0x06, values.year);
18
+ rtc.write(0x07, values.century);
19
+ };
20
+ describe('RTCCard', () => {
21
+ let rtc;
22
+ beforeEach(() => {
23
+ rtc = new RTCCard_1.RTCCard();
24
+ });
25
+ describe('Initialization', () => {
26
+ it('should initialize with valid BCD time and EOSC enabled', () => {
27
+ const seconds = rtc.read(0x00);
28
+ const minutes = rtc.read(0x01);
29
+ const hours = rtc.read(0x02);
30
+ const dayOfWeek = rtc.read(0x03);
31
+ const date = rtc.read(0x04);
32
+ const month = rtc.read(0x05);
33
+ const year = rtc.read(0x06);
34
+ const century = rtc.read(0x07);
35
+ expect(dayOfWeek).toBeGreaterThanOrEqual(1);
36
+ expect(dayOfWeek).toBeLessThanOrEqual(7);
37
+ expect(bcdToDecimal(seconds)).toBeGreaterThanOrEqual(0);
38
+ expect(bcdToDecimal(seconds)).toBeLessThan(60);
39
+ expect(bcdToDecimal(minutes)).toBeGreaterThanOrEqual(0);
40
+ expect(bcdToDecimal(minutes)).toBeLessThan(60);
41
+ expect(bcdToDecimal(hours)).toBeGreaterThanOrEqual(0);
42
+ expect(bcdToDecimal(hours)).toBeLessThan(24);
43
+ expect(bcdToDecimal(date)).toBeGreaterThanOrEqual(1);
44
+ expect(bcdToDecimal(date)).toBeLessThanOrEqual(31);
45
+ expect(bcdToDecimal(month & 0x1f)).toBeGreaterThanOrEqual(1);
46
+ expect(bcdToDecimal(month & 0x1f)).toBeLessThanOrEqual(12);
47
+ expect(bcdToDecimal(year)).toBeGreaterThanOrEqual(0);
48
+ expect(bcdToDecimal(year)).toBeLessThanOrEqual(99);
49
+ expect(bcdToDecimal(century)).toBeGreaterThanOrEqual(0);
50
+ expect(bcdToDecimal(century)).toBeLessThanOrEqual(39);
51
+ expect(month & 0x80).toBe(0x80);
52
+ });
53
+ });
54
+ describe('Registers', () => {
55
+ it('should mask day of week reads to 3 bits', () => {
56
+ rtc.write(0x03, 0xff);
57
+ expect(rtc.read(0x03)).toBe(0x07);
58
+ });
59
+ it('should clear control flags on Control A read', () => {
60
+ rtc.reset(true);
61
+ const first = rtc.read(0x0e);
62
+ const second = rtc.read(0x0e);
63
+ expect(first & 0x04).toBe(0x04);
64
+ expect(second & 0x0f).toBe(0);
65
+ });
66
+ it('should raise IRQ when KSF is set and KIE enabled', () => {
67
+ const mockIRQ = jest.fn();
68
+ rtc.raiseIRQ = mockIRQ;
69
+ rtc.reset(true);
70
+ rtc.write(0x0f, 0x04);
71
+ expect(mockIRQ).toHaveBeenCalledTimes(1);
72
+ const controlA = rtc.read(0x0e);
73
+ expect(controlA & 0x01).toBe(0x01);
74
+ });
75
+ });
76
+ describe('Extended RAM', () => {
77
+ it('should write and read RAM at the address pointer', () => {
78
+ rtc.write(0x10, 0x10);
79
+ rtc.write(0x13, 0x5a);
80
+ rtc.write(0x10, 0x10);
81
+ expect(rtc.read(0x13)).toBe(0x5a);
82
+ });
83
+ it('should auto-increment RAM address when enabled', () => {
84
+ rtc.write(0x0f, 0x20);
85
+ rtc.write(0x10, 0x10);
86
+ rtc.write(0x13, 0x11);
87
+ rtc.write(0x13, 0x22);
88
+ expect(rtc.read(0x10)).toBe(0x12);
89
+ rtc.write(0x10, 0x10);
90
+ expect(rtc.read(0x13)).toBe(0x11);
91
+ expect(rtc.read(0x13)).toBe(0x22);
92
+ expect(rtc.read(0x10)).toBe(0x12);
93
+ });
94
+ });
95
+ describe('Timekeeping', () => {
96
+ it('should advance time when TE is enabled', () => {
97
+ setTime(rtc, {
98
+ seconds: 0x00,
99
+ minutes: 0x00,
100
+ hours: 0x00,
101
+ dayOfWeek: 0x01,
102
+ date: 0x01,
103
+ month: 0x01,
104
+ year: 0x00,
105
+ century: 0x20
106
+ });
107
+ rtc.tick(1);
108
+ expect(rtc.read(0x00)).toBe(0x01);
109
+ });
110
+ it('should stop time when oscillator is disabled', () => {
111
+ setTime(rtc, {
112
+ seconds: 0x10,
113
+ minutes: 0x00,
114
+ hours: 0x00,
115
+ dayOfWeek: 0x01,
116
+ date: 0x01,
117
+ month: 0x01,
118
+ year: 0x00,
119
+ century: 0x20
120
+ });
121
+ rtc.write(0x05, 0x01);
122
+ rtc.tick(1);
123
+ expect(rtc.read(0x00)).toBe(0x10);
124
+ });
125
+ });
126
+ describe('Alarm', () => {
127
+ it('should set TDF and raise IRQ when alarm matches', () => {
128
+ const mockIRQ = jest.fn();
129
+ rtc.raiseIRQ = mockIRQ;
130
+ setTime(rtc, {
131
+ seconds: 0x00,
132
+ minutes: 0x00,
133
+ hours: 0x00,
134
+ dayOfWeek: 0x01,
135
+ date: 0x01,
136
+ month: 0x01,
137
+ year: 0x00,
138
+ century: 0x20
139
+ });
140
+ rtc.write(0x08, 0x01);
141
+ rtc.write(0x09, 0x00);
142
+ rtc.write(0x0a, 0x00);
143
+ rtc.write(0x0b, 0x01);
144
+ rtc.write(0x0f, 0x88);
145
+ rtc.tick(1);
146
+ expect(mockIRQ).toHaveBeenCalledTimes(1);
147
+ const controlA = rtc.read(0x0e);
148
+ expect(controlA & 0x08).toBe(0x08);
149
+ expect(controlA & 0x01).toBe(0x01);
150
+ });
151
+ });
152
+ describe('Watchdog', () => {
153
+ it('should raise IRQ when watchdog expires with WDS=0', () => {
154
+ const mockIRQ = jest.fn();
155
+ rtc.raiseIRQ = mockIRQ;
156
+ rtc.write(0x0f, 0x02);
157
+ rtc.write(0x0c, 0x01);
158
+ rtc.write(0x0d, 0x00);
159
+ rtc.tick(1);
160
+ expect(mockIRQ).toHaveBeenCalledTimes(1);
161
+ const controlA = rtc.read(0x0e);
162
+ expect(controlA & 0x02).toBe(0x02);
163
+ expect(controlA & 0x01).toBe(0x01);
164
+ });
165
+ it('should raise NMI and clear WDE when WDS=1', () => {
166
+ const mockNMI = jest.fn();
167
+ rtc.raiseNMI = mockNMI;
168
+ rtc.write(0x0f, 0x03);
169
+ rtc.write(0x0c, 0x01);
170
+ rtc.write(0x0d, 0x00);
171
+ rtc.tick(1);
172
+ expect(mockNMI).toHaveBeenCalledTimes(1);
173
+ expect(rtc.read(0x0f) & 0x02).toBe(0);
174
+ });
175
+ });
176
+ });
177
+ //# sourceMappingURL=RTCCard.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RTCCard.test.js","sourceRoot":"","sources":["../../../src/tests/IO/RTCCard.test.ts"],"names":[],"mappings":"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"}