-
Notifications
You must be signed in to change notification settings - Fork 236
initrd flashing support
Notes on extending support for flashing Jetson devices that boot from external storage media (NVMe, USB).
Last update: 12 Jan 2023
This is currently supported on the JetPack 5.0/L4T R35.1.0-based branches and kirkstone-l4t-r32.7.x
. For R32.7.x, there is support for T210 (TX1/Nano) as well as T186 (TX2) and T194 (Xavier) targets.
Beyond the normal host tools required for building and normal flashing, you should also have these commands available on your build host:
-
sgdisk
(from thegdisk
/gptfdisk
package) -
udisksctl
(part of theudisks2
package)
If the bmaptool
command is available, it will be used for writing to the storage device, which speeds up writes but (currently) requires root privileges (the scripts will automatically use sudo
to invoke it when needed).
No additional host changes should be required. For running the initrd-flash
script without sudo
, the host changes mentioned in the "Avoiding sudo" section on the Flashing the Jetson Dev Kit wiki page still apply.
No configuration is required if you just want to use initrd flashing and still keep your rootfs on the Jetson's internal storage device. You only need to add a configuration setting if you want to configure your system to have its rootfs (APP
partition) on an external storage device. To do that, add a line to your local.conf
such as:
TNSPEC_BOOTDEV:jetson-xavier-nx-devkit-emmc = "nvme0n1p1"
- If trying this out with a different Jetson device, use the MACHINE name for the override in the above.
- If trying USB storage instead of NVMe, use
sda1
as the boot device, instead ofnvme0n1p1
.
- Put the Jetson device into recovery mode and connect it to your host via the USB OTG port.
- Unpack the
tegraflash
tarball into an empty directory. -
cd
to that directory and run./initrd-flash
(usingsudo
if necessary) to start the flashing process.
The script:
- Uses the RCM boot feature to download a special initrd and kernel that sets up the device as a USB mass storage gadget.
- Waits for the USB storage device to appear on the host, then copies in the bootloader files and a command sequence for the target that instructs it to start the boot device update, and tells it which storage device(s) should be exported to the host for writing.
- The script then calls on
make-sdcard
to write to storage device(s). This happens in parallel with the target programming the boot device. - The script then waits for the target to export another storage device to report its final status and the logs generated on the target. The script copies the device logs into a subdirectory. When finished, it releases the storage device, and the target reboots automatically.
The initrd-flash
script has a --skip-bootloader
option for skipping the programming of the boot partitions, so you can re-flash just rootfs storage device. You should only use this option if you have already programmed the boot partitions once with the versions you're using for your current build.
- Develop the kernel/initrd used here into a more general "recovery" image, and/or applied for cross-version OTA updates, although the specific use cases will probably require something a bit different and need more customization.
- See if something could be done to automate setup when using LUKS encryption. Direct formatting and partition writing from the host isn't really an option there. A hybrid approach (formatting and cryptsetup done on the device, then exporting the encrypted partitions via USB) should be workable.
- The helper scripts now support an
--external-device
option that passes appropriate options totegraflash.py
(needed since one of the BCTs appears to include information the external storage device for the boot chain to work), and an--rcm-boot
option to allow direct download/execution of a kernel+initrd image. - The SDcard-related support in the
nvflashxmlparse
andmake-sdcard
scripts was generalized to distinguish between the 'boot' device and any 'rootfs' device. Themake-sdcard
script also gets a new--serial-number
option for locating the device to write to by the serial number attribute advertised by the USB gadget. - The
tegra-flash-init
recipe was added to install a minimal init script for the flashing kernel, which sets up a USB mass storage gadget for the device to be flashed (passed to it via the kernel command line). The serial number advertised by the gadget is the unique chip id (ECID) of the Tegra SoC. - The
initrd-flash
script and the flashing kernel/initrd are added to the tegraflash package to drive the process. The ECID (unique ID) of the SoC is extracted during initial RCM contact and used to locate the correct/dev/sdX
device for the partition writing. - A
find-jetson-usb
script has been added to wait for the appearance of the Jetson (in recovery mode) on the host USB bus.
- RCM booting on T194 platforms bypasses the UEFI bootloader, directly loading the kernel from nvtboot. This means that the kernel/initrd does not have access to any EFI variables. UEFI is used in the RCM boot chain on T234 platforms.
- On Xavier NX dev kits (SDcard-based), you must still have an SDcard installed in the slot even if you are booting off an external drive. The SDcard must not have an
esp
orAPP
partition on it. You must manually reformat the SDcard, as the flashing process will not do that for you. For all other Jetsons with internal eMMC storage, the eMMC will be erased as part of the flashing process (and re-partitioned/re-populated for those platforms that store some of the bootloader binaries in the eMMC). - Based on readings of some NVIDIA dev forum posts, A/B updates in JetPack 5.0 do not work properly in all cases when booting off an external drive. That is supposed to be fixed in JetPack 5.1.
- Depending on your device's configuration (e.g., having multiple storage devices attached), you may need to manually configure the boot order in the UEFI bootloader by hitting
ESC
when UEFI starts, and then selectingBoot Maintenance Manager
, thenBoot Options
, thenChange Boot Order
. This is a limitation in JetPack 5.0 that is supposed to be fixed in JetPack 5.1. - If you use a custom flash layout for your builds, note that there are some limitations on the composition of your flash layout file(s) due to how the bootloaders and the NVIDIA tools work. For example, you cannot use a SPI flash-only layout for internal storage, since the BUP payload generator expects to be able to create a payload containing the kernel/kernel DTB. The generator will fail during the build, since those partitions are not present in the SPI flash. You also cannot use a single flash layout that includes only the boot partitions (in, for example, SPI flash on AGX Orin and Xavier NX) and the external storage device (
nvme
). The tools that generate the MB1 BCT and/or MB2 BCT will error out because those bootloaders cannot access external storage. Hopefully NVIDIA will resolve these limitations in a future release.
- OE builds are per-machine, so much of the additional scripting to handle different targets during the flashing process can be omitted.
- Stock L4T provides its initrd in prebuilt form, which requires disassembling and reassembling the initrd in the flashing scripts. With OE, we can build the flashing initrd directly.
- Stock L4T requires customizing the external drive's flash layout to specify the exact size of the storage device, in sectors. That's not required with the approach used here.
- Stock L4T inserts udev rules on the host during flashing and does some network setup to talk to the device. This process does not use any networking and does not require any udev rules changes during the flashing process. You also don't have to be root to execute this process, if you have followed the instructions here, although
bmaptool copy
does need root access for its setup, and the script will run it undersudo
for you.
- On Jetson TX2 devices, the bootloaders do not have support for loading the kernel from an external drive. The kernel, initrd, and device tree must reside on the eMMC (along with some of the boot partitions).
- Other Jetsons that boot directly from the eMMC (TX1, Nano-eMMC, Xavier NX-eMMC, AGX Xavier) also need to have some of the boot partitions in the main part of the eMMC.
- With Jetsons running JetPack 5/L4T R35.1.0, you may need to manually interrupt the UEFI bootloader to adjust the boot order to favor the external drive. Even then, UEFI may attempt a PXE (network) boot first.
- On an AGX Orin configured to use an external drive for the rootfs (NVMe), once it has been flashed using
initrd-flash
, the RCM boot of theinitrd-flash
kernel stops working; the NVMe-resident OS is booted instead. This happens with the stock L4T initrd flashing tools also. To work around the problem, clear the partition table on the NVMe drive (e.g., usingsgdisk /dev/nvme0n1 --clear
) before resetting the Orin into recovery mode to start the re-flashing process. - On T210 platforms (TX1/Nano), if you use the normal
doflash.sh
script, boot binaries will get overwritten (due to the way the NVIDIA flashing tools work), and that will cause an "FDT_ERR_BADMAGIC" error if you later try to runinitrd-flash
. The error is minor, and probably won't cause any real issues with the flashing/booting process. To be safe, though, you should not mix normal and initrd-based flashing in the same tegraflash directory.