Difference between revisions of "Rock5/install/spi"
(→3) Flash the SPI flash) |
(add checksums verification) |
||
Line 14: | Line 14: | ||
*[[#Advanced_(external)_method | advanced method]] - flash the SPI with the maskrom mode and an external computer | *[[#Advanced_(external)_method | advanced method]] - flash the SPI with the maskrom mode and an external computer | ||
− | + | <br> | |
For advanced users: | For advanced users: | ||
[[#Addition:_erase_the_SPI_NOR_flash | How to erase the SPI]] | [[#Addition:_erase_the_SPI_NOR_flash | How to erase the SPI]] | ||
− | + | <br> | |
---- | ---- | ||
− | + | <br> | |
= Simple method = | = Simple method = | ||
− | + | <br> | |
== Requirements == | == Requirements == | ||
Line 33: | Line 33: | ||
* ROCK 5B with proper power | * ROCK 5B with proper power | ||
* SD card or eMMC module | * SD card or eMMC module | ||
− | * Linux image for ROCK 5B - | + | * Linux image for ROCK 5B - <i>(Android images are not supported yet)</i> |
− | + | ||
+ | <br> | ||
== Procedure == | == Procedure == | ||
− | + | <br> | |
=== 1) Boot linux from µSD card/eMMC === | === 1) Boot linux from µSD card/eMMC === | ||
Line 45: | Line 45: | ||
The first step is to boot the ROCK 5 with linux from an µSD card or an eMMC module. | The first step is to boot the ROCK 5 with linux from an µSD card or an eMMC module. | ||
− | + | <i>(check [[rock5/install/microSD | this guide]] to flash a new image to an µSD card</i> | |
− | + | <i>or check [[rock5/install/eMMC | this guide]] to flash a new image to an eMMC module)</i> | |
=== 2) Download required files on the ROCK 5 === | === 2) Download required files on the ROCK 5 === | ||
− | You can download files by using <code>wget | + | You can download files by using <code>wget DOWNLOADLINK</code> |
− | + | <i>for example to download the file to clear the spi: <code>wget https://dl.radxa.com/rock5/sw/images/others/zero.img.gz</code></i> | |
+ | <u>Download the required files</u> | ||
− | |||
− | |||
* [https://dl.radxa.com/rock5/sw/images/others/zero.img.gz spi clearing file] | * [https://dl.radxa.com/rock5/sw/images/others/zero.img.gz spi clearing file] | ||
− | and the latest | + | <br> |
− | * [https://dl.radxa.com/rock5/sw/images/loader/rock-5b/release/rock-5b-spi-image-g49da44e116d.img normal bootloader], recommend for everything except armbian - | + | |
+ | and the latest spi bootloader: | ||
+ | * [https://dl.radxa.com/rock5/sw/images/loader/rock-5b/release/rock-5b-spi-image-g49da44e116d.img normal bootloader], recommend for everything except armbian - <7>(for advanced users: this has the u-boot serial console disabled)</i> | ||
* [https://github.com/huazi-yg/rock5b/releases/download/rock5b/rkspi_loader.img bootloader for armbian] (Use this if you like to boot armbian from the M.2 NVME SSD) | * [https://github.com/huazi-yg/rock5b/releases/download/rock5b/rkspi_loader.img bootloader for armbian] (Use this if you like to boot armbian from the M.2 NVME SSD) | ||
− | + | or for advanced users the | |
+ | * [https://dl.radxa.com/rock5/sw/images/loader/rock-5b/debug/rock-5b-spi-image-g3caf61a44c2-debug.img debuging bootloader] with u-boot serial console enabled <i>(This is an debug bootloader if you need to troubleshoot booting issue with serial)</i> | ||
+ | |||
+ | <br> | ||
+ | |||
+ | <u>Check the integrity of the downloaded files:</u> | ||
+ | |||
+ | md5sum zero.img.gz | ||
+ | should give back: | ||
+ | ac581b250fda7a10d07ad11884a16834 zero.img.gz | ||
+ | |||
+ | <br> | ||
+ | |||
+ | extract/uncompress the previous downloaded spi clearing file <i>(gzip should already be installed otherwise install it):</i> | ||
+ | gzip -d zero.img.gz | ||
+ | |||
+ | md5sum zero.img | ||
+ | should give back: | ||
+ | 2c7ab85a893283e98c931e9511add182 zero.img | ||
+ | |||
+ | <br> | ||
+ | |||
+ | and finally check your desired bootloader image: <i>(replace <code>spi-image.img</code> with the name of your downloaded image - eg: <code>rock-5b-spi-image-g49da44e116d.img</code> for the normal bootloader):</i> | ||
+ | md5sum spi-image.img | ||
+ | |||
+ | it should give back one of the following lines: | ||
+ | |||
+ | 46de85de37b8e670883e6f6a8bb95776 rock-5b-spi-image-g49da44e116d.img | ||
+ | 958cbdb6cf9b2e0841fd76c26930db8f rock-5b-spi-image-g3caf61a44c2-debug.img | ||
+ | 1b83982a5979008b4407552152732156 rkspi_loader.img | ||
Line 69: | Line 99: | ||
=== 3) Flash the SPI flash === | === 3) Flash the SPI flash === | ||
− | Make sure the | + | Make sure the spi flash is available: |
ls /dev/mtdblock* | ls /dev/mtdblock* | ||
It should give <code>/dev/mtdblock0</code> back | It should give <code>/dev/mtdblock0</code> back | ||
− | + | completely clear the spi flash: <i>(be patient the flash can take 5mins)</i> | |
− | + | ||
− | + | ||
− | completely clear the | + | |
sudo dd if=zero.img of=/dev/mtdblock0 | sudo dd if=zero.img of=/dev/mtdblock0 | ||
− | now write you desired bootloader to the | + | check if the flash was successfully cleared |
+ | sudo md5sum /dev/mtdblock0 zero.img | ||
+ | |||
+ | the result should look exactly like this: | ||
+ | 2c7ab85a893283e98c931e9511add182 /dev/mtdblock0 | ||
+ | 2c7ab85a893283e98c931e9511add182 zero.img | ||
+ | |||
+ | |||
+ | now write you desired bootloader to the spi flash <i>(replace <code>spi-image.img</code> with the name of your downloaded image again):</i> | ||
sudo dd if=spi-image.img of=/dev/mtdblock0 | sudo dd if=spi-image.img of=/dev/mtdblock0 | ||
sync | sync | ||
+ | |||
+ | check if the flash was successfully <i>(replace <code>spi-image.img</code> with the name of your downloaded image again):</i> | ||
+ | sudo md5sum /dev/mtdblock0 spi-image.img | ||
+ | the checksums should be the same again - if not <b>flash the bootloader again</b>. | ||
+ | |||
+ | <br> | ||
=== 4) Reboot === | === 4) Reboot === | ||
Line 89: | Line 130: | ||
Now you are done flashing a bootloader supporting NVMe booting. | Now you are done flashing a bootloader supporting NVMe booting. | ||
− | + | <i>If you do not flashed the NVMe already check [[Rock5/install/nvme | this guide]] to flash it. (again there are two options available)</i> | |
Otherwise power off the ROCK 5, remove the µSD card or eMMC module and power it back up. | Otherwise power off the ROCK 5, remove the µSD card or eMMC module and power it back up. | ||
Line 119: | Line 160: | ||
Please check this guide, [[rock5/install/rockchip-flash-tools | Install rockchip flash tools under Windows/Linux/MacOS PC.]] | Please check this guide, [[rock5/install/rockchip-flash-tools | Install rockchip flash tools under Windows/Linux/MacOS PC.]] | ||
− | The PC tools we use to communicate with ROCK 5 in | + | The PC tools we use to communicate with ROCK 5 in maskrom mode are the '''rkdeveloptool''' on Linux/macOS and '''RkDevtool''' on Windows PC. |
=== 2) Get RK3588 loader and U-Boot images === | === 2) Get RK3588 loader and U-Boot images === | ||
Line 136: | Line 177: | ||
[[File:Rock-5b-typec-maskrom.jpeg|400px]] | [[File:Rock-5b-typec-maskrom.jpeg|400px]] | ||
− | To boot ROCK 5B to | + | To boot ROCK 5B to maskrom mode is simple: |
* Power off the board. | * Power off the board. |
Revision as of 15:03, 2 February 2023
ROCK 5 > Installation > Install the bootloader to the SPI NOR flash
ROCK 5 has a SPI flash on the board, it contains the bootloader for backup booting and supports booting other media that the SoC maskrom mode itself does not direct support (such as NVMe, SATA or USB 3).
This page describe how to write/install the bootloader to the SPI flash on the ROCK 5B.
There are two methods available to flash the SPI:
- simple method - flash the SPI from the ROCK 5 itself
- advanced method - flash the SPI with the maskrom mode and an external computer
For advanced users: How to erase the SPI
Contents
- 1 Simple method
- 2 Advanced (external) method
- 3 Addition: erase the SPI NOR flash
- 4 Troubleshooting
Simple method
Requirements
- ROCK 5B with proper power
- SD card or eMMC module
- Linux image for ROCK 5B - (Android images are not supported yet)
Procedure
1) Boot linux from µSD card/eMMC
The first step is to boot the ROCK 5 with linux from an µSD card or an eMMC module.
(check this guide to flash a new image to an µSD card or check this guide to flash a new image to an eMMC module)
2) Download required files on the ROCK 5
You can download files by using wget DOWNLOADLINK
for example to download the file to clear the spi: wget https://dl.radxa.com/rock5/sw/images/others/zero.img.gz
Download the required files
and the latest spi bootloader:
- normal bootloader, recommend for everything except armbian - <7>(for advanced users: this has the u-boot serial console disabled)</i>
- bootloader for armbian (Use this if you like to boot armbian from the M.2 NVME SSD)
or for advanced users the
- debuging bootloader with u-boot serial console enabled (This is an debug bootloader if you need to troubleshoot booting issue with serial)
Check the integrity of the downloaded files:
md5sum zero.img.gz
should give back:
ac581b250fda7a10d07ad11884a16834 zero.img.gz
extract/uncompress the previous downloaded spi clearing file (gzip should already be installed otherwise install it):
gzip -d zero.img.gz
md5sum zero.img
should give back:
2c7ab85a893283e98c931e9511add182 zero.img
and finally check your desired bootloader image: (replace spi-image.img
with the name of your downloaded image - eg: rock-5b-spi-image-g49da44e116d.img
for the normal bootloader):
md5sum spi-image.img
it should give back one of the following lines:
46de85de37b8e670883e6f6a8bb95776 rock-5b-spi-image-g49da44e116d.img 958cbdb6cf9b2e0841fd76c26930db8f rock-5b-spi-image-g3caf61a44c2-debug.img 1b83982a5979008b4407552152732156 rkspi_loader.img
3) Flash the SPI flash
Make sure the spi flash is available:
ls /dev/mtdblock*
It should give /dev/mtdblock0
back
completely clear the spi flash: (be patient the flash can take 5mins)
sudo dd if=zero.img of=/dev/mtdblock0
check if the flash was successfully cleared
sudo md5sum /dev/mtdblock0 zero.img
the result should look exactly like this:
2c7ab85a893283e98c931e9511add182 /dev/mtdblock0 2c7ab85a893283e98c931e9511add182 zero.img
now write you desired bootloader to the spi flash (replace spi-image.img
with the name of your downloaded image again):
sudo dd if=spi-image.img of=/dev/mtdblock0 sync
check if the flash was successfully (replace spi-image.img
with the name of your downloaded image again):
sudo md5sum /dev/mtdblock0 spi-image.img
the checksums should be the same again - if not flash the bootloader again.
4) Reboot
Now you are done flashing a bootloader supporting NVMe booting.
If you do not flashed the NVMe already check this guide to flash it. (again there are two options available)
Otherwise power off the ROCK 5, remove the µSD card or eMMC module and power it back up.
It should boot now from your NVMe. 😉
Advanced (external) method
Requirements
- ROCK 5B with proper power
- Linux image for ROCK 5B, Android image is not supported yet
- SD card or eMMC module
- USB Type C cable
- Windows/linux/macOS PC
Procedure
1) Install Tools & Drivers
Please check this guide, Install rockchip flash tools under Windows/Linux/MacOS PC.
The PC tools we use to communicate with ROCK 5 in maskrom mode are the rkdeveloptool on Linux/macOS and RkDevtool on Windows PC.
2) Get RK3588 loader and U-Boot images
- Download the loader image from:
- RK3588 loader - USB flashing helper
- Download the latest SPI image from:
- release version with u-boot serial console disabled(Recommend)
- debug version with u-boot serial console enabled(Use it when you need to troubleshoot booting issue)
- armbian version (Use it when you need to install the armbian Image to M.2 NVME SSD)
3) Boot the board to Maskrom mode
To boot ROCK 5B to maskrom mode is simple:
- Power off the board.
- Remove bootable device like MicroSD card, eMMC module, etc.
- Press the golden (or silver on some board revisions) button and hold it.
- Plug the USB-A to Type-C cable to ROCK 5B Type-C port, the other side to PC.
- Release the golded button.
- Check usb device
- For macOS host:
lsusb
a result should be:... ID 2207:350b Fuzhou Rockchip Electronics Co., Ltd. Composite Device
- For Linux host:
lsusb
a result should be:... ID 2207:350b Fuzhou Rockchip Electronics Company
- For Windows host: Open RKDevTool and you would see the device is in Found One MASKROM Device
- For macOS host:
4) Write u-boot images to SPI NOR flash or erase SPI NOR flash
Option 1: Flash with Linux PC/Mac
On linux or Mac, run the rkdeveloptool
sudo rkdeveloptool ld DevNo=1 Vid=0x2207,Pid=0x350b,LocationID=106 Maskrom
This will load the loader (flash helper, downloaded from 2) to run on ROCK 5B and init the ram and prepare the flashing environment etc.
sudo rkdeveloptool db /path/to/rk3588_spl_loader_v1.08.111.bin # will output: Downloading bootloader succeeded.
Next, write SPI image from PC/Mac to ROCK 5B SPI flash
You can use the image download from Step 2.
sudo rkdeveloptool wl 0 rock-5b-spi-image-g49da44e116d.img Write LBA from file (100%)
Reboot the device
rkdeveloptool rd
now, the device should boot on SPI Nor Flash. And the blue led is on.
Option 2: Flash with Windows PC
Double click the RKDevTool.exe and you will see the following interface: Double click the RKDevTool.exe and you will see the following interface:
Step 1: confirm that ROCK 5B is in maskrom mode
If your ROCK 5B is in maskrom mode and connects to PC, you can see that the program detects it, as the red arrow below
Step 2: Load Configuration File
Right-click in the list box and select Load Config,Then select the configuration file in the resource management folder(The configuration file and RKDevTool are in the same directory)
Step 3: Select Loader
Next, click the right last columns in the "Loader" row to select rk3588_spl_loader_v1.08.111.bin
Step 4: Select SPI image
Next, click the right last columns in the "spi" row to select spi-image.
Step 5: Excute
Finally, click the "Excute" button, and you will see the content in the red box on the right. When the progress reaches 100%, the download is completed.
Addition: erase the SPI NOR flash
Option 1: Operate on ROCK 5B
Boot your ROCK 5B with linux running on µSD card or eMMC module:
Make sure the SPI flash is available:
ls /dev/mtdblock*
It should give /dev/mtdblock0
back
sudo dd if=/dev/zero of=/dev/mtdblock0 sync
Option 2: Erase with Linux PC/Mac
Please notice that when you want to erase SPI NOR flash, fire these commands. If you don't have zero.img, download this one please. zero.img And extract it.
rkdeveloptool db rk3588_spl_loader_v1.08.111.bin rkdeveloptool wl 0 zero.img rkdeveloptool rd
Option 3: Erase with Windows PC
Before Erasing, please confirm that ROCK 5B is in maskrom mode
Step 1: Download
Choose the "Advanced features" button, then select rk3588_spl_loader_v1.08.111.bin
, next click the "Download" button
Step 2: Erase all
Click the "erase all" button
Step 3: Reboot device
Troubleshooting
- If you have issue with flashing via USB OTG, start a new post on the forum, https://forum.radxa.com/c/rock5.