diff --git a/Orin_Flash/agx_orin_emulation.md b/Orin_Flash/agx_orin_emulation.md new file mode 100644 index 0000000..31c8799 --- /dev/null +++ b/Orin_Flash/agx_orin_emulation.md @@ -0,0 +1,23 @@ +## Emulation with the Jetson AGX Orin Development Kit + +The Orin NX 8GB and 16GB can be emulated during flashing of the Jetson AGX Orin Devkit using this jetson-flash branch: [https://github.com/balena-os/jetson-flash/commits/orin_nx_emulation_on_agx_orin_devkit](https://github.com/balena-os/jetson-flash/commits/orin_nx_emulation_on_agx_orin_devkit) + +An example command for flashing the emulated configuration is: +``` +sudo bin/cmd.js -m jetson-agx-orin-devkit-as-nx-16gb -f +``` + +Important notes on Orin NX emulation: + +- The same Balena AGX Orin Devkit image is used while flashing an emulated Orin NX, thus the cloud will report a Jetson AGX Orin Devkit device type. However, lscpu will report different numbers of CPUs for the emulated devices. Similarly, `cat /proc/device-tree/nvidia,dtsfilename` will report a different device-tree for each configuration. +- For the Orin NX 8GB emulation, after flashing is completed, it's necessary to edit the file /mnt/sysroot/active/current/boot/extlinux/extlinux.conf and add "mem=8G" (unquoted) to the APPEND element, for example: " ... sdhci_tegra.en_boot_part_access=1 rootwait mem=8G". Once the extlinux.conf file is modified and saved, the device should be rebooted for the available RAM configuration to take effect. +- The emulated configuration is used only during provisioning and is not preserved after a host operating system OTA update. +- These configurations should be used for testing purposes only, and they should never be used to provision production devices +- Cloud support for Orin NX machines can only be evaluated after the hardware is available and the upstream Yocto BSP (meta-tegra) adds support for them. + +Depending on the device used, the machine used will be one of: +- jetson-agx-orin-devkit-64-nvme +- jetson-orin-nx-xavier-nx-devkit +- jetson-orin-nano-devkit-nvme +- jetson-orin-nx-seeed-j4012 +- jetson-orin-nano-seeed-j3010 diff --git a/Orin_Flash/images/jetson-agx-orin-devkit-64gb.jpg b/Orin_Flash/images/jetson-agx-orin-devkit-64gb.jpg new file mode 100644 index 0000000..8f3cabd Binary files /dev/null and b/Orin_Flash/images/jetson-agx-orin-devkit-64gb.jpg differ diff --git a/Orin_Flash/images/jetson-agx-orin-devkit-64gb_recovery.jpg b/Orin_Flash/images/jetson-agx-orin-devkit-64gb_recovery.jpg new file mode 100644 index 0000000..bf8e10e Binary files /dev/null and b/Orin_Flash/images/jetson-agx-orin-devkit-64gb_recovery.jpg differ diff --git a/Orin_Flash/images/jetson-orin-nano-seeed-j3010.jpg b/Orin_Flash/images/jetson-orin-nano-seeed-j3010.jpg new file mode 100644 index 0000000..1a53728 Binary files /dev/null and b/Orin_Flash/images/jetson-orin-nano-seeed-j3010.jpg differ diff --git a/Orin_Flash/images/jetson-orin-nx-seeed-j4012.png b/Orin_Flash/images/jetson-orin-nx-seeed-j4012.png new file mode 100644 index 0000000..82734b0 Binary files /dev/null and b/Orin_Flash/images/jetson-orin-nx-seeed-j4012.png differ diff --git a/Orin_Flash/images/jetson-orin-nx-seeed-j4012_recovery.jpg b/Orin_Flash/images/jetson-orin-nx-seeed-j4012_recovery.jpg new file mode 100644 index 0000000..503f69e Binary files /dev/null and b/Orin_Flash/images/jetson-orin-nx-seeed-j4012_recovery.jpg differ diff --git a/Orin_Flash/images/jetson-orin-nx-xavier-nx-devkit.jpg b/Orin_Flash/images/jetson-orin-nx-xavier-nx-devkit.jpg new file mode 100644 index 0000000..5a830b3 Binary files /dev/null and b/Orin_Flash/images/jetson-orin-nx-xavier-nx-devkit.jpg differ diff --git a/Orin_Flash/jetson-agx-orin-devkit-64gb.md b/Orin_Flash/jetson-agx-orin-devkit-64gb.md new file mode 100644 index 0000000..b13f6e9 --- /dev/null +++ b/Orin_Flash/jetson-agx-orin-devkit-64gb.md @@ -0,0 +1,67 @@ + +# Instructions for the Jetson AGX Orin Devkit 64GB + + + +These are the flashing instructions for the [Jetson AGX Orin Developer Kit 64GB](https://www.nvidia.com/en-us/autonomous-machines/embedded-systems/jetson-orin/). For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 6.0.6 or later | 36.3 | 6.0 | You are on the correct version. (v0.5.77 or greater) | + + +## Requirements +- Docker needs to be installed on the x86 Host PC and the Docker image needs to be run as privileged +- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. +- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualized environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB +- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. + +## Jetson AGX Orin Devkit 64GB Flashing steps: + +NOTE: By default, balenaOS is flashed on the Jetson AGX Orin 64GB Devkit's eMMC; You can change the default using the instructions below. + +1. Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using [Etcher](https://www.balena.io/etcher). +2. If you would like to flash and boot from a NVME drive instead of the eMMC, please follow these steps: + 1. After writing your balenaOS image to the USB key, mount the flash-rootA partition of the USB stick and open the file `etc/resin-init-flasher.conf` located in it. + 2. The first line of this file is `INTERNAL_DEVICE_KERNEL="mmcblk0"`. Replace `mmcblk0` with `nvme0n1`, save and close the file. + 3. Ensure the flash-rootA partition is unmounted before removing the USB key from your PC. + 4. IMPORTANT: Flashing balenaOS on the NVME will erase the contents of the device's eMMC as well. Please make sure to back-up your data. +3. Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder +4. Put the AGX Orin Devkit 64GB in Force Recovery mode: + 1. Make sure you connect the Type-C plug of the data cable to the USB Type-C port used for flashing, which is located next to 40-pin connector. + 2. While holding the middle Force Recovery button, insert the USB Type-C power supply plug into the USB Type-C port above the DC jack. + 3. This will turn on the Jetson dev kit in Force Recovery Mode. + 4. Release the middle Force Recovery button + 5. Confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and you should see output similar to: `Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX` (The APX is important) +5. Insert the USB stick created above in the upper USB port located near the the display port of the AGX Orin Devkit 64GB. +6. Clone this repo on your host PC. +7. Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: +``` +~/jetson-flash$ cd Orin_Flash/ +~/jetson-flash/Orin_Flash$ ./build_and_run.sh +``` +8. Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: +``` +root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-agx-orin-devkit-64gb +``` + +Other considerations: +- The flashing process takes around 5-10 minutes and once it completes, the board will power-off. The device can be taken out of recovery mode and the USB flasher stick can be unplugged. +- Remove and reconnect power to the device. + +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/Orin_Flash/jetson-orin-nano-devkit-nvme.md b/Orin_Flash/jetson-orin-nano-devkit-nvme.md new file mode 100644 index 0000000..fd329d0 --- /dev/null +++ b/Orin_Flash/jetson-orin-nano-devkit-nvme.md @@ -0,0 +1,61 @@ + +# Instructions for the Jetson Orin Nano 8GB (SD) Devkit NVME + + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 5.3.22 or later | 36.3 | 6.0 | You are on the correct version. (v0.5.73 or greater) | +| 5.3.12 - 5.3.21 | 35.5.0 | 5.1.3 | [v0.5.72](https://github.com/balena-os/jetson-flash/tree/v0.5.72) | +| 4.1.5 - 5.3.10 | 35.4.1 | 5.1.2 | [v0.5.67](https://github.com/balena-os/jetson-flash/tree/v0.5.67) | +| 2.115.18 - 4.1.2 | 35.3.1 | 5.1.1 | [v0.5.57](https://github.com/balena-os/jetson-flash/tree/v0.5.57) | + + +## Requirements +- Docker needs to be installed on the x86 Host PC and the Docker image needs to be run as privileged +- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. +- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualized environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB +- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. + +### Jetson Orin Nano 8GB (SD) Devkit NVME Flashing steps: + +1. Attach a NVME drive to the Orin Nano Devkit +2. Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. +3. Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder +4. Put the Jetson Orin Nano in Force Recovery mode: + 1. Ensure the device is powered off and the power adapter disconnected. Enable Force Recovery mode by placing a jumper across the "FC REC" and "GND" pins located on the edge of the carrier board, under the Jetson Orin Nano module. + 2. Connect your host computer to the device's USB-C connector. + 3. Connect the power adapter to the Power Jack. + 4. The device will automatically power on in Force Recovery Mode. + 5. Confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and you should see output similar to: `Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX` (The APX is important) +5. Insert the USB stick created above in the upper USB port located near the the display port of the Orin Nano Devkit +6. Clone this repo to your host PC. +7. Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: +``` +~/jetson-flash$ cd Orin_Flash/ +~/jetson-flash/Orin_Flash$ ./build_and_run.sh +``` +8. Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: +``` +root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nano-devkit-nvme +``` + +Other considerations: +- The flashing process takes around 5-10 minutes and once it completes, the board will power-off. The device can be taken out of recovery mode and the USB flasher stick can be unplugged. +- Remove and reconnect power to the device. + +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/Orin_Flash/jetson-orin-nano-seeed-j3010.md b/Orin_Flash/jetson-orin-nano-seeed-j3010.md new file mode 100644 index 0000000..c783b07 --- /dev/null +++ b/Orin_Flash/jetson-orin-nano-seeed-j3010.md @@ -0,0 +1,61 @@ +# Instructions for the Seeed reComputer J3010 4GB + + + +These are the flashing instructions for the [Seeed J3010](https://www.seeedstudio.com/reComputer-J3010-p-5589.html) Edge AI Computer with NVIDIA® Jetson™ Orin™ Nano 4GB. [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions) for the list of other supported Jetson devices. + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 5.3.22 or later | 36.3 | 6.0 | You are on the correct version. (v0.5.75 or greater) | +| 5.3.12 - 5.3.21 | 35.5.0 | 5.1.3 | [v0.5.74](https://github.com/balena-os/jetson-flash/tree/v0.5.74) | + + +## Requirements +- Docker needs to be installed on the x86 Host PC and the Docker image needs to be run as privileged +- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. +- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualized environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB +- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. + +### Seeed reComputer J3010 Flashing steps: + +1. Ensure a NVME drive is attached to the Seeed reComputer J3010 +2. Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. +3. Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder +4. Put the Seeed reComputer J3010 in Force Recovery mode: + 1. Ensure the device is powered off and the power adapter disconnected. + 2. Open the top lid of the reComputer and place a jumper across the Force Recovery Mode pins. These are pins ("GND") and ("FC REC") and are located on the carrier board, under the Orin Nano module. + 3. Connect your host computer to the device's USB-C connector. + 4. Connect the power adapter to the Power Jack [J2]. + 5. The device will automatically power on in Force Recovery Mode. + 6. Confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and you should see output similar to: `Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX` (The APX is important) +5. Insert the USB stick created above in any of the USB ports of the Seeed reComputer J3010 Flashing +6. Clone this repo to your host PC. +7. Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: +``` +~/jetson-flash$ cd Orin_Flash/ +~/jetson-flash/Orin_Flash$ ./build_and_run.sh +``` +8. Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: +``` +root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nano-seeed-j3010 +``` + +Other considerations: +- The flashing process takes around 5-10 minutes and once it completes, the board will power-off. The device can be taken out of recovery mode and the USB flasher stick can be unplugged. +- Remove and reconnect power to the device. + +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/Orin_Flash/jetson-orin-nx-seeed-j4012.md b/Orin_Flash/jetson-orin-nx-seeed-j4012.md new file mode 100644 index 0000000..4a14480 --- /dev/null +++ b/Orin_Flash/jetson-orin-nx-seeed-j4012.md @@ -0,0 +1,61 @@ + +# Instructions for the Seeed reComputer J4012 16GB + + + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 5.3.22 or later | 36.3 | 6.0 | You are on the correct version. (v0.5.75 or greater) | +| 5.3.12 - 5.3.21 | 35.5.0 | 5.1.3 | [v0.5.74](https://github.com/balena-os/jetson-flash/tree/v0.5.74) | +| 5.1.8 - 5.3.10 | 35.4.1 | 5.1.2 | [v0.5.67](https://github.com/balena-os/jetson-flash/tree/v0.5.67) | + +## Requirements +- Docker needs to be installed on the x86 Host PC and the Docker image needs to be run as privileged +- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. +- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualized environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB +- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. + +### Seeed reComputer J4012 Flashing steps: + +1. Ensure a NVME drive is attached to the Seeed reComputer J4012 +2. Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. +3. Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder +4. Put the Seeed reComputer J4012 in Force Recovery mode: + 1. Ensure the device is powered off and the power adapter disconnected. + 2. Open the top lid of the reComputer and place a jumper across the Force Recovery Mode pins. These are pins ("GND") and ("FC REC") and are located on the carrier board, under the Orin NX module. + 3. Connect your host computer to the device's USB-C connector. + 4. Connect the power adapter to the Power Jack [J2]. + 5. The device will automatically power on in Force Recovery Mode. + 6. Confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and you should see output similar to: `Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX` (The APX is important) +5. Insert the USB stick created above in any of the USB ports of the Seeed reComputer J4012 Flashing +6. Clone this repo to your host PC. +7. Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: +``` +~/jetson-flash$ cd Orin_Flash/ +~/jetson-flash/Orin_Flash$ ./build_and_run.sh +``` +8. Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: +``` +root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nx-seeed-j4012 +``` + +Other considerations: +- The flashing process takes around 5-10 minutes and once it completes, the board will power-off. The device can be taken out of recovery mode and the USB flasher stick can be unplugged. +- Remove and reconnect power to the device. + +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/Orin_Flash/jetson-orin-nx-xavier-nx-devkit.md b/Orin_Flash/jetson-orin-nx-xavier-nx-devkit.md new file mode 100644 index 0000000..b89e769 --- /dev/null +++ b/Orin_Flash/jetson-orin-nx-xavier-nx-devkit.md @@ -0,0 +1,65 @@ + +# Instructions for the Jetson Orin NX in Xavier NX Devkit NVME + + + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 5.3.22 or later | 36.3 | 6.0 | You are on the correct version. (v0.5.73 or greater) | +| 5.3.12 - 5.3.21 | 35.5.0 | 5.1.3 | [v0.5.72](https://github.com/balena-os/jetson-flash/tree/v0.5.72) | +| 4.1.5 - 5.3.10 | 35.4.1 | 5.1.2 | [v0.5.67](https://github.com/balena-os/jetson-flash/tree/v0.5.67) | +| 2.115.18 - 4.1.2 | 35.3.1 | 5.1.1 | [v0.5.57](https://github.com/balena-os/jetson-flash/tree/v0.5.57) | +| 2.114.0 - 2.115.13 | 35.2.1 | 5.1 | [0.5.49](https://github.com/balena-os/jetson-flash/tree/v0.5.49) | + + +## Requirements +- Docker needs to be installed on the x86 Host PC and the Docker image needs to be run as privileged +- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. +- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualized environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB +- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. + +### Jetson Orin NX in Xavier NX Devkit NVME Flashing steps: + + +1. Attach a NVMe drive to the Xavier NX Devkit +2. Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. +3. Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder +4. Put the Jetson Orin NX in Force Recovery mode: + 1. Ensure the device is powered off and the power adapter disconnected. + 2. Place a jumper across the Force Recovery Mode pins. These are pins 9 ("GND") and 10 ("FC REC") of the Button Header (J14). + 3. Connect your host computer to the device's USB Micro-B connector. + 4. Connect the power adapter to the Power Jack [J16]. + 5. The device will automatically power on in Force Recovery Mode. + 6. Confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and you should see output similar to: `Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX` (The APX is important) +5. Insert the USB stick created above in any of the 4 USB ports of the Xavier NX Devkit +6. Clone this repo to your host PC. +7. Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: +``` +~/jetson-flash$ cd Orin_Flash/ +~/jetson-flash/Orin_Flash$ ./build_and_run.sh +``` +7. Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: +``` +root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nx-xavier-nx-devkit + +``` + +Other considerations: +- The flashing process takes around 5-10 minutes and once it completes, the board will power-off. The device can be taken out of recovery mode and the USB flasher stick can be unplugged. +- Remove and reconnect power to the device. + +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/README.md b/README.md index d4d5725..419dbf0 100644 --- a/README.md +++ b/README.md @@ -1,447 +1,42 @@ # jetson-flash +A set of tools that allows users to flash balenaOS on supported Jetson devices. -This tool allows users to flash balenaOS on supported Jetson devices: - -|Device | balena machine name | L4T version | Provisioning method | -|-------|---------------------|-------------|---------------------| -|Jetson Nano eMMC | jetson-nano-emmc | L4T 32.7.3 | jetson-flash | -|Jetson Nano SD-CARD Devkit | jetson-nano | L4T 32.7.3 | jetson-flash | -|Jetson Nano 2GB Devkit | jetson-nano-2gb-devkit | L4T 32.7.1 | jetson-flash | -|Jetson TX2 | jetson-tx2 | L4T 32.7.3 | jetson-flash | -|Jetson TX2 NX (in Jetson Xavier NX Devkit) | jetson-tx2-nx-devkit | L4T 32.7.3 | jetson-flash | -|Jetson AGX Xavier | jetson-xavier | L4T 32.7.3 | jetson-flash | -|Jetson Xavier NX Devkit eMMC | jetson-xavier-nx-devkit-emmc | L4T 32.7.3 | jetson-flash | -|Jetson Xavier NX Devkit SD-CARD | jetson-xavier-nx-devkit | L4T 32.7.3 | jetson-flash | -|Jetson AGX Orin Devkit 32GB | jetson-agx-orin-devkit | L4T 36.3 | jetson-flash | -|Jetson AGX Orin Devkit 64GB | jetson-agx-orin-devkit-64gb | L4T 36.3 | [RCM-Boot script + USB Key](#agx-orin-devkit-64gb-flashing) | -|Jetson Orin Nano 8GB (SD) Devkit NVME | jetson-orin-nano-devkit-nvme | L4T 36.3 | [RCM-Boot script + USB Key](#orin-nano-flashing) | -|Jetson Orin NX in Xavier NX Devkit NVME | jetson-orin-nx-xavier-nx-devkit | L4T 36.3 | [RCM-Boot script + USB Key](#orin-nx-flashing) | -|Seeed reComputer J3010 | jetson-orin-nano-seeed-j3010 | L4T 36.3 | [RCM-Boot script + USB Key](#seeed-recomputer-j3010-flashing) | -|Seeed reComputer J4012 16GB | jetson-orin-nx-seeed-j4012 | L4T 36.3 | [RCM-Boot script + USB Key](#seeed-recomputer-j4012-flashing) | - -## IMPORTANT -- The Jetson Orin NX cannot be flashed trough Jetson-Flash, instead a separate container image is used as detaled below in the [Orin NX Flashing](#orin-nx-flashing) section. - The same applies for the Orin Nano Devkit NVME, Seeed reComputer J3010 and J4012 as well as for the AGX Orin 64GB Devkit -- For the latest Jetson Orin and Seeed reComputer production images older than balenaOS v6.0 downloaded from balena-cloud, please use [v0.5.72](https://github.com/balena-os/jetson-flash/commit/fc1904907391f4bb1a8599a477910bcaea932e5e) for provisioning. -- Production OS images for Jetson Orin and Seeed reComputer devices on versions lower than balenaOS v6.0 are based on L4T 35.5.0 - Jetpack 5. OS versions newer than v6.0 as well as draft releases starting with v5.3.23 are based on L4T 36.3 and should be flashed using this repository at [v0.5.73](https://github.com/balena-os/jetson-flash) or newer. - + ## About -Jetson Flash will extract the balenaOS image from a downloaded provisioned image (such as from balenaCloud) and then flashes that image to a Jetson board connected to a host PC via USB. - -This tool invokes NVIDIA’s proprietary software to properly partition the eMMC and place the required balenaOS software in the necessary location to make it bootable. Even on Jetson boards without eMMC, this tool may be necessary to initially flash balenaOS because of the way JetPack uses onboard QSPI flash memory for the bootloader. (In those cases, this tool can write to the QSPI so the device will be able to boot balenaOS from the SD card.) - -NOTES: -- The USB flashing method for the Jetson TX2 is an alternative to SD-CARD provisioning, and can also be used to re-flash TX2s that cannot boot normally due to corrupt QSPI firmware. -- For the Jetson-TX2 flasher image only, the system-proxy directory entries are not copied over by jetson-flash. -- If flashing Jetson TX2 with a BalenaOS image older than 2.47, please checkout tag 'v0.3.0'. BalenaOS 2.47 updated L4T version from 28.3 to 32.4.2. -- Current BSP version used for flashing each device type is listed above. Please ensure the balenaOS version you are flashing uses the same L4T, by consulting the changelog available in the [BalenaOS Jetson repository](https://github.com/balena-os/balena-jetson/commits/master). -- Jetson Flash v0.5.10 should be used for flashing devices on L4T 32.4.4. -- The L4T BSP archive is automatically downloaded by the tool during flashing and the L4T version is already updated to match the latest balena-cloud image version. -- balenaOS images for Jetson Orin devices at v5.3.21, v5.3.21+rev1, v5.3.21+rev2 and v5.3.21+rev3 are based on L4T 35.5.0. -- balenaOS images for Jetson Orin devices at versions greater than v5.3.23 are based on L4T 36.3 - Jetpack 6. - - -## Software required -Jetson Flash requires a Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). - -You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. - -### non-Docker - -Prerequisites: - -- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) -- [NodeJS](https://nodejs.org) -- Make sure you have python2 installed and that the `python` binary points to python2. -- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 - -Installation: - -Make sure the prerequesites listed above are installed. - -Clone this repository: -```sh -$ git clone https://github.com/balena-os/jetson-flash.git -``` - -Install Node.js dependencies by issuing the following command in the jetson-flash directory: -```sh -$ npm install -``` - -### Docker - -Prerequisites: - -- the Docker image should be run as privileged -- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device - -## How to use - -Follow the steps below to flash your Jetson board - -### Recovery mode - -Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. - -**Jetson Nano:** - -With power off, enable Force Recovery mode by placing a jumper across the "FRC" pins of the Button Header on the carrier board. - -- For carrier board revision A02, these are pins 3 ("FC REC") and 4 ("GND") of Button Header J40 which is located near the camera header. -- For carrier board revision B01, (and the Nano 2GB) these are pins 9 ("GND") and 10 ("FC REC") of Button Header J12, which is located on the edge of the carrier board under the Jetson module. - -Then power on the device. - -**Jetson Orin Nano Devkit NVME :** - -1. Ensure the device is powered off and the power adapter disconnected. Enable Force Recovery mode by placing a jumper across the "FC REC" and "GND" pins located on the edge of the carrier board, under the Jetson Orin Nano module. -2. Connect your host computer to the device's USB-C connector. -3. Connect the power adapter to the Power Jack. -4. The device will automatically power on in Force Recovery Mode. - -**Jetson TX2:** - -1. Power down the device, removing the AC adapter. -2. Connect the Micro-B plug on the USB cable to the Recovery (USB Micro-B) Port on the device and the other end to an available USB port on the host PC. -3. Connect the power adapter to the device. -4. With the system powered on: -- Press and hold the RECOVERY FORCE button. -- While depressing the RECOVERY FORCE button, press and release the RESET button. -- Wait 2 seconds and release the RECOVERY FORCE button. - -**Jetson AGX Xavier:** - -1. Connect the developer kit as described above. It should be powered off. -2. Press and hold down the Force Recovery button. -3. Press and hold down the Power button.Signed-off-by: Alexandru Costache ") and the desired device type (from the "balena machine name" in the table above, in place of ""): - -```sh -$ ./bin/cmd.js -f -m -``` - -For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container(building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. - -```sh -./build.sh [-m /bin/bash` - -Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of "") and the desired device type (from the "balena machine name" in the table above, in place of ""):: - -```sh -./bin/cmd.js -f /data/images/ -m --accept-license=yes -c /tmp/Linux_for_Tegra -``` - -You can alternatively just run the jetson-flash tool in a single command by running the container with this command: - -```sh -docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m --accept-license=yes -c /tmp/Linux_for_Tegra -``` - -It will exit upon completion. - ---- - -The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: - -``` -*** The target t186ref has been flashed successfully. *** -Reset the board to boot from internal eMMC. - -``` - -## Emulation with the Jetson AGX Orin Development Kit - -The Orin NX 8GB and 16GB can be emulated during flashing of the Jetson AGX Orin Devkit using this jetson-flash branch: [https://github.com/balena-os/jetson-flash/commits/orin_nx_emulation_on_agx_orin_devkit](https://github.com/balena-os/jetson-flash/commits/orin_nx_emulation_on_agx_orin_devkit) - -An example command for flashing the emulated configuration is: -``` -sudo bin/cmd.js -m jetson-agx-orin-devkit-as-nx-16gb -f -``` - -Important notes on Orin NX emulation: - -- The same Balena AGX Orin Devkit image is used while flashing an emulated Orin NX, thus the cloud will report a Jetson AGX Orin Devkit device type. However, lscpu will report different numbers of CPUs for the emulated devices. Similarly, `cat /proc/device-tree/nvidia,dtsfilename` will report a different device-tree for each configuration. -- For the Orin NX 8GB emulation, after flashing is completed, it's necessary to edit the file /mnt/sysroot/active/current/boot/extlinux/extlinux.conf and add "mem=8G" (unquoted) to the APPEND element, for example: " ... sdhci_tegra.en_boot_part_access=1 rootwait mem=8G". Once the extlinux.conf file is modified and saved, the device should be rebooted for the available RAM configuration to take effect. -- The emulated configuration is used only during provisioning and is not preserved after a host operating system OTA update. -- These configurations should be used for testing purposes only, and they should never be used to provision production devices -- Cloud support for Orin NX machines can only be evaluated after the hardware is available and the upstream Yocto BSP (meta-tegra) adds support for them. - -## Orin NX Flashing: - -Important notes on Orin NX provisioning: - -- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualised environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB -- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. -- The current Orin NX balenaOS images v5.3.21, v5.3.21+rev1, v5.3.21+rev2 and v5.3.21+rev3 are based on L4T 35.5.0 -- Draft balenaOS releases at v5.3.21+rev4 or newer are based on L4T 36.3 - Jetpack 6 -- Flashing of the Orin NX module in a Xavier NX Devkit carrier board with a NVME attached can be done solely by using the Docker image inside the Orin_Flash folder. The Dockerfile and the scripts inside this folder are not used by jetson-flash and should be used as a stand-alone means for flashing BalenaOS on the Orin NX and the attached NVME. -- Docker needs to be installed on the Host PC and the Docker image needs to be run as privileged -- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. - -### Orin NX Flashing steps: - -- Attach a NVME drive to the Xavier NX Devkit -- Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. -- Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder -- Put the Jetson Orin NX in Force Recovery mode -- Insert the USB stick created above in any of the 4 USB ports of the Xavier NX Devkit -- Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: -``` -~/jetson-flash$ cd Orin_Flash/ -~/jetson-flash/Orin_Flash$ ./build_and_run.sh -``` -- Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: -``` -root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nx-xavier-nx-devkit -``` - -## AGX Orin Devkit 64GB Flashing: - -Important notes on AGX Orin Devkit 64GB provisioning: - -- By default, balenaOS is flashed on the Jetson AGX Orin 64GB Devkit's eMMC -- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualised environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB -- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. -- balenaOS releases for this device type are based on L4T 36.3 - Jetpack 6 -- Flashing of the AGX Orin Devkit 64GB with a NVME attached can be done solely by using the Docker image inside the Orin_Flash folder. The Dockerfile and the scripts inside this folder are not used by jetson-flash and should be used as a stand-alone means for flashing BalenaOS on the AGX Orin Devkit 64GB and the attached NVME. -- Docker needs to be installed on the Host PC and the Docker image needs to be run as privileged -- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. - -### AGX Orin Devkit 64GB flashing steps: - -- Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. -- If you would like to flash and boot from a NVME drive instead of the eMMC, please follow these steps: - - After writing your balenaOS image to the USB key, mount the flash-rootA partition of the USB stick and open the file `etc/resin-init-flasher.conf` located in it - - The first line of this file is `INTERNAL_DEVICE_KERNEL="mmcblk0"`. Replace `mmcblk0` with `nvme0n1`, save and close the file - - Ensure the flash-rootA partition is unmounted before removing the USB key from your PC - - IMPORTANT: Flashing balenaOS on the NVME will erase the contents of the device's eMMC as well. Please make sure to back-up your data -- Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder -- Put the AGX Orin Devkit 64GB in Force Recovery mode -- Insert the USB stick created above in the upper USB port located near the the display port of the AGX Orin Devkit 64GB -- Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: -``` -~/jetson-flash$ cd Orin_Flash/ -~/jetson-flash/Orin_Flash$ ./build_and_run.sh -``` -- Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: -``` -root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-agx-orin-devkit-64gb -``` - -## Orin Nano Flashing: - -Important notes on Orin Nano provisioning: - -- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualised environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson device successfully over USB -- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. -- The latest Orin Nano balenaOS images v5.3.21, v5.3.21+rev1, v5.3.21+rev2 and v5.3.21+rev3 are based on L4T 35.5.0 -- Draft balenaOS releases at v5.3.21+rev4 or newer are based on L4T 36.3 - Jetpack 6 -- Flashing of the Orin Nano Devkit with a NVME attached can be done solely by using the Docker image inside the Orin_Flash folder. The Dockerfile and the scripts inside this folder are not used by jetson-flash and should be used as a stand-alone means for flashing BalenaOS on the Orin Nano and the attached NVME. -- Docker needs to be installed on the Host PC and the Docker image needs to be run as privileged -- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. - -### Orin Nano Flashing steps: - -- Attach a NVME drive to the Orin Nano Devkit -- Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. -- Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder -- Put the Jetson Orin Nano in Force Recovery mode -- Insert the USB stick created above in the upper USB port located near the the display port of the Orin Nano Devkit -- Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: -``` -~/jetson-flash$ cd Orin_Flash/ -~/jetson-flash/Orin_Flash$ ./build_and_run.sh -``` -- Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: -``` -root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nano-devkit-nvme -``` - -## Seeed reComputer J3010 Flashing: - -- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 24.04. Other host operating systems or virtualised environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson module successfuly over USB -- The current Seeed reComputer J3010 image is based on L4T 35.5.0 -- Flashing of the Seeed reComputer J3010 with a NVME attached can be done solely by using the Docker image inside the Orin_Flash folder. The Dockerfile and the scripts inside this folder are not used by jetson-flash and should be used as a stand-alone means for flashing BalenaOS on the Seeed reComputer J3010 and the NVME attached to the carrier board. -- Docker needs to be installed on the Host PC and the Docker image needs to be run as privileged -- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. - -### Seeed reComputer J3010 Flashing steps: - -- Ensure a NVME drive is attached to the Seeed reComputer J3010 -- Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. -- Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder -- Put the Seeed reComputer J3010 in Force Recovery mode by connecting the FC REC and GND pins with a jumper cable. The pins are located on the carrier board, under the Jetson Orin NX module -- Insert the USB stick created above in any of the USB ports of the Seeed reComputer J3010 Flashing -- Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: -``` -~/jetson-flash$ cd Orin_Flash/ -~/jetson-flash/Orin_Flash$ ./build_and_run.sh -``` -- Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin.sh` script: -``` -root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nano-seeed-j3010 -``` - -## Seeed reComputer J4012 Flashing: - -- The Docker image and the associated scripts require a Linux-based host and have been validated on a PC running Ubuntu 22.04. Other host operating systems or virtualised environments may also work, provided that the Nvidia BSP flashing tools are able to communicate with the Jetson module successfully over USB -- We don't formally test Ubuntu 22.04 in VMWare virtual machines, but it seem to work. More specifically, with VMWare Fusion for Mac and VMWare Workstation for Windows. Note: when prompted by VMWare choose to automatically connect the NVIDIA Corp. APX USB device (i.e. the Orin device) to the VM rather than to the host. -- The current Seeed reComputer J4012 image is based on L4T 35.5.0 -- Flashing of the Seeed reComputer J4012 with a NVME attached can be done solely by using the Docker image inside the Orin_Flash folder. The Dockerfile and the scripts inside this folder are not used by jetson-flash and should be used as a stand-alone means for flashing BalenaOS on the Seeed reComputer J4012 and the NVME attached to the carrier board. -- Docker needs to be installed on the Host PC and the Docker image needs to be run as privileged -- The balenaOS image downloaded from balena-cloud needs to be unpacked and copied on your Host PC inside the `~/images/` folder. This location will be bind mounted inside the running container. - -### Seeed reComputer J4012 Flashing steps: - -- Ensure a NVME drive is attached to the Seeed reComputer J4012 -- Download your balenaOS image from balena-cloud, unpack and write it to a USB stick. We recommend using Etcher. -- Place the balenaOS unpacked image inside the folder ~/images on your HOST PC. This location will be automatically bind-mounted in the container image in the `/data/images/` folder -- Put the Seeed reComputer J4012 in Force Recovery mode by connecting the FC REC and GND pins with a jumper cable. The pins are located on the carrier board, under the Jetson Orin NX module -- Insert the USB stick created above in any of the USB ports of the Seeed reComputer J4012 Flashing -- Navigate to the `Orin_Flash` folder and run the Docker image by executing the `build_and_run.sh` script: -``` -~/jetson-flash$ cd Orin_Flash/ -~/jetson-flash/Orin_Flash$ ./build_and_run.sh -``` -- Once the docker image has been built and starts running, the balenaOS kernel and flasher image can be booted by executing the `flash_orin_nx.sh` script: -``` -root@03ce5cbcbb0d:/usr/src/app/orin-flash# ./flash_orin.sh -f /data/images/ -m jetson-orin-nx-seeed-j4012 -``` - - - -Depending on the device used, the machine used will be one of: -- jetson-agx-orin-devkit-64-nvme -- jetson-orin-nx-xavier-nx-devkit -- jetson-orin-nano-devkit-nvme -- jetson-orin-nx-seeed-j4012 -- jetson-orin-nano-seeed-j3010 - - -Other considerations: -- The flashing process takes around 5-10 minutes and once it completes, the board will power-off. The device can be taken out of recovery mode and the USB flasher stick can be unplugged. -- Remove and reconnect power to the device. - -## Support - -If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub and the balena.io team will be happy to help. - -Submitting changes ------------------- - -Changes can be submitted in form of PRs to this repository, each PR may include multiple commits. - -The header of each commit must not exceed 72 characters in length and must be in 1 line only. - -The header and the subject of each commit must be separated by an empty line. - -The subject of each commit must not exceed 72 characters per line and can be wrapped to several lines. - -The subject and the footer of each commit must be separated by an empty line. - -Every pull request must contain at least one commit annotated with the Change-type footer, and all commits should include a Signed-off-by. - -An example of a valid commit is: - -``` -Update Xavier AGX to L4T 32.7.3 - -Change-type: patch -Signed-off-by: Your Name -``` - +Jetson Flash will extract the balenaOS image from a downloaded provisioned image (such as from balenaCloud) and then flash that image to a Jetson board connected to a host PC via USB. + +This tool invokes NVIDIA’s proprietary software to properly partition the boot media (such as eMMC) and place the required balenaOS software in the necessary location to make it bootable. Even on Jetson boards without eMMC, this tool may be necessary to initially flash balenaOS because of the way JetPack uses onboard QSPI flash memory for the bootloader. (In those cases, this tool can write to the QSPI so the device will be able to boot balenaOS from the SD card.) + +## Instructions + +Choose your device from the list below for step-by-step instructions: + +|Device | Current L4T version | +|-------|---------------------| +|[Jetson Nano eMMC](jetson-nano-emmc.md) | L4T 32.7.3 | +|[Jetson Nano SD-CARD Devkit](jetson-nano.md) | L4T 32.7.3 | +|[Jetson Nano 2GB Devkit](jetson-nano-2gb-devkit.md) | L4T 32.7.1 | +|[Jetson TX2](jetson-tx2.md) | L4T 32.7.3 | +|[Jetson TX2 NX (in Jetson Xavier NX Devkit)](jetson-tx2-nx-devkit.md) | L4T 32.7.3 | +|[Jetson AGX Xavier](jetson-xavier.md) | L4T 32.7.3 | +|[Jetson Xavier NX Devkit eMMC](jetson-xavier-nx-devkit-emmc.md) | L4T 32.7.3 | +|[Jetson Xavier NX Devkit SD-CARD](jetson-xavier-nx-devkit.md) | L4T 32.7.3 | +|[Jetson AGX Orin Devkit 32GB](jetson-agx-orin-devkit.md) | L4T 36.3 | +|[Jetson AGX Orin Devkit 64GB](https://github.com/balena-os/jetson-flash/blob/alanb-documentation/Orin_Flash/jetson-agx-orin-devkit-64gb.md) | L4T 36.3 | +|[Jetson Orin Nano 8GB (SD) Devkit NVME](https://github.com/balena-os/jetson-flash/blob/alanb-documentation/Orin_Flash/jetson-orin-nano-devkit-nvme.md) | L4T 36.3 | +|[Jetson Orin NX in Xavier NX Devkit NVME](https://github.com/balena-os/jetson-flash/blob/alanb-documentation/Orin_Flash/jetson-orin-nx-xavier-nx-devkit.md) | L4T 36.3 | +|[Seeed reComputer J3010 4GB](https://github.com/balena-os/jetson-flash/blob/alanb-documentation/Orin_Flash/jetson-orin-nano-seeed-j3010.md) | L4T 36.3 | +|[Seeed reComputer J4012 16GB](https://github.com/balena-os/jetson-flash/blob/alanb-documentation/Orin_Flash/jetson-orin-nx-seeed-j4012.md) | L4T 36.3 | + +**Don't see your device listed?** +- Use the closest match above to the Jetson module on your carrier board +- Reach out to us on the [balena Forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) + License ------- The project is licensed under the Apache 2.0 license. + +Photo by Mélody P on Unsplash + diff --git a/flash.jpg b/flash.jpg new file mode 100644 index 0000000..6cf2d46 Binary files /dev/null and b/flash.jpg differ diff --git a/images/jetson-nano-2gb-devkit.png b/images/jetson-nano-2gb-devkit.png new file mode 100644 index 0000000..9d0a6c6 Binary files /dev/null and b/images/jetson-nano-2gb-devkit.png differ diff --git a/images/jetson-nano-2gb-devkit_rec.png b/images/jetson-nano-2gb-devkit_rec.png new file mode 100644 index 0000000..c15f3e0 Binary files /dev/null and b/images/jetson-nano-2gb-devkit_rec.png differ diff --git a/images/jetson-nano-emmc.jpg b/images/jetson-nano-emmc.jpg new file mode 100644 index 0000000..8793444 Binary files /dev/null and b/images/jetson-nano-emmc.jpg differ diff --git a/images/jetson-nano.png b/images/jetson-nano.png new file mode 100644 index 0000000..42a4220 Binary files /dev/null and b/images/jetson-nano.png differ diff --git a/images/jetson-nano_rec.png b/images/jetson-nano_rec.png new file mode 100644 index 0000000..2cb2862 Binary files /dev/null and b/images/jetson-nano_rec.png differ diff --git a/images/jetson-tx2-nx-devkit.png b/images/jetson-tx2-nx-devkit.png new file mode 100644 index 0000000..9c5de1d Binary files /dev/null and b/images/jetson-tx2-nx-devkit.png differ diff --git a/images/jetson-tx2.png b/images/jetson-tx2.png new file mode 100644 index 0000000..8de1098 Binary files /dev/null and b/images/jetson-tx2.png differ diff --git a/images/jetson-tx2_rec.png b/images/jetson-tx2_rec.png new file mode 100644 index 0000000..df3bdc1 Binary files /dev/null and b/images/jetson-tx2_rec.png differ diff --git a/images/jetson-xavier.jpg b/images/jetson-xavier.jpg new file mode 100644 index 0000000..56a9aa1 Binary files /dev/null and b/images/jetson-xavier.jpg differ diff --git a/jetson-agx-orin-devkit.md b/jetson-agx-orin-devkit.md new file mode 100644 index 0000000..e6e3c63 --- /dev/null +++ b/jetson-agx-orin-devkit.md @@ -0,0 +1,151 @@ +# Instructions for the Jetson AGX Orin Devkit 32GB + + + +These are the flashing instructions for the Jetson AGX Orin Devkit 32GB. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 5.3.22 or later | 36.3 | 6.0 | You are on the correct version. (v0.5.73 or greater) | +| 5.3.12 - 5.3.21 | 35.5.0 | 5.1.3 | [v0.5.72](https://github.com/balena-os/jetson-flash/tree/v0.5.72) | +| 4.1.5 - 5.3.10 | 35.4.1 | 5.1.2 | [v0.5.67](https://github.com/balena-os/jetson-flash/tree/v0.5.67) | +| 2.115.18 - 4.1.2 | 35.3.1 | 5.1.1 | [v0.5.57](https://github.com/balena-os/jetson-flash/tree/v0.5.57) | +| 2.113.32 - 2.115.13 | 35.2.1 | 5.1 | [0.5.48](https://github.com/balena-os/jetson-flash/tree/v0.5.48) | +| 2.105.11 - 2.113.31 | 35.1.0 | 5.0.2 | [0.5.43](https://github.com/balena-os/jetson-flash/tree/v0.5.43) | + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +1. Make sure you connect the Type-C plug of the data cable to the USB Type-C port used for flashing, which is located next to 40-pin connector. +2. While holding the middle Force Recovery button, insert the USB Type-C power supply plug into the USB Type-C port above the DC jack. +3. This will turn on the Jetson dev kit in Force Recovery Mode. +4. HOLD DOWN UNTIL you hear the fan and get a usb connection popup on your connected PC + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-agx-orin-devkit +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-agx-orin-devkit] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-agx-orin-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-agx-orin-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-nano-2gb-devkit.md b/jetson-nano-2gb-devkit.md new file mode 100644 index 0000000..b625213 --- /dev/null +++ b/jetson-nano-2gb-devkit.md @@ -0,0 +1,152 @@ +# Instructions for the Jetson Nano 2GB Developers Kit (SD-CARD version) + + + +These are the flashing instructions for the Jetson Nano 2GB SD-CARD Developers Kit. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +Note that this is for the Jetson Nano Developer Kit 2GB RAM version with an on-module SD card slot. + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.95.15+rev1 or later | 32.7.1 | 4.6.1 | You are on the latest version (v0.5.22 or later) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.21](https://github.com/balena-os/jetson-flash/tree/v0.5.21) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.14](https://github.com/balena-os/jetson-flash/tree/v0.5.14) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.13](https://github.com/balena-os/jetson-flash/tree/v0.5.13) | + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the NVIDIA Jetson Nano Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +With power off, enable Force Recovery mode by placing a jumper across the "FRC" pins of the Button Header on the carrier board. + +- These are pins 9 ("GND") and 10 ("FC REC") of Button Header J12, which is located on the edge of the carrier board under the Jetson module. + +Then power on the device. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-nano-2gb-devkit +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-nano-2gb-devkit] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-nano-2gb-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-nano-2gb-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-nano-emmc.md b/jetson-nano-emmc.md new file mode 100644 index 0000000..d25a1a1 --- /dev/null +++ b/jetson-nano-emmc.md @@ -0,0 +1,156 @@ +# Instructions for the Jetson Nano eMMC + + + +These are the flashing instructions for the [Jetson Nano eMMC]([https://www.nvidia.com/en-us/autonomous-machines/embedded-systems/jetson-orin/](https://developer.nvidia.com/embedded/jetson-nano)). For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +Note that this is for the production Jetson Nano module without an SD card slot, **not** the [Jetson Nano SD Card Developer Kit](jetson-nano.md), which has an SD card slot on the module itself. + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.38 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.37](https://github.com/balena-os/jetson-flash/tree/v0.5.37) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.28](https://github.com/balena-os/jetson-flash/tree/v0.5.28) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.21](https://github.com/balena-os/jetson-flash/tree/v0.5.21) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.13](https://github.com/balena-os/jetson-flash/tree/v0.5.13) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.10](https://github.com/balena-os/jetson-flash/tree/v0.5.10) | + + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the NVIDIA Jetson Nano Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +With power off, enable Force Recovery mode by placing a jumper across the "FRC" pins of the Button Header on the carrier board. + +- For carrier board revision A02, these are pins 3 ("FC REC") and 4 ("GND") of Button Header J40 which is located near the camera header. +- For carrier board revision B01, (and the Nano 2GB) these are pins 9 ("GND") and 10 ("FC REC") of Button Header J12, which is located on the edge of the carrier board under the Jetson module. + +Then power on the device. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-nano-emmc +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-nano-emmc] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-nano-emmc --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-nano-emmc --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-nano.md b/jetson-nano.md new file mode 100644 index 0000000..2725d5e --- /dev/null +++ b/jetson-nano.md @@ -0,0 +1,155 @@ +# Instructions for the Jetson Nano Developers Kit (SD-CARD version) + + + +These are the flashing instructions for the Jetson Nano SD-CARD Developers Kit. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +Note that this is for the Jetson Nano Developer Kit with an on-module SD card slot, **not** the [Jetson Nano eMMC](jetson-nano-emmc.md), which does not have an SD card slot on the module itself. + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.53 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.52](https://github.com/balena-os/jetson-flash/tree/v0.5.52) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.22](https://github.com/balena-os/jetson-flash/tree/v0.5.22) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.21](https://github.com/balena-os/jetson-flash/tree/v0.5.21) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.13](https://github.com/balena-os/jetson-flash/tree/v0.5.13) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.10](https://github.com/balena-os/jetson-flash/tree/v0.5.10) | + + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the NVIDIA Jetson Nano Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +With power off, enable Force Recovery mode by placing a jumper across the "FRC" pins of the Button Header on the carrier board. + +- For carrier board revision A02, these are pins 3 ("FC REC") and 4 ("GND") of Button Header J40 which is located near the camera header. +- For carrier board revision B01, (and the Nano 2GB) these are pins 9 ("GND") and 10 ("FC REC") of Button Header J12, which is located on the edge of the carrier board under the Jetson module. + +Then power on the device. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-nano +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-nano] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-nano --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-nano --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-tx2-nx-devkit.md b/jetson-tx2-nx-devkit.md new file mode 100644 index 0000000..7c6dce6 --- /dev/null +++ b/jetson-tx2-nx-devkit.md @@ -0,0 +1,152 @@ +# Instructions for the Jetson TX2 NX (in Jetson Xavier NX Devkit) + + + +These are the flashing instructions for the Jetson TX2 NX (in Jetson Xavier NX Devkit). For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.39 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.38](https://github.com/balena-os/jetson-flash/tree/v0.5.38) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.28](https://github.com/balena-os/jetson-flash/tree/v0.5.28) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.21](https://github.com/balena-os/jetson-flash/tree/v0.5.21) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.13](https://github.com/balena-os/jetson-flash/tree/v0.5.13) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.10](https://github.com/balena-os/jetson-flash/tree/v0.5.10) | + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +1. Ensure the device is powered off and the power adapter disconnected. +2. Place a jumper across the Force Recovery Mode pins. These are pins 9 ("GND") and 10 ("FC REC") of the Button Header (J14). +3. Connect your host computer to the device's USB Micro-B connector. +4. Connect the power adapter to the Power Jack [J16]. +5. The device will automatically power on in Force Recovery Mode. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-tx2-nx-devkit +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-tx2-nx-devkit] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-tx2-nx-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-tx2-nx-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-tx2.md b/jetson-tx2.md new file mode 100644 index 0000000..1872379 --- /dev/null +++ b/jetson-tx2.md @@ -0,0 +1,165 @@ +# Instructions for the Jetson TX2 + + + +These are the flashing instructions for the Jetson TX2. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.35 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.34](https://github.com/balena-os/jetson-flash/tree/v0.5.34) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.32](https://github.com/balena-os/jetson-flash/tree/v0.5.32) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.26](https://github.com/balena-os/jetson-flash/tree/v0.5.26) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.19](https://github.com/balena-os/jetson-flash/tree/v0.5.19) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.10](https://github.com/balena-os/jetson-flash/tree/v0.5.10) | +| 2.50.1+rev1 - 2.60.1+rev2 | 32.4.3 | 4.4 | [v0.5.5](https://github.com/balena-os/jetson-flash/tree/v0.5.5) | +| 2.47.1+rev2 - 2.49.0+rev2 | 32.3.1 | 4.3 | [v0.4.1](https://github.com/balena-os/jetson-flash/tree/v0.4.1) | +| 2.39.0+rev1 - 2.47.1+rev1 | 32.2.0 | 4.2 | [v0.4.0](https://github.com/balena-os/jetson-flash/tree/v0.4.0) | +| Older than 2.47 | 28.3 | 3.3 | [v0.3.0](https://github.com/balena-os/jetson-flash/tree/v0.3.0) | + + + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +## TX2 Notes + +- The USB flashing method for the Jetson TX2 is an alternative to SD-CARD provisioning, and can also be used to re-flash TX2s that cannot boot normally due to corrupt QSPI firmware. +- For the Jetson-TX2 flasher image only, the system-proxy directory entries are not copied over by jetson-flash. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +1. Power down the device, removing the AC adapter. +2. Connect the Micro-B plug on the USB cable to the Recovery (USB Micro-B) Port on the device and the other end to an available USB port on the host PC. +3. Connect the power adapter to the device. +4. With the system powered on: + - Press and hold the RECOVERY FORCE button. + - While depressing the RECOVERY FORCE button, press and release the RESET button. + - Wait 2 seconds and release the RECOVERY FORCE button. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-tx2 +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-tx2] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-tx2 --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-tx2 --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-xavier-nx-devkit-emmc.md b/jetson-xavier-nx-devkit-emmc.md new file mode 100644 index 0000000..731b401 --- /dev/null +++ b/jetson-xavier-nx-devkit-emmc.md @@ -0,0 +1,152 @@ +# Instructions for the Jetson Xavier NX Devkit eMMC + + +These are the flashing instructions for the Jetson Xavier NX Devkit eMMC. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.54 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.53](https://github.com/balena-os/jetson-flash/tree/v0.5.53) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.33](https://github.com/balena-os/jetson-flash/tree/v0.5.33) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.23](https://github.com/balena-os/jetson-flash/tree/v0.5.23) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.17](https://github.com/balena-os/jetson-flash/tree/v0.5.17) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.3](https://github.com/balena-os/jetson-flash/tree/v0.5.3) | + + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +1. Ensure the device is powered off and the power adapter disconnected. +2. Place a jumper across the Force Recovery Mode pins. These are pins 9 ("GND") and 10 ("FC REC") of the Button Header (J14). +3. Connect your host computer to the device's USB Micro-B connector. +4. Connect the power adapter to the Power Jack [J16]. +5. The device will automatically power on in Force Recovery Mode. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-xavier-nx-devkit-emmc +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-xavier-nx-devkit-emmc] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-xavier-nx-devkit-emmc --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-xavier-nx-devkit-emmc --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-xavier-nx-devkit.md b/jetson-xavier-nx-devkit.md new file mode 100644 index 0000000..b6d80ef --- /dev/null +++ b/jetson-xavier-nx-devkit.md @@ -0,0 +1,152 @@ +# Instructions for the Jetson Xavier NX Devkit SD-CARD + + +These are the flashing instructions for the Jetson Xavier NX Devkit SD-CARD. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.36 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.35](https://github.com/balena-os/jetson-flash/tree/v0.5.53) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.33](https://github.com/balena-os/jetson-flash/tree/v0.5.33) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.23](https://github.com/balena-os/jetson-flash/tree/v0.5.23) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.17](https://github.com/balena-os/jetson-flash/tree/v0.5.17) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.3](https://github.com/balena-os/jetson-flash/tree/v0.5.3) | + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +1. Ensure the device is powered off and the power adapter disconnected. +2. Place a jumper across the Force Recovery Mode pins. These are pins 9 ("GND") and 10 ("FC REC") of the Button Header (J14). +3. Connect your host computer to the device's USB Micro-B connector. +4. Connect the power adapter to the Power Jack [J16]. +5. The device will automatically power on in Force Recovery Mode. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-xavier-nx-devkit +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-xavier-nx-devkit] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-xavier-nx-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-xavier-nx-devkit --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + + +License +------- + +The project is licensed under the Apache 2.0 license. diff --git a/jetson-xavier.md b/jetson-xavier.md new file mode 100644 index 0000000..cd93f72 --- /dev/null +++ b/jetson-xavier.md @@ -0,0 +1,150 @@ +# Instructions for the Jetson AGX Xavier + + + +These are the flashing instructions for the Jetson AGX Xavier. For the list of other balena-supported Jetson devices [See here](https://github.com/balena-os/jetson-flash/tree/alanb-documentation?tab=readme-ov-file#instructions). + +## L4T/balenaOS/jetson-flash compatibility + +**Use the version of jetson-flash that corresponds to the version of balenaOS that you would like to provision per the table below.** + +(Each version of jetson-flash uses a specific version of NVIDIA's L4T BSP to properly partition the Jetson's boot media. This BSP version must also match the BSP used in the version of balenaOS you're flashing) + +| balenaOS version | BSP version | Jetpack version | Use this version of jetson-flash | +|------------------|-------------|-----------------|----------------------------------| +| 2.108.9+rev1 or later | 32.7.3 | 4.6.3 | You are on the correct version. (v0.5.49 or later) | +|2.101.1 - 2.108.9 | 32.7.2 | 4.6.2 | [v0.5.48](https://github.com/balena-os/jetson-flash/tree/v0.5.48) | +| 2.95.15+rev1 - 2.101.0 | 32.7.1 | 4.6.1 | [v0.5.23](https://github.com/balena-os/jetson-flash/tree/v0.5.23) | +| 2.87.1+rev1 - 2.95.14 | 32.6.1 | 4.6 | [v0.5.22](https://github.com/balena-os/jetson-flash/tree/v0.5.22) | +|2.82.11+rev2 - 2.85.2+rev5 | 32.5.1 | 4.5.1 | [v0.5.18](https://github.com/balena-os/jetson-flash/tree/v0.5.18) | +| 2.67.2+rev1 - 2.82.11+rev1 | 32.4.4 | 4.4.1 | [v0.5.10](https://github.com/balena-os/jetson-flash/tree/v0.5.10) | + +## Requirements +Jetson Flash requires an x86 Linux-based host (or virtual machine) and has been tested on Ubuntu 22.04 (Focal). + +You can either install all the prerequisites listed below or run the provided Docker image (using Docker, not balenaOS) on the host. + +### non-Docker + +Prerequisites: + +- Sudo privileges (required by Tegra Flash and to delete intermediate steps created by the tool in `/tmp/${pid_of_process}`) +- [NodeJS](https://nodejs.org) +- Make sure you have python2 installed and that the `python` binary points to python2. +- Dependencies required for the the L4T package, including: lbzip2, e2fsprogs, dosfstools, libxml2-utils, lz4 + +Installation: + +Make sure the prerequesites listed above are installed. + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +Install Node.js dependencies by issuing the following command in the jetson-flash directory: +```sh +$ npm install +``` + +### Docker + +Prerequisites: + +- the Docker image should be run as privileged +- `/dev/bus/usb` needs to be bind-mounted for the Tegra BSP tools to communicate with the device + +Installation: + +Clone this repository: +```sh +$ git clone https://github.com/balena-os/jetson-flash.git +``` + +## How to use + +Follow the steps below to flash your Jetson board + +### Recovery mode + +Make sure that the Jetson board is plugged into your host via USB and is in recovery mode before issuing the flashing command. + +We only test jetson-flash on the reference NVIDIA carrier board. If your carrier board varies significantly from the Developer Kit you may need to contact the manufacturer for the proper recovery mode steps. + +1. Ensure the device is powered off and connect it to the host PC via USB. +2. Press and hold down the Force Recovery button. +3. Press and hold down the Power button. +4. Release both buttons. + +**Confirmation** + +You can confirm your device is running in recovery mode by issuing the command `lsusb | grep NVIDIA` and examining the output. + +You should see something similar to the below, depending on your board: + +``` +Bus 003 Device 005: ID 0955:7023 NVIDIA Corp. APX + +``` + +(The `APX` is crucial to confirming recovery mode.) + +Or + +``` +Bus 001 Device 019: ID 0955:7c18 NVIDIA Corp. T186 [TX2 Tegra Parker] recovery mode +``` + +### Run the tool + +For **non - Docker**, run the tool by specifying the path to the unzipped image (in place of "") and the device type as shown below: + +```sh +$ ./bin/cmd.js -f -m jetson-xavier +``` + +For **Docker**, issue the following commands in the folder that has the Dockerfile to build the container (building may take a while and appear to hang, so be patient.) Create a folder named `images` in your home directory and place your balena image file there so it's available inside the container. + +```sh +./build.sh [-m jetson-xavier] +``` + +You can then enter the container using: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image /bin/bash +``` + +Alternatively, run the provided docker-compose file with `docker-compose up` and ssh into the container with `docker exec -it /bin/bash` + +Once in the container, you can run jetson-flash by specifying the balena image in your host's `~/images/` folder (in place of ""): + +```sh +./bin/cmd.js -f /data/images/ -m jetson-xavier --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +You can alternatively just run the jetson-flash tool in a single command by running the container with this command: + +```sh +docker container run --rm -it --privileged -v /dev/bus/usb:/dev/bus/usb -v ~/images:/data/images jetson-flash-image ./bin/cmd.js -f /data/images/ -m jetson-xavier --accept-license=yes -c /tmp/Linux_for_Tegra +``` + +It will exit upon completion. + +--- + +The flashing process may take 5 - 15 minutes or longer during which a lot of log output will appear. If all goes well, you'll see something similar to the following upon completion: + +``` +*** The target t186ref has been flashed successfully. *** +Reset the board to boot from internal eMMC. + +``` +## Support + +If you're having any problems, please [raise an issue](https://github.com/balena-os/jetson-flash/issues/new) on GitHub or ask a question [in our forums](https://forums.balena.io/c/share-questions-or-issues-about-balena-jetson-flash-which-is-a-tool-that-allows-users-to-flash-balenaos-on-nvidia-jetson-devices/95) and the balena.io team will be happy to help. + +License +------- + +The project is licensed under the Apache 2.0 license.