Flash Steps for NVIDIA Thor System on Chip (SoC)#
Use the bootburn utility to flash platform boards with the boot loader, kernel, and file system. The bootburn utility is provided as part of the Foundation package.
Bootburn#
Bootburn is a Python script that:
Boots the device in the recovery-mode with ramdisk
Signs or generates the images on the host
Transfers the images to target using ADB
Flashes the boards
Bootburn automatically resizes the rootfs image on the target to optimize the available storage on the partition dedicated to it, either on eMMC or NOR.
Bootburn supports a host NFS share as the mount point for the target rootfs. This feature provides a convenient way for developers to copy files between the target and host for rapid development. In this case, the uncompressed target rootfs directory on the host is leveraged directly by the target.
Bootburn relies on the Foundation services to provide the flashing and boot loader functionality. You configure it with the CFG file rather than with bootburn command-line parameters; the bootburn utility supports limited command-line options.
Bootburn Command Usage#
Run the bootburn.py
script from a shell on your host Linux system by executing the command:
./bootburn.py <options>
Bootburn Options#
Options |
Description |
---|---|
-b <p3960-10-sw01 | p3960-10-sw02 | p3960-10-sw03 | p3960-30-sw01 | p3898-a01> (lowercase b) |
Provides the board name and revision. Possible board names include:
Not all boards are supported in NSR and SR. For more information, see the NVIDIA DriveOS API Reference. |
–board_config .json |
Can be used with |
-d (lowercase d) |
Specifies the DTB file to flash and the target partition. The default file is defined in
Note This option is not intended to specify kernel-dtb in Hypervisor. |
–encryption_key |
Takes as parameter the full file path and name. Secure boot encryption key. Can be used with Find “SBK”. "AES" : {
"SBK" :
{
"IV" : OEM_FUSE_IV,
"Manifest" : "10860000",
"Offset" : "0d01",
#"Plain" : "63979cd900154cfaedc539cd17572387296058fe988013c055be99bfd8db41f9",
"Plain" : "753aafbeab213322ef0f8cecc805d1b086e252953dfb3cac215a778f68cb5a72",
#"Plain" : "0000000000000000000000000000000000000000000000000000000000000000",
Where |
-f (lowercase) |
Failure analysis (FA) mode support. |
-g (lowercase) |
Generate binaries at mentioned path only and do not flash. Used with |
-h (lowercase h) |
Provides guidance on the actions and options of |
-i (lowercase i) |
File path to platform configuration file. If not provided for hypervisor configurations, then the tool expects the platform configuration file to be present in the hypervisor output directory. |
-k (lowercase k) |
Specifies the configuration file for flashing. |
-m (lowercase) |
Flashing Modular Diagnostic Software (MODS). This option enables mods-specific overrides. |
-o (lowercase o) |
Skips flashing of recovery partitions. Used by minicom. WARNING: If you are using minicom with -o option, minicom does not initialize the port and therefore does NOT check or acquire the lock files for the communication port. If minicom is running in the background and you run bootburn with the -x option, bootburn acquires the lock BEFORE accessing the communication port. So, when bootburn attempts to communicate with MCU it fails. |
-p (lowercase p) |
Signs the boot loader, secure OS (TOS), kernel and BCT binary, then flashes the device. |
–hsm |
Can be used with |
-q (lowercase q) |
Flashes QNX images. |
-t (lowercase t) |
Specifies the output directory where images to be flashed onto the target are to be stored. The default directory is named |
-x |
Specifies the communication port for MCU to put the SoC in recovery mode automatically. With this Bootburn generates a unique ID from the target Inforom data. The allowed target ID list for the user provided board is generated from BOM data file included in the package. Bootburn aborts flashing if the target unique ID is not found in the list of generated unique IDs for the provided board name. This feature is supported on P3960, P3663, and P3898 boards with Inforom system object version 3 or above. Note On boards with inforom, the bct sku info is updated with the information in the inforom. If the Warning: If minicom is used with the
|
-B (uppercase B) |
Specifies the boot device, which must be either qspi or emmc. qspi is the default. |
-C (uppercase C) |
Specifies use of debug binaries for the boot loader. |
-D (uppercase D) |
Directs |
-E (uppercase E) |
Enables DRAM ECC. |
-I (uppercase I) |
Flashes a specific device when multiple devices are in recovery. To get the bus and device ID of each device in recovery, enter the lsusb command on the host. For example, if lsusb gives the following output:
Then flash the second device with the –I option as in this example:
|
-L (uppercase L) |
Enables low-power modes. This option requires that the spe-fw and WB0 firmware packages be included in the bootburn configuration because low-power modes require them. |
-M (uppercase M) |
Specifies development version firmware. |
-R (uppercase R) |
Specifies RCM boot support, where the device boots without being flashed. When the target is in recovery mode, this option causes the flashing script to download all binaries, other than BCT, from the host. The target then reads the BCT from storage and other binaries from RAM. It boots the kernel directly on RAM. This option is much faster than when flashing also occurs. It is especially useful during debugging. Use the -R flag to initiate RCMBOOT with any of the commands mentioned in this table. |
-T (uppercase T) |
Enables tracing. Tracing logs are stored under the |
–safety |
Execute bootburn scripts in safety mode. Only a limited set of options is available for use in safety mode. For more information, see the Safety Use Cases for Bootburn Scripts chapter in the NVIDIA DriveOS 7.0 Safety Developer Guide for more information. |
-U |
Pass in the UFS provision configuration file. |
-V (uppercase V) |
Specifies read-back verification, where the binary images are read back (after writing) from the target’s storage and compared with the original binary images. The two sets of images are compared to detect discrepancies. |
–customer-data |
Specified customer data such as skuinfo and others to be updated during flashing See flashing_customer_data.docx for information on how to use it. |