These instructions will guide you how to update your X16 firmware from any previous version to the latest version. This guide will be updated once there are new releases. This guide is applicable for Gen 1 hardware, PRxxxxx boards.
- Latest release
- Requirements
- Update instructions
- Appendix: Release history
- Appendix: Stock version numbers
- Appendix: How to downgrade from latest release to first release
Firmware | Version | Date | Link |
---|---|---|---|
ROM | R48 | 2024-09-06 | https://github.com/X16Community/x16-rom/releases/tag/r48 |
SMC | 48.0.0 | 2024-12-23 | https://github.com/X16Community/x16-smc/releases/tag/r48.0.0 |
VERA | 48.0.1 | 2025-01-08 | https://github.com/X16Community/vera-module/releases/tag/v48.0.1 |
SMC bootloader | 3 | 2024-09-13 | https://github.com/X16Community/x16-smc-bootloader/releases/tag/v3 |
Property | Requirement |
---|---|
Hardware | Gen 1 PRxxxxx board |
ROM | Minimum version R43 |
SMC | Minimum version 43.0.0 |
VERA | No minimum version |
Use the HELP
command to see which versions you currently have.
You may want to take a picture of the screen or write it down, for future reference.
- Poll bootloader version with this command:
PRINT I2CPEEK($42,$8E)
- This should be 2 if you have a stock PR board. Note that if you have bootloader 3 it may incorrectly display as 255.
- If you have SMC version 47.2.3 or later, you can use the tool "SMCBLD7.PRG" inside [smc tools] (see step 3) to identify bootloader version based on its CRC-16 checksum, making this a more accurate bootloader test.
- Take a picture of the screen, for future reference.
- Plug SD card in your PC and make a backup of all files. In case SD card gets corrupted, damaged, or you loose your files otherwise.
- If needed, you can download the latest version of the SD card bundle here: https://github.com/cx16forum/sdcard
- If you know your current version numbers (step 1), and do not care about rolling back, you can safely skip this step.
- If you like to preserve the history, and your version is not already archived, you may want to dump it before overwriting it.
CLICK FOR DETAILS
If your version is not archived (e.g. ROM prerelease), you may want to make a backup of this one (and give a heads-up on Discord, #kernel).
- Dump tool for ROM/SMC/VERA/RTC: https://cx16forum.com/forum/viewtopic.php?p=34970
- Archive of official releases:
- Unofficial releases, known to have been delivered with some machines:
- SMC 45.1.0: Dump: https://github.com/FlightControl-User/x16-flash/releases/download/r3.0.0/R45-BINS.zip
- SMC bootloader v2(bad): Dump: Inside [bootloader tools] X16Community/x16-smc#53 (comment) / src: X16Community/x16-smc#20
- ROM R47 prerelease git 8929A57+: Dump: https://cx16forum.com/forum/viewtopic.php?p=31112 / src: X16Community/x16-rom#213 (exact source is ambiguous due to the +)
- ROM R47 prerelease git 33ACE3A4: Dump: https://cx16forum.com/forum/viewtopic.php?p=31112 / src: X16Community/x16-rom#241
- BIN files and their associated programming tool must stay in the same folder
- Note that the x16-flash tool (UPDATE.PRG) will attempt to program both ROM, SMC and VERA if it finds associated .BIN files in its folder, so make sure that its folder only contains ROM.BIN
- UPDATE
- VERA
- FLASHVERA.PRG
- VERA.BIN (downloaded file must be renamed to VERA.BIN)
- ROM
- UPDATE.PRG
- ROM.BIN
- SMC
- SMCUPDATE-x.x.x.PRG (do not rename)
- SMCTOOLS
- SMCBLD7.PRG
- SMCBLW19.PRG
- BOOT3.BIN
- VERA
To organize multiple ROM and VERA versions on the SD card, you may e.g. add folders with version numbers, and place firmware inside.
- VERA 48.0.1
- https://github.com/X16Community/vera-module/releases/tag/v48.0.1
- Download Assets -> VERA_48.0.1.BIN
- https://github.com/mooinglemur/flashvera/releases/tag/v0.2
- Download Assets -> FLASHVERA.PRG
- https://github.com/X16Community/vera-module/releases/tag/v48.0.1
- ROM R48
- https://github.com/X16Community/x16-rom/releases/tag/r48
- Download Assets -> Release.R48.ROM.Image.zip
- Extract "rom.bin"
- Download Assets -> Release.R48.ROM.Image.zip
- https://github.com/FlightControl-User/x16-flash/releases/tag/r3.0.0
- Download Assets -> CX16-UPDATE-R3.0.0.PRG
- https://github.com/X16Community/x16-rom/releases/tag/r48
- SMC 48.0.0
- https://github.com/X16Community/x16-smc/releases/tag/r48.0.0
- Download Assets -> X16-SMC_r48.0.0.zip
- Extract "SMCUPDATE-48.0.0.PRG"
- Download Assets -> X16-SMC_r48.0.0.zip
- https://github.com/X16Community/x16-smc/releases/tag/r48.0.0
- SMC tools v6
- X16Community/x16-smc#53 (comment)
- Download smc-flash-manipulation-6.zip
- Extract files mentioned under SMCTOOLS above
- Download smc-flash-manipulation-6.zip
- X16Community/x16-smc#53 (comment)
- Prepare the folder structure on the SD card.
- Copy downloaded files to SD card, inside the folder structure mentioned above.
- Rename files as needed. Uppercase/lowercase is not important.
- To list files in current folder, or change folder, you use the commands
DOS"$"
orDOS"CD:folder"
. - A shortcut is to use the
@
prefix, e.g.@$
and@CD:folder
- To enter the VERA folder, you can e.g. use the command
@CD:/UPDATE/VERA
- You can also navigate like this:
@CD:/UPDATE
@$
@CD:VERA
@$
VERA have best backward compatibility, and should be flashed first.
- 48.0.1 supports at least ROM 47 prerelease, and probably older ROMs as well.
- Release page: https://github.com/X16Community/vera-module/releases/tag/v48.0.1
- Follow instructions on release page to program VERA.
@CD:/UPDATE/VERA
LOAD "FLASHVERA.PRG"
RUN
- After programming, restart machine and type
HELP
to verify VERA version.
- Minimum SMC version: 43.0.0
- Minimum VERA version: 0.3.1
- You may follow this guide: https://github.com/FlightControl-User/x16-flash
@CD:/UPDATE/ROM
LOAD "UPDATE.PRG"
RUN
- Follow the instructions on screen.
- Note that the J1 jumper must be on, to allow ROM to be reprogrammed. Disconnect jumper after programming, to ensure ROM is write protected.
- Important: Only program ROM in this step, not VERA or SMC.
- To update SMC, a little program on the SMC called "bootloader" is used to replace its main program.
- All PR boards up to ~900 seem to have been delivered with version 45.1.0, and with a bootloader which claims to be version 2, but, unfortunately, is a corrupt version of version 2 (also referred to as the "bad" bootloader). This have the consequence that, if you attempt to program, the x16 will hang at the end of programming. If you attempt to fix the hang problem by disconnecting power, and plug it back in, your SMC will be "bricked", and you cannot use your x16 until you disconnect the SMC and program it manually using an external programmer or Arduino [recovery-with-arduino].
- To update your SMC with bad bootloader, you have 2 options:
- Option 1: Disconnect the SMC, connect to an external programmer, and install latest firmware https://github.com/X16Community/x16-smc/blob/main/doc/recovery-with-arduino.md
- Option 2: Reset the SMC by shorting its reset pin to GND, using a jumper wire. Instruction: https://github.com/X16Community/x16-smc/blob/main/doc/update-with-bad-bootloader-v2.md
- NB: If you plan to do option 2, ref the instructions, you should practice doing this reset while at the READY prompt. Once you get the hang of it, you can do it during programming. It is important that you get it correct at the critical moment when the SMC is hanging inside the bad bootloader.
- If you have a different SMC version than 45.1.0, you most likely do not have the bad bootloader.
- The recommended method to upgrade SMC to latest version 48.0.0, is to use an installer with version 48.0.0 bundled together with the installer.
- If there is a risk of having the bad v2 bootloader, have a jumper wire ready
- Load and run the installer
@CD:/UPDATE/SMC
LOAD "SMCUPDATE-48.0.0.PRG"
RUN
- Use the jumper wire if needed, ref the "update-with-bad-bootloader-v2.md" instructions
CLICK FOR DETAILS
- The tool SMCUPDATE 2.0 allows you to specify a .hex file to install
- This tool works with bootloader 2, but not with bootloader 3
- Tool: https://github.com/stefan-b-jakobsson/x16-smc-update/releases/tag/2.0
- When prompted for file name, enter "x16-smc.ino.hex"
- The tool x16-flash allows you to program the .bin file from the release page
- This tool ignores bootloader version, and works with both v2 and v3
- If bootloader version is 2, you cannot reprogram with the same version
- This tool gives bad recommendation in the case of bad bootloader
- Tool: https://github.com/FlightControl-User/x16-flash/releases/tag/r3.0.0
- These tools can work with the .hex and .bin files found in the release page
Follow instructions inside the text file in [smc tools] ("smc-flash-manipulation-6.zip")
- Run SMCBLD7.PRG to get bootloader checksum, version and failsafe status
@CD:/UPDATE/SMCTOOLS
LOAD "SMCBLD7.PRG"
RUN
- Run SMCBLW19.PRG to install BOOT3.BIN
@CD:/UPDATE/SMCTOOLS
LOAD "SMCBLW19.PRG"
RUN
- Run SMCBLD7.PRG to validate checksum again, confirm it BF63 (v3)
- To install "Boot v3 failsafe", you need to update SMC a second time (repeat step 6)
- Run SMCBLD7.PRG, to confirm that boot v3 failsafe is installed
With Boot V3 failsafe installed, you have a fallback mechanism in case SMC firmware gets corrupted.
Date | ROM | SMC | VERA | SMC bootloader | Notes |
---|---|---|---|---|---|
2025-01-08 | 48.0.1 | XOR Sawtooth + bus stability | |||
2024-12-23 | 48.0.0 | Kbd initstate, read fuse++ | |||
2024-09-13 | 3 | Boot v3, with failsafe | |||
2024-09-06 | R48 | Release R48 ("Cadmium") | |||
2024-07-05 | 47.2.3 | Bootloader manipulation ++ | |||
2024-03-30 | R47 | 47.0.0 | 47.0.2 | Release R47 ("Roswell") | |
2023-12-24 | R47 pre 33ACE3A4* | Unreleased ROM version* | |||
2023-11-20 | 0.3.2 | Experimental FX | |||
2023-11-06 | R47 pre 8929A57+* | Unreleased ROM version* | |||
2023-11-06 | R46 | Release R46 ("Winnipeg") | |||
2023-10-18 | 45.1.0* | Unreleased*, bootloader support | |||
2023-10-17 | R45 | Release R45 ("Nuuk") | |||
2023-10-04 | 2 | Boot v2, auto power off | |||
2023-10-04 | 2 (bad)* | Bad version* | |||
2023-08-14 | R44 | Release R44 ("Milan") | |||
2023-08-09 | 0.3.1 | Experimental FX | |||
2023-05-17 | R43 | 43.0.0 | Release R43 ("Stockholm") | ||
2023-04-19 | 1 | Boot v1 | |||
2023-03-23 | 0.1.1 | VERA 0.1.1 | |||
2023-03-07 | R42 | R42 | Release R42 ("Cambridge") |
- A few releases are not official, but, these have been delivered with some of the machines, see below.
CLICK FOR DETAILS
This is based on feedback from users on Discord, and is very approximate. If you have updated info, feel free to send a message on Discord.
Firmware | Version | Date | Link |
---|---|---|---|
ROM | R47pre git 8929A57+* | 2023-11-06 | Build: https://cx16forum.com/forum/viewtopic.php?p=31112 / src: X16Community/x16-rom#213 (exact source is ambiguous due to the +) |
SMC | 45.1.0* | 2023-10-18 | Build: https://github.com/FlightControl-User/x16-flash/blob/main/arduino/x16-smc-r45.1-bootloader.hex / src: X16Community/x16-smc#20 |
VERA | 0.3.2 | 2023-11-20 | https://github.com/X16Community/vera-module/releases/tag/v0.3.2 |
SMC bootloader | 2 (bad)* | 2023-10-04 | Build: https://github.com/FlightControl-User/x16-flash/blob/main/arduino/x16-smc-r45.1-bootloader.hex / src: https://github.com/stople/x16-smc-bootloader/tree/bad_v2 |
Firmware | Version | Date | Link |
---|---|---|---|
ROM | R47pre git 33ACE3A4* | 2023-12-24 | Build: https://cx16forum.com/forum/viewtopic.php?p=31112 / src: X16Community/x16-rom#241 |
SMC | 45.1.0* | 2023-10-18 | |
VERA | 0.3.2 | 2023-11-20 | |
SMC bootloader | 2 (bad)* | 2023-10-04 |
Firmware | Version | Date | Link |
---|---|---|---|
ROM | R47 | 2024-03-30 | https://github.com/X16Community/x16-rom/releases/tag/r47 |
SMC | 47.0.0 | 2024-03-30 | https://github.com/X16Community/x16-smc/releases/tag/r47.0.0 |
VERA | 47.0.2 | 2024-03-30 | https://github.com/X16Community/vera-module/releases/tag/v47.0.2 |
SMC bootloader | 2 | 2023-10-04 | https://github.com/X16Community/x16-smc-bootloader/releases/tag/v2 |
Firmware | Version | Date | Link |
---|---|---|---|
ROM | R48 | 2024-09-06 | https://github.com/X16Community/x16-rom/releases/tag/r48 |
SMC | 47.2.3 | 2024-07-05 | https://github.com/X16Community/x16-smc/releases/tag/r47.2.3 |
VERA | 47.0.2 | 2024-03-30 | https://github.com/X16Community/vera-module/releases/tag/v47.0.2 |
SMC bootloader | 2 | 2023-10-04 | https://github.com/X16Community/x16-smc-bootloader/releases/tag/v2 |
Machine | ROM | SMC | VERA | SMC bootloader |
---|---|---|---|---|
PR00015 | R47pre git 8929A57+* | |||
PR00102 | R47pre git 8929A57+* | 45.1.0* | 0.3.2 | 2 (bad)* |
PR00499 | R47pre git 33ACE3A4* | |||
PR00831 | R47pre git 33ACE3A4* | 45.1.0* | 0.3.2 | 2 (bad)* |
PR00923 | 47.0.0 | |||
PR01011 | R48 | 47.2.3 | 47.0.2 | 2 |
CLICK FOR DETAILS
This is optional, as all bootloaders are backward compatible. If you do not plan to downgrade bootloader, go to step 2.
Run SMCBLD7.PRG. Check if "Boot v3 failsafe" is installed. If it is, and you plan to downgrade to bootloader v2 or older, you must:
- Ensure [any working SMC programming tool and SMC version] is present on SD card
- SMCUPDATE-47.2.3 can be used
- NB: x16-flash with bootloader 2 rejects programming SMC to the same version!
- Downgrade bootloader, using SMCBLW19.PRG
- Computer is now in a critical state. If you power it off, it is bricked.
- In this state, you must perform a SMC programming, to any version, with any tool, to uninstall "boot v3 failsafe".
- If you installed bad v2 bootloader, remember to reset it using jumper wire
Downgrade SMC using any tool
- SMCUPDATE or x16-update
- Note that SMC 45.1.0* or newer is needed if you want to use the bootloader afterwards
- SMC older than R42 is intended for an incompatible hardware revision
Downgrade ROM
- ROM older than R42 is intended for an incompatible hardware revision
Downgrade VERA
- If using VERA.BIN from release page, use the associated FLASHVERA
- If using VERA.BIN released together with x16-flash, use x16-flash to program it