CPU variants: Difference between revisions
m (capitalization) |
(Notes that DMC status bit is cleared 1 APU cycle late on UA6527P, TA-03NP1, (T)1818P, UM6561-2. Other clones untested.) |
||
Line 36: | Line 36: | ||
One revision has (UMC) © Ⓜ B6167F 1989 09 on the die. | One revision has (UMC) © Ⓜ B6167F 1989 09 on the die. | ||
DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. The cause is not known. This changes the timing for [[DMA#Bugs|DMC DMA implicit-stop glitches]] (the sample must be started 1 APU cycle earlier to trigger the glitches), and it is suspected that it delays DMC IRQ by 1 APU cycle. | |||
{| class="tabular" | {| class="tabular" | ||
Line 55: | Line 57: | ||
|- | |- | ||
| UM6561xx-2 || NES-on-a-chip for PAL-B. Revisions "xx" F, AF, BF, CF known. Earlier revisions (which?) CPU half believed identical to UA6527P; later revisions correct pulse channel duties. | | UM6561xx-2 || NES-on-a-chip for PAL-B. Revisions "xx" F, AF, BF, CF known. Earlier revisions (which?) CPU half believed identical to UA6527P; later revisions correct pulse channel duties. | ||
F and AF revision pulse wave duty cycles | F and AF revision pulse wave duty cycles match RP2A03, and DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. | ||
AF revision observed to have incorrect ASR #imm ($4B) behavior, but other stable illegal instructions work properly. | AF revision observed to have incorrect ASR #imm ($4B) behavior, but other stable illegal instructions work properly. | ||
Line 65: | Line 65: | ||
| T1818 || ??-made NES-on-a-chip, NTSC timing. Believed to exist, but evidence currently scant. | | T1818 || ??-made NES-on-a-chip, NTSC timing. Believed to exist, but evidence currently scant. | ||
|- | |- | ||
| T1818P || ??-made NES-on-a-chip[[//forums.nesdev.org/viewtopic.php?p=228515#p228515]. Requires external 2 KiB RAMs for CPU and PPU. Swapped pulse duty cycles. | | T1818P || ??-made NES-on-a-chip[[//forums.nesdev.org/viewtopic.php?p=228515#p228515]. Requires external 2 KiB RAMs for CPU and PPU. Swapped pulse duty cycles. DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. | ||
|- | |- | ||
| TA-03N || ??-made clone of 2A03G. Pin 30 selects input clock divider? | | TA-03N || ??-made clone of 2A03G. Pin 30 selects input clock divider? | ||
Line 74: | Line 74: | ||
[[File:CPU=TA-03NP EWP0124.jpg|400px]] But not this one, this input clock divider is 12. | [[File:CPU=TA-03NP EWP0124.jpg|400px]] But not this one, this input clock divider is 12. | ||
|- | |- | ||
| TA-03NP1 || ??-made clone of 2A03G for NTSC compatibility in PAL countries. Input clock divider is 15. Fixed DPCM problems? | | TA-03NP1 || ??-made clone of 2A03G for NTSC compatibility in PAL countries. Input clock divider is 15. Fixed DPCM problems? DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. | ||
[[File:CPU=TA-03NP1 6527P 9231.jpg|400px]] | [[File:CPU=TA-03NP1 6527P 9231.jpg|400px]] | ||
|- | |- |
Revision as of 11:46, 13 February 2023
Beyond the well-studied 2A03G, we know of the following CPU revisions, both made by Ricoh and other manufacturers:
RP2A03 | M2 duty cycle is 17/24 instead of 15/24 [1]. Lacks tonal noise mode. APU Frame Counter not restarted on reset. Has broken and disabled programmable interval timer on-die. Pin 30 connects to nothing. Other differences? | ||||||
RP2A03E | Pin 30 may connect to 6502 /RDY input. | ||||||
RP2A03G | Reference model. Pin 30 enables a CPU test mode. Later runs introduced a DMC DMA bug [2]. | ||||||
RP2A03H | No known differences from late RP2A03G. | ||||||
RP2A04 | Not actually a CPU at all, just a jumper in a 40-pin PDIP | ||||||
RP2A07 | Input clock divider is 16. M2 duty cycle is 19/32 [3]. Changes to noise, DPCM, frame timer tables. Fixed DPCM RDY address bus glitches. Pin 30 connects to 6502 /RDY input. | ||||||
RP2A07A | no known differences relative to 2A07letterless | ||||||
MG-N-501 | Unlike early UA6527, DMC works | ||||||
MG-P-501 | Micro Genius-made clone. Die has the same (UMC) © Ⓜ B6167F marking as a UA6527P. | ||||||
UA6527 | UMC-made clone of 2A03G. Has swapped pulse channel duty cycles. | ||||||
UA6527P | UMC-made clone of 2A03G for compatibility with NTSC software in PAL countries. input clock divider is 15. Otherwise believed same as 6527.
Two revisions exist: before mid-1990 (which has UMC logo on left) and after-mid-1990 (which has UMC logo on top). It is said that old UMC CPU has broken DMC reader function [4]. Additionally it has input clock divider equals to 16 in contrary to the 15 present in newer one, that would explain why some games work differently (for example: CodeMasters' titles) One revision has (UMC) © Ⓜ B6167F 1989 09 on the die. DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. The cause is not known. This changes the timing for DMC DMA implicit-stop glitches (the sample must be started 1 APU cycle earlier to trigger the glitches), and it is suspected that it delays DMC IRQ by 1 APU cycle.
| ||||||
UA6540 | UMC-made clone of 2A07 [5]. Has swapped pulse duty cycles.
Subsequent research implies this is identical to the early 6527P - NTSC tuning tables, ÷16 CPU divider. [6] | ||||||
UM6557 | Believed to be a 100% duplicate of UA6527, for use in SECAM regions. | ||||||
UM6561xx-1 | NES-on-a-chip for NTSC. Revisions "xx" F, AF, BF, CF known. Earlier revisions (which?) CPU half believed identical to UA6527; later revisions correct pulse channel duties. | ||||||
UM6561xx-2 | NES-on-a-chip for PAL-B. Revisions "xx" F, AF, BF, CF known. Earlier revisions (which?) CPU half believed identical to UA6527P; later revisions correct pulse channel duties.
F and AF revision pulse wave duty cycles match RP2A03, and DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. AF revision observed to have incorrect ASR #imm ($4B) behavior, but other stable illegal instructions work properly. | ||||||
T1818 | ??-made NES-on-a-chip, NTSC timing. Believed to exist, but evidence currently scant. | ||||||
T1818P | ??-made NES-on-a-chip[[7]. Requires external 2 KiB RAMs for CPU and PPU. Swapped pulse duty cycles. DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. | ||||||
TA-03N | ??-made clone of 2A03G. Pin 30 selects input clock divider? | ||||||
TA-03NP | ??-made clone of 2A03G for NTSC compatibility in PAL countries. Input clock divider is 15? | ||||||
TA-03NP1 | ??-made clone of 2A03G for NTSC compatibility in PAL countries. Input clock divider is 15. Fixed DPCM problems? DMC status bit is cleared 1 APU cycle later than on RP2A03 CPUs. | ||||||
PM03 | Gradiente-made clone of 2A03G. [8] | ||||||
GS870007 | (Goldstar??)-made clone of 2A03 - has functioning decimal mode? [9] | ||||||
KC-6005 | Found in MT777-DX famiclone, behaves exactly like UA6527P | ||||||
6005B | |||||||
2011 | |||||||
“2A03E” | Both with and without USC insignia | ||||||
KP2B03E |
If you know of other differences or other revisions, please add them!