Memory speed: Difference between revisions
No edit summary |
|||
Line 1: | Line 1: | ||
[[File:Aes_cxk5814.jpg|thumb|[[VRAM]] chip, note the "-35" marking. 35ns is the highest speed requirement in the NeoGeo.]] | [[File:Aes_cxk5814.jpg|thumb|[[VRAM]] chip, note the "-35" marking. 35ns is the highest speed requirement in the NeoGeo.]] | ||
Memory speed (or speed grade) is a value representing the maximum time it takes for a memory chip to output valid data after | Memory speed (or speed grade) is a value representing the maximum time it takes for a memory chip to output valid data after its address is changed. | ||
It is essential for memory chips to be fast enough to avoid crashes or glitches. When replacing RAMs or making cartmods, care must be taken to use chips with appropriate speed grades. | It is essential for memory chips to be fast enough to avoid crashes or glitches. When replacing RAMs, replacing the [[system ROM]] or making cartmods, care must be taken to use chips with the appropriate speed grades. | ||
Speed is usually indicated on the chip. It is actually a time value (speed = 1/t) specified in nanoseconds or tens of nanoseconds. | Speed is usually indicated on the chip. It is actually a time value (speed = 1/t) specified in nanoseconds or tens of nanoseconds. | ||
During the specified time, the data output isn't guaranteed to be valid. So if the system | During the specified time, the data output isn't guaranteed to be valid. So if the chip is too slow, the system might catch wrong bits resulting in unstable operation. | ||
Regarding the NeoGeo, faster (lower value) isn't a problem | Regarding the NeoGeo, faster than required (lower value) isn't a problem, slower than required (higher value) is bad. | ||
= | A slower chip can work in some cases if you're lucky, but you should never expect stable operation in all conditions. For example, some 120ns chips might work in place of a 100ns one, but a slight variation in voltage or temperature could cause crashes or resets. Taking the risk isn't worth it. | ||
=Requirements summary= | |||
See the related section in the [[VRAM]], [[Palette RAM]], [[P ROM]], [[V ROM]], [[S ROM]], [[C ROM]], and [[M1 ROM]] pages. | See the related section in the [[VRAM]], [[Palette RAM]], [[P ROM]], [[V ROM]], [[S ROM]], [[C ROM]], and [[M1 ROM]] pages. | ||
{|class="wikitable" | |||
!Memory kind | |||
!Maximum value | |||
!Mclks | |||
!Proof | |||
|- | |||
|Z80 RAM | |||
|rowspan="2"|<500ns | |||
|rowspan="2"|12? (500ns) | |||
|rowspan="2"|Z80 read cycle | |||
|- | |||
|M1 ROM | |||
|- | |||
|Lower VRAM | |||
|120ns | |||
|3 (125ns) | |||
|Picture | |||
|- | |||
|Upper VRAM | |||
|35ns | |||
|1 (41.7ns) | |||
|Picture | |||
|- | |||
|Palette RAM | |||
|120ns | |||
|3 (125ns) | |||
|Picture | |||
|- | |||
|L0 ROM | |||
|120ns ? | |||
|? | |||
| | |||
|- | |||
|P ROM | |||
|rowspan="4"|150ns | |||
|rowspan="4"|4 (167ns) | |||
|rowspan="4"|SNK EPROM | |||
|- | |||
|System ROM | |||
|- | |||
|68k RAM | |||
|- | |||
|Backup RAM | |||
|- | |||
|V ROM | |||
|200ns | |||
|6 (250ns) | |||
|YM2610 read cycle | |||
|- | |||
|S ROM | |||
|200ns ? | |||
|5? (208ns) | |||
| | |||
|- | |||
|C ROM | |||
|200ns ? | |||
|5? (208ns) | |||
| | |||
|- | |||
|Memory card | |||
|200ns ? | |||
|5? (208ns) | |||
| | |||
|} | |||
=Standard speed grades= | =Standard speed grades= |
Revision as of 04:35, 6 September 2017
Memory speed (or speed grade) is a value representing the maximum time it takes for a memory chip to output valid data after its address is changed.
It is essential for memory chips to be fast enough to avoid crashes or glitches. When replacing RAMs, replacing the system ROM or making cartmods, care must be taken to use chips with the appropriate speed grades.
Speed is usually indicated on the chip. It is actually a time value (speed = 1/t) specified in nanoseconds or tens of nanoseconds.
During the specified time, the data output isn't guaranteed to be valid. So if the chip is too slow, the system might catch wrong bits resulting in unstable operation.
Regarding the NeoGeo, faster than required (lower value) isn't a problem, slower than required (higher value) is bad.
A slower chip can work in some cases if you're lucky, but you should never expect stable operation in all conditions. For example, some 120ns chips might work in place of a 100ns one, but a slight variation in voltage or temperature could cause crashes or resets. Taking the risk isn't worth it.
Requirements summary
See the related section in the VRAM, Palette RAM, P ROM, V ROM, S ROM, C ROM, and M1 ROM pages.
Memory kind | Maximum value | Mclks | Proof |
---|---|---|---|
Z80 RAM | <500ns | 12? (500ns) | Z80 read cycle |
M1 ROM | |||
Lower VRAM | 120ns | 3 (125ns) | Picture |
Upper VRAM | 35ns | 1 (41.7ns) | Picture |
Palette RAM | 120ns | 3 (125ns) | Picture |
L0 ROM | 120ns ? | ? | |
P ROM | 150ns | 4 (167ns) | SNK EPROM |
System ROM | |||
68k RAM | |||
Backup RAM | |||
V ROM | 200ns | 6 (250ns) | YM2610 read cycle |
S ROM | 200ns ? | 5? (208ns) | |
C ROM | 200ns ? | 5? (208ns) | |
Memory card | 200ns ? | 5? (208ns) |
Standard speed grades
- -250 (250ns)
- -200 or -20 (200ns)
- -150 or -15 (150ns)
- -120 or -12 (120ns)
- -90 (90ns)
- -70 (70ns)
- -55 (55ns)
- -35 (35ns).
Note the possible confusion. If the value is less than 30 you probably have to add a 0, even if SRAM is now available in 25ns (not 250ns) speed grades.
Check the datasheets.
DRAM
DRAM (CD systems) is way more complex than SRAM, timings and sequences are primordial.