-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathKNOWN_BUGS
331 lines (219 loc) · 9.61 KB
/
KNOWN_BUGS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
Known bugs of the T48 uController core
======================================
Release 0.6.1 BETA
------------------
*******************************************************************************
Deassertion of PROG too early
PROG is deasserted in XTAL2 cycle which might lead to read data being already
invalid (tri-stated) when the core samples P2[3:0] at the end of XTAL3.
Fixed in:
clock_ctrl.vhd 1.12
Fix will be included in next release.
Release 0.6 BETA
----------------
*******************************************************************************
Deassertion of PROG too early
See above.
*******************************************************************************
P2 Port value restored after expander access
After access to expander interface (ANLD Pp; MOVD A,Pp; MOVD Pp,A; ORLD Pp)
the port value of P2 is restored. This is wrong according to chapter "Port 2
Operations" of the "Expanded MCS-48 System" manual. It states that previously
latched I/O information will be removed and not restored.
Fixed in:
p2.vhd 1.8
Fix will be included in next release.
*******************************************************************************
Problem when INT and JMP
When code is executed from Memory Bank 1, the injected CALL triggered by the
interrupt does not always vector to address 3. This happens because of a bus
collision between the decoder unit and the db_bus unit. The resulting address
can be either:
* 000h, 001h, 002h, 003h for external and timer interrupt
* 004h, 005h, 006h, 007h for timer interrupt
The problem was introduced in release 0.6 BETA when the glitch on PCH was
fixed.
Fixed in:
decoder.vhd 1.21
New regression test: int_on_mb1
Fix will be included in next release.
Release 0.5 BETA
----------------
*******************************************************************************
Deassertion of PROG too early
See above.
*******************************************************************************
P2 Port value restored after expander access
See above.
*******************************************************************************
Target address of JMP and CALL to Program Memory Bank 1 corrupted by interrupt
An interrupt occuring during the execution of a JMP instruction, forces bit 11
of the target address to 0. This corrupts target addresses that are located in
Program Memory Bank 1.
Fixed in:
int.vhd 1.5
New regression test: white_box/int_on_int
Fix will be included in next release.
*******************************************************************************
MSB of Program Counter changed upon PC increment
The current implementation of the Program Counter allows that the MSB (bit 11)
is modifed when the PC increments at address 07FFh linear code execution. This
is contrary to the description found in "The Expanded MCS-48 System" which
states that bit 11 is only altered by JMP and CALL/RET but not by normal
increment.
Fixed in:
pmem_crtl.vhd 1.4
New regression test: white_box/pc_wrap_bit11
Fix will be included in next release.
*******************************************************************************
Wrong clock applied to T0
After executing the 'ENT0 CLK' instruction, the internal clock (XTAL divided
by 3) should be applied to T0.
The t48_core applies clk_i to T0. This is equal to XTAL in the current
implementation of t8048 and others. Therefore, the clock at T0 is three times
faster than specified.
Fixed in:
clock_ctrl.vhd 1.7
t48_core.vhd 1.8
Fix will be included in next release.
Release 0.4 BETA
----------------
*******************************************************************************
P2 Port value restored after expander access
See above.
*******************************************************************************
Target address of JMP and CALL to Program Memory Bank 1 corrupted by interrupt
See above.
*******************************************************************************
MSB of Program Counter changed upon PC increment
See above.
*******************************************************************************
Wrong clock applied to T0
See above.
*******************************************************************************
RD' and WR' not asserted for INS A, BUS and OUTL BUS, A
The control signals RD' and WR' are not asserted when the instructions INS A,
BUS and OUTL BUS, A are executed. The BUS is read or written but the control
signals are missing.
Fixed in:
decoder.vhd 1.16
Fix will be included in next release.
*******************************************************************************
P1 constantly in push-pull mode in t8048
Port P1 is constantly driven by an active push-pull driver instead of an
open-collector driver type. This inhibits using any bit of P1 in input
direction.
Fixed in:
t8048.vhd 1.4
Fix will be included in next release.
Release 0.3 BETA
----------------
*******************************************************************************
P2 Port value restored after expander access
See above.
*******************************************************************************
Target address of JMP and CALL to Program Memory Bank 1 corrupted by interrupt
See above.
*******************************************************************************
MSB of Program Counter changed upon PC increment
See above.
*******************************************************************************
Wrong clock applied to T0
See above.
*******************************************************************************
RD' and WR' not asserted for INS A, BUS and OUTL BUS, A
See above.
*******************************************************************************
P1 constantly in push-pull mode in t8048
See above.
*******************************************************************************
PSENn Timing
PSENn is erroneously activated during read or write from external memory when
the read and write strobe signals RDn and WRn are active. This happens when
code is executed from external Program Memory.
The problem lies in the decoder module where the PSENn signal is generated
based on the current machine cycle.
Fixed in decoder.vhd 1.15
Added waveform check for PSENn in if_timing.vhd 1.3
New regression test: white_box/psen_rd_wr_timing
Fix will be included in next release.
Release 0.2 BETA
----------------
*******************************************************************************
P2 Port value restored after expander access
See above.
*******************************************************************************
MSB of Program Counter changed upon PC increment
See above.
*******************************************************************************
Wrong clock applied to T0
See above.
*******************************************************************************
RD' and WR' not asserted for INS A, BUS and OUTL BUS, A
See above.
*******************************************************************************
P1 constantly in push-pull mode in t8048
See above.
*******************************************************************************
PSENn Timing
See above.
*******************************************************************************
Program Memory bank can be switched during interrupt
During an interrupt service routine (i.e. after vectoring to location 3 or 7
of the Program Memory and befor executing the RETR instruction) the Program
Memory bank can be switched by executing a JMP or CALL instruction. These
instructions honour the current state of the Program Memory Bank Flag and thus
switch the Program Memory bank upon execution.
Fixed in:
int.vhd 1.2
decoder.vhd 1.14
Updated regression test:
black_box/mb/int
Fix will be included in next release.
Release 0.1 BETA
----------------
*******************************************************************************
P2 Port value restored after expander access
See above.
*******************************************************************************
MSB of Program Counter changed upon PC increment
See above.
*******************************************************************************
Wrong clock applied to T0
See above.
*******************************************************************************
RD' and WR' not asserted for INS A, BUS and OUTL BUS, A
See above.
*******************************************************************************
PSENn Timing
See above.
*******************************************************************************
Program Memory bank can be switched during interrupt
See above.
******************************************************************************
External Program Memory ignored when EA = 0
The external Program Memory is always ignored when EA = 0 with the t8048 system
toplevel. Desired behaviour is to access external Program Memory when code
has to be fetched from an address location that is outside the internal
Program Memory.
Fixed in t8048.vhd 1.3
Fix will be included in next release.
******************************************************************************
ANL and ORL to P2 read port status instead of port output register
The ANL and ORL instructions for P2 read the port status and apply the logical
operation on this value. Instead, they should read the port output register
and operate on this value.
Fixed in p2.vhd 1.5
Regression test:
white_box/p2_port_reg_conflict
Fix will be included in next release.
******************************************************************************
Counter is not incremented
When in counter mode, the timer/counter module does not increment upon a
falling edge of T1. Reason is a typo in the code for the edge detection signal
t1_inc_s - it will never become true.
Fixed in timer.vhd 1.3
Regression tests:
black_box/cnt/cnt
black_box/cnt/int
Fix will be included in next release.