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,503 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const GPIOCard_1 = require("../../components/IO/GPIOCard");
4
+ /**
5
+ * Helper function to create a mock GPIO attachment
6
+ */
7
+ const createMockAttachment = (options = {}) => {
8
+ const { priority = 0, enabled = true, portAValue = 0xFF, portBValue = 0xFF, ca1Interrupt = false, ca2Interrupt = false, cb1Interrupt = false, cb2Interrupt = false, } = options;
9
+ let currentPortAValue = portAValue;
10
+ let currentPortBValue = portBValue;
11
+ return {
12
+ reset: jest.fn(),
13
+ tick: jest.fn(),
14
+ readPortA: jest.fn(() => currentPortAValue),
15
+ readPortB: jest.fn(() => currentPortBValue),
16
+ writePortA: jest.fn(),
17
+ writePortB: jest.fn(),
18
+ isEnabled: jest.fn(() => enabled),
19
+ getPriority: jest.fn(() => priority),
20
+ clearInterrupts: jest.fn(),
21
+ updateControlLines: jest.fn(),
22
+ hasCA1Interrupt: jest.fn(() => ca1Interrupt),
23
+ hasCA2Interrupt: jest.fn(() => ca2Interrupt),
24
+ hasCB1Interrupt: jest.fn(() => cb1Interrupt),
25
+ hasCB2Interrupt: jest.fn(() => cb2Interrupt),
26
+ // Helper method to update values (not part of interface)
27
+ setPortAValue: (value) => { currentPortAValue = value; },
28
+ setPortBValue: (value) => { currentPortBValue = value; },
29
+ };
30
+ };
31
+ describe('GPIOCard (65C22 VIA)', () => {
32
+ let gpio;
33
+ beforeEach(() => {
34
+ gpio = new GPIOCard_1.GPIOCard();
35
+ });
36
+ describe('Initialization', () => {
37
+ it('should initialize with all registers reset', () => {
38
+ expect(gpio.read(0x00)).toBe(0xFF); // ORB - all inputs default to 1
39
+ expect(gpio.read(0x01)).toBe(0xFF); // ORA - all inputs default to 1
40
+ expect(gpio.read(0x02)).toBe(0x00); // DDRB - all inputs
41
+ expect(gpio.read(0x03)).toBe(0x00); // DDRA - all inputs
42
+ expect(gpio.read(0x0A)).toBe(0x00); // SR
43
+ expect(gpio.read(0x0B)).toBe(0x00); // ACR
44
+ expect(gpio.read(0x0C)).toBe(0x00); // PCR
45
+ expect(gpio.read(0x0D)).toBe(0x00); // IFR
46
+ expect(gpio.read(0x0E)).toBe(0x80); // IER - bit 7 always reads as 1
47
+ });
48
+ it('should initialize timers to max values', () => {
49
+ const t1cl = gpio.read(0x04);
50
+ const t1ch = gpio.read(0x05);
51
+ expect(t1cl).toBe(0xFF);
52
+ expect(t1ch).toBe(0xFF);
53
+ });
54
+ });
55
+ describe('Reset', () => {
56
+ it('should reset all registers to default state', () => {
57
+ gpio.write(0x00, 0x55);
58
+ gpio.write(0x02, 0xFF);
59
+ gpio.write(0x0B, 0xFF);
60
+ gpio.reset(true);
61
+ expect(gpio.read(0x00)).toBe(0xFF);
62
+ expect(gpio.read(0x02)).toBe(0x00);
63
+ expect(gpio.read(0x0B)).toBe(0x00);
64
+ });
65
+ });
66
+ describe('Data Direction Registers', () => {
67
+ it('should write and read DDRB', () => {
68
+ gpio.write(0x02, 0xAA);
69
+ expect(gpio.read(0x02)).toBe(0xAA);
70
+ });
71
+ it('should write and read DDRA', () => {
72
+ gpio.write(0x03, 0x55);
73
+ expect(gpio.read(0x03)).toBe(0x55);
74
+ });
75
+ it('should affect port reading behavior', () => {
76
+ // Set DDRA bits 0-3 as outputs, 4-7 as inputs
77
+ gpio.write(0x03, 0x0F);
78
+ gpio.write(0x01, 0x5A); // Write to ORA
79
+ const value = gpio.read(0x01);
80
+ // Bits 0-3 should read as 0xA (from ORA), bits 4-7 as 0xF (inputs default to 1)
81
+ expect(value & 0x0F).toBe(0x0A);
82
+ expect(value & 0xF0).toBe(0xF0);
83
+ });
84
+ });
85
+ describe('Output Registers', () => {
86
+ it('should write and read ORB', () => {
87
+ gpio.write(0x02, 0xFF); // Set all as outputs
88
+ gpio.write(0x00, 0x42);
89
+ expect(gpio.read(0x00)).toBe(0x42);
90
+ });
91
+ it('should write and read ORA', () => {
92
+ gpio.write(0x03, 0xFF); // Set all as outputs
93
+ gpio.write(0x01, 0x24);
94
+ expect(gpio.read(0x01)).toBe(0x24);
95
+ });
96
+ it('should write and read ORA without handshake', () => {
97
+ gpio.write(0x03, 0xFF); // Set all as outputs
98
+ gpio.write(0x0F, 0x88); // Write to ORA_NH
99
+ expect(gpio.read(0x0F)).toBe(0x88);
100
+ });
101
+ });
102
+ describe('Timer 1', () => {
103
+ it('should write to T1 low latch via T1CL', () => {
104
+ gpio.write(0x04, 0x34);
105
+ gpio.write(0x05, 0x12); // T1CH starts timer
106
+ expect(gpio.read(0x06)).toBe(0x34); // Read T1LL
107
+ });
108
+ it('should write to T1 high latch via T1LH', () => {
109
+ gpio.write(0x07, 0x56);
110
+ expect(gpio.read(0x07)).toBe(0x56);
111
+ });
112
+ it('should load latch into counter when writing T1CH', () => {
113
+ gpio.write(0x04, 0x10); // T1CL
114
+ gpio.write(0x05, 0x00); // T1CH - loads counter and starts
115
+ const low = gpio.read(0x04);
116
+ const high = gpio.read(0x05);
117
+ expect(low).toBe(0x10);
118
+ expect(high).toBe(0x00);
119
+ });
120
+ it('should countdown Timer 1', () => {
121
+ gpio.write(0x04, 0x05); // Low = 5
122
+ gpio.write(0x05, 0x00); // High = 0, starts timer
123
+ // Tick 5 times
124
+ for (let i = 0; i < 5; i++) {
125
+ gpio.tick(1000000);
126
+ }
127
+ expect(gpio.read(0x04)).toBe(0x00);
128
+ });
129
+ it('should set T1 interrupt flag when counter reaches zero', () => {
130
+ gpio.write(0x04, 0x02);
131
+ gpio.write(0x05, 0x00);
132
+ gpio.tick(1000000);
133
+ gpio.tick(1000000);
134
+ gpio.tick(1000000); // Counter reaches 0
135
+ const ifr = gpio.read(0x0D);
136
+ expect(ifr & 0x40).toBe(0x40); // T1 interrupt flag
137
+ });
138
+ it('should clear T1 interrupt flag when reading T1CL', () => {
139
+ gpio.write(0x04, 0x01);
140
+ gpio.write(0x05, 0x00);
141
+ gpio.tick(1000000);
142
+ gpio.tick(1000000);
143
+ gpio.read(0x04); // Clear flag by reading T1CL
144
+ const ifr = gpio.read(0x0D);
145
+ expect(ifr & 0x40).toBe(0x00);
146
+ });
147
+ it('should stop in one-shot mode after timeout', () => {
148
+ gpio.write(0x04, 0x02);
149
+ gpio.write(0x05, 0x00);
150
+ // Countdown to 0
151
+ gpio.tick(1000000);
152
+ gpio.tick(1000000);
153
+ gpio.tick(1000000);
154
+ // Additional ticks shouldn't change counter
155
+ gpio.tick(1000000);
156
+ expect(gpio.read(0x04)).toBe(0x00);
157
+ });
158
+ it('should reload in free-run mode (ACR bit 6 set)', () => {
159
+ gpio.write(0x0B, 0x40); // ACR - enable free-run mode
160
+ gpio.write(0x04, 0x04); // Latch = 4
161
+ gpio.write(0x05, 0x00);
162
+ // Tick sequence: 4->3, 3->2, 2->1, 1->0 (triggers reload to 4), 4->3, 3->2
163
+ for (let i = 0; i < 6; i++) {
164
+ gpio.tick(1000000);
165
+ }
166
+ // After 6 ticks in free-run mode, should be at 2
167
+ expect(gpio.read(0x04)).toBe(0x02);
168
+ });
169
+ it('should toggle PB7 when ACR bit 7 is set', () => {
170
+ gpio.write(0x02, 0xFF); // DDRB all outputs
171
+ gpio.write(0x00, 0x00); // ORB = 0
172
+ gpio.write(0x0B, 0x80); // ACR - enable PB7 toggle
173
+ gpio.write(0x04, 0x01);
174
+ gpio.write(0x05, 0x00);
175
+ gpio.tick(1000000);
176
+ gpio.tick(1000000);
177
+ const orb = gpio.read(0x00);
178
+ expect(orb & 0x80).toBe(0x80); // PB7 should be toggled
179
+ });
180
+ });
181
+ describe('Timer 2', () => {
182
+ it('should write to T2 low latch', () => {
183
+ gpio.write(0x08, 0x42);
184
+ gpio.write(0x09, 0x00); // Start timer
185
+ expect(gpio.read(0x08)).toBe(0x42);
186
+ });
187
+ it('should countdown Timer 2', () => {
188
+ gpio.write(0x08, 0x05);
189
+ gpio.write(0x09, 0x00);
190
+ for (let i = 0; i < 5; i++) {
191
+ gpio.tick(1000000);
192
+ }
193
+ expect(gpio.read(0x08)).toBe(0x00);
194
+ });
195
+ it('should set T2 interrupt flag when counter reaches zero', () => {
196
+ gpio.write(0x08, 0x02);
197
+ gpio.write(0x09, 0x00);
198
+ gpio.tick(1000000);
199
+ gpio.tick(1000000);
200
+ gpio.tick(1000000);
201
+ const ifr = gpio.read(0x0D);
202
+ expect(ifr & 0x20).toBe(0x20); // T2 interrupt flag
203
+ });
204
+ it('should clear T2 interrupt flag when reading T2CL', () => {
205
+ gpio.write(0x08, 0x01);
206
+ gpio.write(0x09, 0x00);
207
+ gpio.tick(1000000);
208
+ gpio.tick(1000000);
209
+ gpio.read(0x08); // Clear flag
210
+ const ifr = gpio.read(0x0D);
211
+ expect(ifr & 0x20).toBe(0x00);
212
+ });
213
+ it('should stop after timeout (one-shot mode)', () => {
214
+ gpio.write(0x08, 0x02);
215
+ gpio.write(0x09, 0x00);
216
+ for (let i = 0; i < 4; i++) {
217
+ gpio.tick(1000000);
218
+ }
219
+ // Should stay at 0
220
+ expect(gpio.read(0x08)).toBe(0x00);
221
+ });
222
+ });
223
+ describe('Shift Register', () => {
224
+ it('should write and read shift register', () => {
225
+ gpio.write(0x0A, 0xA5);
226
+ expect(gpio.read(0x0A)).toBe(0xA5);
227
+ });
228
+ it('should clear SR interrupt flag when writing to SR', () => {
229
+ // Manually set SR interrupt flag
230
+ gpio.write(0x0E, 0x84); // Enable SR interrupt
231
+ gpio.write(0x0D, 0x04); // Won't actually set, but let's test the read behavior
232
+ gpio.write(0x0A, 0x00); // Writing SR should clear flag
233
+ const ifr = gpio.read(0x0D);
234
+ expect(ifr & 0x04).toBe(0x00);
235
+ });
236
+ it('should clear SR interrupt flag when reading SR', () => {
237
+ gpio.write(0x0A, 0xFF);
238
+ gpio.read(0x0A); // Should clear flag
239
+ const ifr = gpio.read(0x0D);
240
+ expect(ifr & 0x04).toBe(0x00);
241
+ });
242
+ });
243
+ describe('Interrupt Flag Register (IFR)', () => {
244
+ it('should read IFR with bit 7 always 0 when no interrupts', () => {
245
+ const ifr = gpio.read(0x0D);
246
+ expect(ifr & 0x80).toBe(0x00);
247
+ });
248
+ it('should set bit 7 when any enabled interrupt is active', () => {
249
+ gpio.write(0x0E, 0xC0); // Enable T1 interrupt (IER)
250
+ gpio.write(0x04, 0x01);
251
+ gpio.write(0x05, 0x00);
252
+ gpio.tick(1000000);
253
+ gpio.tick(1000000);
254
+ const ifr = gpio.read(0x0D);
255
+ expect(ifr & 0x80).toBe(0x80); // Bit 7 set
256
+ });
257
+ it('should clear specific interrupt flags when writing to IFR', () => {
258
+ gpio.write(0x0E, 0xC0); // Enable T1
259
+ gpio.write(0x04, 0x01);
260
+ gpio.write(0x05, 0x00);
261
+ gpio.tick(1000000);
262
+ gpio.tick(1000000);
263
+ gpio.write(0x0D, 0x40); // Clear T1 flag
264
+ const ifr = gpio.read(0x0D);
265
+ expect(ifr & 0x40).toBe(0x00);
266
+ });
267
+ });
268
+ describe('Interrupt Enable Register (IER)', () => {
269
+ it('should read IER with bit 7 always set', () => {
270
+ gpio.write(0x0E, 0x00);
271
+ const ier = gpio.read(0x0E);
272
+ expect(ier & 0x80).toBe(0x80);
273
+ });
274
+ it('should set interrupt enable bits when bit 7 is 1', () => {
275
+ gpio.write(0x0E, 0xC0); // Set T1 interrupt enable
276
+ const ier = gpio.read(0x0E);
277
+ expect(ier & 0x40).toBe(0x40);
278
+ });
279
+ it('should clear interrupt enable bits when bit 7 is 0', () => {
280
+ gpio.write(0x0E, 0xC0); // Set T1
281
+ gpio.write(0x0E, 0x40); // Clear T1 (bit 7 = 0)
282
+ const ier = gpio.read(0x0E);
283
+ expect(ier & 0x40).toBe(0x00);
284
+ });
285
+ it('should enable multiple interrupts', () => {
286
+ gpio.write(0x0E, 0xFF); // Enable all
287
+ const ier = gpio.read(0x0E);
288
+ expect(ier & 0x7F).toBe(0x7F);
289
+ });
290
+ });
291
+ describe('IRQ Generation', () => {
292
+ it('should call raiseIRQ when enabled interrupt is triggered', () => {
293
+ const mockIRQ = jest.fn();
294
+ gpio.raiseIRQ = mockIRQ;
295
+ gpio.write(0x0E, 0xC0); // Enable T1 interrupt
296
+ gpio.write(0x04, 0x01);
297
+ gpio.write(0x05, 0x00);
298
+ gpio.tick(1000000);
299
+ gpio.tick(1000000);
300
+ expect(mockIRQ).toHaveBeenCalled();
301
+ });
302
+ it('should not call raiseIRQ when interrupt is not enabled', () => {
303
+ const mockIRQ = jest.fn();
304
+ gpio.raiseIRQ = mockIRQ;
305
+ gpio.write(0x04, 0x01);
306
+ gpio.write(0x05, 0x00);
307
+ gpio.tick(1000000);
308
+ gpio.tick(1000000);
309
+ expect(mockIRQ).not.toHaveBeenCalled();
310
+ });
311
+ });
312
+ describe('Auxiliary Control Register (ACR)', () => {
313
+ it('should write and read ACR', () => {
314
+ gpio.write(0x0B, 0x55);
315
+ expect(gpio.read(0x0B)).toBe(0x55);
316
+ });
317
+ it('should control Timer 1 free-run mode (bit 6)', () => {
318
+ gpio.write(0x0B, 0x00); // One-shot
319
+ gpio.write(0x04, 0x02);
320
+ gpio.write(0x05, 0x00);
321
+ for (let i = 0; i < 4; i++) {
322
+ gpio.tick(1000000);
323
+ }
324
+ const t1 = gpio.read(0x04);
325
+ expect(t1).toBe(0x00); // Should stay at 0
326
+ });
327
+ it('should control PB7 output (bit 7)', () => {
328
+ gpio.write(0x02, 0xFF); // Set all Port B as outputs
329
+ gpio.write(0x00, 0x00); // Set ORB to 0
330
+ gpio.write(0x0B, 0xC0); // Free-run + PB7 toggle enabled
331
+ gpio.write(0x04, 0x02); // Latch = 2
332
+ gpio.write(0x05, 0x00);
333
+ const before = gpio.read(0x00) & 0x80; // Should be 0
334
+ // Tick until timer expires (3 ticks: 2, 1, 0)
335
+ gpio.tick(1000000);
336
+ gpio.tick(1000000);
337
+ gpio.tick(1000000);
338
+ const after = gpio.read(0x00) & 0x80; // Should be toggled (0x80)
339
+ expect(before).toBe(0x00);
340
+ expect(after).toBe(0x80);
341
+ });
342
+ });
343
+ describe('Peripheral Control Register (PCR)', () => {
344
+ it('should write and read PCR', () => {
345
+ gpio.write(0x0C, 0xAA);
346
+ expect(gpio.read(0x0C)).toBe(0xAA);
347
+ });
348
+ it('should update control lines when PCR is written', () => {
349
+ // This is hard to test without access to private fields,
350
+ // but we can verify the write doesn't crash
351
+ gpio.write(0x0C, 0xEE); // CA2 and CB2 manual outputs high
352
+ expect(gpio.read(0x0C)).toBe(0xEE);
353
+ });
354
+ });
355
+ describe('Port A/B Interrupt Clearing', () => {
356
+ it('should clear CA1/CA2 interrupts when reading ORA', () => {
357
+ // Manually would need attachment to trigger, but reading should clear
358
+ gpio.read(0x01);
359
+ const ifr = gpio.read(0x0D);
360
+ expect(ifr & 0x03).toBe(0x00);
361
+ });
362
+ it('should clear CA1/CA2 interrupts when writing ORA', () => {
363
+ gpio.write(0x01, 0x00);
364
+ const ifr = gpio.read(0x0D);
365
+ expect(ifr & 0x03).toBe(0x00);
366
+ });
367
+ it('should clear CB1/CB2 interrupts when reading ORB', () => {
368
+ gpio.read(0x00);
369
+ const ifr = gpio.read(0x0D);
370
+ expect(ifr & 0x18).toBe(0x00);
371
+ });
372
+ it('should clear CB1/CB2 interrupts when writing ORB', () => {
373
+ gpio.write(0x00, 0x00);
374
+ const ifr = gpio.read(0x0D);
375
+ expect(ifr & 0x18).toBe(0x00);
376
+ });
377
+ it('should NOT clear interrupts when using no-handshake register', () => {
378
+ // This test verifies that ORA_NH doesn't clear flags
379
+ // Since we can't easily set the flags without attachments, we just verify it works
380
+ gpio.write(0x0F, 0x42);
381
+ expect(gpio.read(0x0F)).toBe(0xFF); // All inputs
382
+ });
383
+ });
384
+ describe('GPIO Attachments', () => {
385
+ it('should attach a device to Port A', () => {
386
+ const mockAttachment = createMockAttachment({ priority: 0 });
387
+ gpio.attachToPortA(mockAttachment);
388
+ expect(gpio.getPortAAttachment(0)).toBe(mockAttachment);
389
+ });
390
+ it('should attach a device to Port B', () => {
391
+ const mockAttachment = createMockAttachment({ priority: 0 });
392
+ gpio.attachToPortB(mockAttachment);
393
+ expect(gpio.getPortBAttachment(0)).toBe(mockAttachment);
394
+ });
395
+ it('should read input from attached device on Port A', () => {
396
+ const mockAttachment = createMockAttachment({ portAValue: 0x00 });
397
+ gpio.attachToPortA(mockAttachment);
398
+ const value = gpio.read(0x01);
399
+ expect(value).toBe(0x00);
400
+ });
401
+ it('should read input from attached device on Port B', () => {
402
+ const mockAttachment = createMockAttachment({ portBValue: 0xAA });
403
+ gpio.attachToPortB(mockAttachment);
404
+ const value = gpio.read(0x00);
405
+ expect(value).toBe(0xAA);
406
+ });
407
+ it('should sort attachments by priority', () => {
408
+ var _a, _b, _c;
409
+ const attachment1 = createMockAttachment({ priority: 5 });
410
+ const attachment2 = createMockAttachment({ priority: 2 });
411
+ const attachment3 = createMockAttachment({ priority: 8 });
412
+ gpio.attachToPortA(attachment1);
413
+ gpio.attachToPortA(attachment2);
414
+ gpio.attachToPortA(attachment3);
415
+ expect((_a = gpio.getPortAAttachment(0)) === null || _a === void 0 ? void 0 : _a.getPriority()).toBe(2); // Highest priority (lowest number)
416
+ expect((_b = gpio.getPortAAttachment(1)) === null || _b === void 0 ? void 0 : _b.getPriority()).toBe(5);
417
+ expect((_c = gpio.getPortAAttachment(2)) === null || _c === void 0 ? void 0 : _c.getPriority()).toBe(8);
418
+ });
419
+ it('should notify attachments when control lines change', () => {
420
+ const mockAttachment = createMockAttachment();
421
+ gpio.attachToPortA(mockAttachment);
422
+ expect(mockAttachment.updateControlLines).toHaveBeenCalled(); // Called during attach
423
+ });
424
+ it('should tick all attachments', () => {
425
+ const mockAttachment = createMockAttachment();
426
+ gpio.attachToPortA(mockAttachment);
427
+ gpio.tick(1000000);
428
+ expect(mockAttachment.tick).toHaveBeenCalledWith(1000000);
429
+ });
430
+ it('should check attachment interrupts and set IFR flags', () => {
431
+ const mockAttachment = createMockAttachment({ ca1Interrupt: true });
432
+ gpio.attachToPortA(mockAttachment);
433
+ gpio.tick(1000000);
434
+ const ifr = gpio.read(0x0D);
435
+ expect(ifr & 0x02).toBe(0x02); // CA1 interrupt flag
436
+ });
437
+ it('should return null for invalid attachment index', () => {
438
+ expect(gpio.getPortAAttachment(0)).toBeNull();
439
+ expect(gpio.getPortBAttachment(10)).toBeNull();
440
+ });
441
+ it('should handle multiple attachments reading from same port', () => {
442
+ const attachment1 = createMockAttachment({ priority: 0, portAValue: 0x0F });
443
+ const attachment2 = createMockAttachment({ priority: 1, portAValue: 0xF0 });
444
+ gpio.attachToPortA(attachment1);
445
+ gpio.attachToPortA(attachment2);
446
+ const value = gpio.read(0x01);
447
+ // Values are ANDed together: 0x0F & 0xF0 = 0x00
448
+ expect(value).toBe(0x00);
449
+ });
450
+ });
451
+ describe('Port Direction Behavior', () => {
452
+ it('should read outputs from OR when DDR bit is 1', () => {
453
+ gpio.write(0x03, 0xFF); // All outputs
454
+ gpio.write(0x01, 0xA5);
455
+ expect(gpio.read(0x01)).toBe(0xA5);
456
+ });
457
+ it('should read external input when DDR bit is 0', () => {
458
+ const mockAttachment = createMockAttachment({ portAValue: 0xFF });
459
+ gpio.attachToPortA(mockAttachment);
460
+ gpio.write(0x03, 0x00); // All inputs
461
+ expect(gpio.read(0x01)).toBe(0xFF); // All high
462
+ });
463
+ it('should mix input and output based on DDR', () => {
464
+ const mockAttachment = createMockAttachment({ portAValue: 0x00 });
465
+ gpio.attachToPortA(mockAttachment);
466
+ gpio.write(0x03, 0x0F); // Lower 4 bits output, upper 4 input
467
+ gpio.write(0x01, 0x55);
468
+ const value = gpio.read(0x01);
469
+ // Lower 4 bits from ORA: 0x05
470
+ // Upper 4 bits from attachment: 0x00
471
+ expect(value & 0x0F).toBe(0x05);
472
+ expect(value & 0xF0).toBe(0x00);
473
+ });
474
+ });
475
+ describe('Edge Cases', () => {
476
+ it('should mask register addresses to 4 bits', () => {
477
+ gpio.write(0x03, 0xFF);
478
+ gpio.write(0x11, 0x42); // 0x11 & 0x0F = 0x01 (ORA)
479
+ expect(gpio.read(0x11)).toBe(0x42);
480
+ });
481
+ it('should mask data values to 8 bits', () => {
482
+ gpio.write(0x03, 0xFF);
483
+ gpio.write(0x01, 0x1FF);
484
+ expect(gpio.read(0x01)).toBe(0xFF);
485
+ });
486
+ it('should handle timer countdown to exactly zero', () => {
487
+ // Timer starts at 1, counts down to 0 and triggers interrupt
488
+ gpio.write(0x04, 0x01);
489
+ gpio.write(0x05, 0x00);
490
+ gpio.tick(1000000); // 1 -> 0
491
+ gpio.tick(1000000); // Reaches 0, interrupt triggered
492
+ const ifr = gpio.read(0x0D);
493
+ expect(ifr & 0x40).toBe(0x40);
494
+ });
495
+ it('should not countdown timers when not running', () => {
496
+ const t1Before = gpio.read(0x04);
497
+ gpio.tick(1000000);
498
+ const t1After = gpio.read(0x04);
499
+ expect(t1Before).toBe(t1After);
500
+ });
501
+ });
502
+ });
503
+ //# sourceMappingURL=GPIOCard.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GPIOCard.test.js","sourceRoot":"","sources":["../../../src/tests/IO/GPIOCard.test.ts"],"names":[],"mappings":"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"}