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.
- package/LICENSE +21 -0
- package/README.md +261 -0
- package/dist/components/CPU.js +1170 -0
- package/dist/components/CPU.js.map +1 -0
- package/dist/components/Cart.js +23 -0
- package/dist/components/Cart.js.map +1 -0
- package/dist/components/IO/Empty.js +19 -0
- package/dist/components/IO/Empty.js.map +1 -0
- package/dist/components/IO/GPIOAttachments/GPIOAttachment.js +71 -0
- package/dist/components/IO/GPIOAttachments/GPIOAttachment.js.map +1 -0
- package/dist/components/IO/GPIOAttachments/GPIOJoystickAttachment.js +90 -0
- package/dist/components/IO/GPIOAttachments/GPIOJoystickAttachment.js.map +1 -0
- package/dist/components/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.js +489 -0
- package/dist/components/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.js.map +1 -0
- package/dist/components/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.js +274 -0
- package/dist/components/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.js.map +1 -0
- package/dist/components/IO/GPIOCard.js +597 -0
- package/dist/components/IO/GPIOCard.js.map +1 -0
- package/dist/components/IO/InputBoard.js +19 -0
- package/dist/components/IO/InputBoard.js.map +1 -0
- package/dist/components/IO/LCDCard.js +19 -0
- package/dist/components/IO/LCDCard.js.map +1 -0
- package/dist/components/IO/RAMCard.js +63 -0
- package/dist/components/IO/RAMCard.js.map +1 -0
- package/dist/components/IO/RTCCard.js +483 -0
- package/dist/components/IO/RTCCard.js.map +1 -0
- package/dist/components/IO/SerialCard.js +282 -0
- package/dist/components/IO/SerialCard.js.map +1 -0
- package/dist/components/IO/SoundCard.js +620 -0
- package/dist/components/IO/SoundCard.js.map +1 -0
- package/dist/components/IO/StorageCard.js +428 -0
- package/dist/components/IO/StorageCard.js.map +1 -0
- package/dist/components/IO/VGACard.js +9 -0
- package/dist/components/IO/VGACard.js.map +1 -0
- package/dist/components/IO/VideoCard.js +623 -0
- package/dist/components/IO/VideoCard.js.map +1 -0
- package/dist/components/IO.js +3 -0
- package/dist/components/IO.js.map +1 -0
- package/dist/components/Machine.js +310 -0
- package/dist/components/Machine.js.map +1 -0
- package/dist/components/RAM.js +24 -0
- package/dist/components/RAM.js.map +1 -0
- package/dist/components/ROM.js +23 -0
- package/dist/components/ROM.js.map +1 -0
- package/dist/index.js +441 -0
- package/dist/index.js.map +1 -0
- package/dist/tests/CPU.test.js +1626 -0
- package/dist/tests/CPU.test.js.map +1 -0
- package/dist/tests/Cart.test.js +119 -0
- package/dist/tests/Cart.test.js.map +1 -0
- package/dist/tests/IO/GPIOAttachments/GPIOAttachment.test.js +339 -0
- package/dist/tests/IO/GPIOAttachments/GPIOAttachment.test.js.map +1 -0
- package/dist/tests/IO/GPIOAttachments/GPIOJoystickAttachment.test.js +126 -0
- package/dist/tests/IO/GPIOAttachments/GPIOJoystickAttachment.test.js.map +1 -0
- package/dist/tests/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.test.js +779 -0
- package/dist/tests/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.test.js.map +1 -0
- package/dist/tests/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.test.js +355 -0
- package/dist/tests/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.test.js.map +1 -0
- package/dist/tests/IO/GPIOCard.test.js +503 -0
- package/dist/tests/IO/GPIOCard.test.js.map +1 -0
- package/dist/tests/IO/RAMCard.test.js +229 -0
- package/dist/tests/IO/RAMCard.test.js.map +1 -0
- package/dist/tests/IO/RTCCard.test.js +177 -0
- package/dist/tests/IO/RTCCard.test.js.map +1 -0
- package/dist/tests/IO/SerialCard.test.js +423 -0
- package/dist/tests/IO/SerialCard.test.js.map +1 -0
- package/dist/tests/IO/SoundCard.test.js +528 -0
- package/dist/tests/IO/SoundCard.test.js.map +1 -0
- package/dist/tests/IO/StorageCard.test.js +647 -0
- package/dist/tests/IO/StorageCard.test.js.map +1 -0
- package/dist/tests/IO/VideoCard.test.js +549 -0
- package/dist/tests/IO/VideoCard.test.js.map +1 -0
- package/dist/tests/Machine.test.js +383 -0
- package/dist/tests/Machine.test.js.map +1 -0
- package/dist/tests/RAM.test.js +160 -0
- package/dist/tests/RAM.test.js.map +1 -0
- package/dist/tests/ROM.test.js +123 -0
- package/dist/tests/ROM.test.js.map +1 -0
- package/jest.config.cjs +9 -0
- package/package.json +43 -0
- package/src/components/CPU.ts +1371 -0
- package/src/components/Cart.ts +20 -0
- package/src/components/IO/GPIOAttachments/GPIOAttachment.ts +189 -0
- package/src/components/IO/GPIOAttachments/GPIOJoystickAttachment.ts +99 -0
- package/src/components/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.ts +465 -0
- package/src/components/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.ts +287 -0
- package/src/components/IO/GPIOCard.ts +677 -0
- package/src/components/IO/RAMCard.ts +68 -0
- package/src/components/IO/RTCCard.ts +518 -0
- package/src/components/IO/SerialCard.ts +335 -0
- package/src/components/IO/SoundCard.ts +711 -0
- package/src/components/IO/StorageCard.ts +473 -0
- package/src/components/IO/VideoCard.ts +730 -0
- package/src/components/IO.ts +11 -0
- package/src/components/Machine.ts +364 -0
- package/src/components/RAM.ts +23 -0
- package/src/components/ROM.ts +19 -0
- package/src/index.ts +474 -0
- package/src/tests/CPU.test.ts +2045 -0
- package/src/tests/Cart.test.ts +149 -0
- package/src/tests/IO/GPIOAttachments/GPIOAttachment.test.ts +413 -0
- package/src/tests/IO/GPIOAttachments/GPIOJoystickAttachment.test.ts +147 -0
- package/src/tests/IO/GPIOAttachments/GPIOKeyboardEncoderAttachment.test.ts +961 -0
- package/src/tests/IO/GPIOAttachments/GPIOKeyboardMatrixAttachment.test.ts +449 -0
- package/src/tests/IO/GPIOCard.test.ts +644 -0
- package/src/tests/IO/RAMCard.test.ts +284 -0
- package/src/tests/IO/RTCCard.test.ts +222 -0
- package/src/tests/IO/SerialCard.test.ts +530 -0
- package/src/tests/IO/SoundCard.test.ts +659 -0
- package/src/tests/IO/StorageCard.test.ts +787 -0
- package/src/tests/IO/VideoCard.test.ts +668 -0
- package/src/tests/Machine.test.ts +437 -0
- package/src/tests/RAM.test.ts +196 -0
- package/src/tests/ROM.test.ts +154 -0
- 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":"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"}
|
|
@@ -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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"}
|