Difference between revisions of "Nova"
|  (→Ports) |  (→Links) | ||
| (19 intermediate revisions by the same user not shown) | |||
| Line 7: | Line 7: | ||
| The main uses of NVRAM are: [https://www.cpcwiki.eu/forum/amstrad-cpc-hardware/nova-nvram-rtc-for-amstrad-cpc-latest-news-from-pulkotronics/msg199014/#msg199014 Source] | The main uses of NVRAM are: [https://www.cpcwiki.eu/forum/amstrad-cpc-hardware/nova-nvram-rtc-for-amstrad-cpc-latest-news-from-pulkotronics/msg199014/#msg199014 Source] | ||
| *For UniDOS, the goal is to store the configuration of UniDOS in a single place even if you have many storage devices connected to your CPC. Since the card also provides a realtime clock, UniDOS will be able to set the correct file dates in the filesystem. | *For UniDOS, the goal is to store the configuration of UniDOS in a single place even if you have many storage devices connected to your CPC. Since the card also provides a realtime clock, UniDOS will be able to set the correct file dates in the filesystem. | ||
| − | *For development tools: here the idea is precisely to NOT be dktronic's compatible. You can load some code into the RAM and have it available without interference on the CPC state. Very useful if you want to debug some other code. | + | *For development tools: here the idea is precisely to NOT be [[Standard Memory Expansions|dktronic's compatible]]. You can load some code into the RAM and have it available without interference on the CPC state. Very useful if you want to debug some other code. | 
| + | |||
| + | UniDOS automatically uses Nova to avoid main memory usage for FatFs and ensure a much better AMSDOS compatibility [https://unidos.cpcscene.net/doku.php?id=en%3Amanuel_n%C5%93uds Source]. It can also help implement [[Albireo]] USB mouse support in old games without having to make space in conventional RAM. | ||
| + | |||
| + | <br> | ||
| == Ports == | == Ports == | ||
| Line 26: | Line 30: | ||
| ! rowspan="2" | Address | ! rowspan="2" | Address | ||
| ! colspan="8" | Data | ! colspan="8" | Data | ||
| − | |||
| ! rowspan="2" | Range (BCD) | ! rowspan="2" | Range (BCD) | ||
| |- | |- | ||
| ! D7 !! D6 !! D5 !! D4 !! D3 !! D2 !! D1 !! D0 | ! D7 !! D6 !! D5 !! D4 !! D3 !! D2 !! D1 !! D0 | ||
| |- | |- | ||
| − | | 7FFFh || colspan="4" | 10 Years || colspan="4"  | + | | 7FFFh || colspan="4" | 10 Years || colspan="4" | Year || 00-99 | 
| |- | |- | ||
| − | | 7FFEh || 0 || 0 || 0 || 10 M. || colspan="4"  | + | | 7FFEh || 0 || 0 || 0 || 10 M. || colspan="4" | Month || 01-12 | 
| |- | |- | ||
| − | | 7FFDh || 0 || 0 || colspan="2" | 10 date || colspan="4"  | + | | 7FFDh || 0 || 0 || colspan="2" | 10 date || colspan="4" | Date || 01-31 | 
| |- | |- | ||
| − | | 7FFCh || 0 || FT || CEB || CB || 0 || colspan="3" | Day  | + | | 7FFCh || 0 || FT || CEB || CB || 0 || colspan="3" | Day || 00-01/01-07 | 
| |- | |- | ||
| − | | 7FFBh || 0 || 0 || colspan="2" | 10 hours || colspan="4"  | + | | 7FFBh || 0 || 0 || colspan="2" | 10 hours || colspan="4" | Hours || 00-23 | 
| |- | |- | ||
| − | | 7FFAh || 0 || colspan="3" | 10 minutes || colspan="4"  | + | | 7FFAh || 0 || colspan="3" | 10 minutes || colspan="4" | Minutes || 00-59 | 
| |- | |- | ||
| − | | 7FF9h || ST || colspan="3" | 10 seconds || colspan="4"  | + | | 7FF9h || ST || colspan="3" | 10 seconds || colspan="4" | Seconds || 00-59 | 
| |- | |- | ||
| − | | 7FF8h || W || R || S || colspan="5" | Calibration  | + | | 7FF8h || W || R || S || colspan="5" | Calibration ||   | 
| |} | |} | ||
| Line 51: | Line 54: | ||
| *CB = CENTURY bit | *CB = CENTURY bit | ||
| *CEB = CENTURY ENABLE bit (when CEB is set to '1,' CB will toggle from '0' to '1' or from '1' to '0' at the turn of the century) | *CEB = CENTURY ENABLE bit (when CEB is set to '1,' CB will toggle from '0' to '1' or from '1' to '0' at the turn of the century) | ||
| − | *FT = FREQUENCY TEST bit (must be set to '0'  | + | *FT = FREQUENCY TEST bit (must be set to '0' for normal operation) | 
| *0 = Must be set to '0' | *0 = Must be set to '0' | ||
| *ST = STOP bit ('1' stops the oscillator) | *ST = STOP bit ('1' stops the oscillator) | ||
| *Calibration (The oscillation rate of any crystal changes with temperature. The accuracy is greatly improved by properly setting the calibration bits) | *Calibration (The oscillation rate of any crystal changes with temperature. The accuracy is greatly improved by properly setting the calibration bits) | ||
| *S = SIGN bit ('1' indicates positive calibration, '0' indicates negative calibration) | *S = SIGN bit ('1' indicates positive calibration, '0' indicates negative calibration) | ||
| − | *R = READ bit | + | *R = READ bit (Setting the READ bit to a '1' halts updates to the registers) | 
| − | *W = WRITE bit | + | *W = WRITE bit (Setting the WRITE bit to a '1' halts updates to the registers. The user can then load them with the correct day, date, and time data in 24-hour BCD format. Resetting the WRITE bit to a '0' then transfers the values of all registers to the actual counters and allows normal operation to resume) | 
| + | |||
| + | <br> | ||
| == Software == | == Software == | ||
| Line 63: | Line 68: | ||
| The Nova RTC is supported by all the big guns: [[FutureOS]], [[SymbOS]], [[UniDOS]], [[HDCPM]], etc.. | The Nova RTC is supported by all the big guns: [[FutureOS]], [[SymbOS]], [[UniDOS]], [[HDCPM]], etc.. | ||
| − | + | UniDOS provides an RSX command to read or write to the RTC under Basic: | |
| − | + | [[File:Nova RTC UniDOS RSX.jpg]] | |
| − | + | Without RSX, accessing the RTC registers can simply be done that way: | |
| + |  OUT &FE82,&6B ' Map page 4 at 6000-7FFF | ||
| + |  POKE &7FF8,&40 ' Put the card in RTC read mode (7FF8-7FFF will stop updating) | ||
| + |  year = PEEK(&7FFF) | ||
| + |  month = PEEK(&7FFE) | ||
| + |  day = PEEK(&7FFD) | ||
| + |  weekday = PEEK(&7FFC) | ||
| + |  hour = PEEK(&7FFB) | ||
| + |  minute = PEEK(&7FFA) | ||
| + |  second = PEEK(&7FF9) | ||
| + |  POKE &7FF8,&00 ' Put the card in running mode (7FF8-7FFF start updating every second again) | ||
| + |  OUT &FE82,&00 | ||
| + | |||
| + | <br> | ||
| + | |||
| + | == Links == | ||
| − | [[Media:Nova cpc nvram.pdf| | + | *[https://pulkomandy.github.io/shinra.github.io/nova.html Official website] | 
| + | *[[Media:Nova cpc nvram.pdf|Nova KiCad schematics]] | ||
| + | *[https://framagit.org/offset/nova-acepansion Nova ACEpansion] on Framagit | ||
| + | *[[Media:M48t35.pdf|Datasheet of the M48T35Y TimeKeeper SRAM chip]] | ||
| − | + | <br> | |
| [[Category:Peripherals]] | [[Category:Peripherals]] | ||
| [[Category:Hardware]] | [[Category:Hardware]] | ||
| [[Category:Memory expansions]] | [[Category:Memory expansions]] | ||
Latest revision as of 20:42, 9 April 2025
Non-volatile RAM and Real Time Clock (RTC) for Amstrad CPC. This works like RAM, but the content is not erased when the computer is off.
All Nova cards come with the 32KB chip. Source
The main uses of NVRAM are: Source
- For UniDOS, the goal is to store the configuration of UniDOS in a single place even if you have many storage devices connected to your CPC. Since the card also provides a realtime clock, UniDOS will be able to set the correct file dates in the filesystem.
- For development tools: here the idea is precisely to NOT be dktronic's compatible. You can load some code into the RAM and have it available without interference on the CPC state. Very useful if you want to debug some other code.
UniDOS automatically uses Nova to avoid main memory usage for FatFs and ensure a much better AMSDOS compatibility Source. It can also help implement Albireo USB mouse support in old games without having to make space in conventional RAM.
Ports
The interface uses only one port (&FE82) to map the NVRAM in and out. It is possible to map it at any address multiple of &2000.
The four higher bits of the byte sent to port &FE82 determine the base address: 0 = &0000, 2 = &2000, 4 = &4000, ..., E = &E000.
The NVRAM, when it is enabled, masks 8K of RAM or ROM and replaces it with its own contents. Four NVRAM pages of 8K are available.
The four lower bits of the byte sent to port &FE82 selects the page: 8 = page0, 9 = page1, A = page2, B = page3, the other values disable the mapping.
In the fourth page, the last 8 bytes are not normal RAM, but can be used to read and write the time from the realtime clock.
Assuming the interface is mapped at 6000-7FFF:
| Address | Data | Range (BCD) | |||||||
|---|---|---|---|---|---|---|---|---|---|
| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | ||
| 7FFFh | 10 Years | Year | 00-99 | ||||||
| 7FFEh | 0 | 0 | 0 | 10 M. | Month | 01-12 | |||
| 7FFDh | 0 | 0 | 10 date | Date | 01-31 | ||||
| 7FFCh | 0 | FT | CEB | CB | 0 | Day | 00-01/01-07 | ||
| 7FFBh | 0 | 0 | 10 hours | Hours | 00-23 | ||||
| 7FFAh | 0 | 10 minutes | Minutes | 00-59 | |||||
| 7FF9h | ST | 10 seconds | Seconds | 00-59 | |||||
| 7FF8h | W | R | S | Calibration | |||||
Legend:
- CB = CENTURY bit
- CEB = CENTURY ENABLE bit (when CEB is set to '1,' CB will toggle from '0' to '1' or from '1' to '0' at the turn of the century)
- FT = FREQUENCY TEST bit (must be set to '0' for normal operation)
- 0 = Must be set to '0'
- ST = STOP bit ('1' stops the oscillator)
- Calibration (The oscillation rate of any crystal changes with temperature. The accuracy is greatly improved by properly setting the calibration bits)
- S = SIGN bit ('1' indicates positive calibration, '0' indicates negative calibration)
- R = READ bit (Setting the READ bit to a '1' halts updates to the registers)
- W = WRITE bit (Setting the WRITE bit to a '1' halts updates to the registers. The user can then load them with the correct day, date, and time data in 24-hour BCD format. Resetting the WRITE bit to a '0' then transfers the values of all registers to the actual counters and allows normal operation to resume)
Software
The Nova RTC is supported by all the big guns: FutureOS, SymbOS, UniDOS, HDCPM, etc..
UniDOS provides an RSX command to read or write to the RTC under Basic:
Without RSX, accessing the RTC registers can simply be done that way:
OUT &FE82,&6B ' Map page 4 at 6000-7FFF POKE &7FF8,&40 ' Put the card in RTC read mode (7FF8-7FFF will stop updating) year = PEEK(&7FFF) month = PEEK(&7FFE) day = PEEK(&7FFD) weekday = PEEK(&7FFC) hour = PEEK(&7FFB) minute = PEEK(&7FFA) second = PEEK(&7FF9) POKE &7FF8,&00 ' Put the card in running mode (7FF8-7FFF start updating every second again) OUT &FE82,&00
Links
- Official website
- Nova KiCad schematics
- Nova ACEpansion on Framagit
- Datasheet of the M48T35Y TimeKeeper SRAM chip


