Preparation
Download the latest version of the BSP Source Files and the Windows 10 IoT Enterprise documentation from NXP:
https://www.nxp.com/design/software/embedded-software/i-mx-software/windows-10-iot-enterprise-for-i-mx-applications-processors:IMXWIN10IOTDownload the "Windows 10 IoT Entrerprise 2021" ARM64 DVD Image as described in Section 3 of the i.MX Windows 10 IoT Quick Start Guide.
Setup
Set up your build environment as described in chapter 2 of the i.MX Windows 10 IoT User’s Guide.
(Visual Studio 2019, ADK + WinPE addon for ADK + WDK)Extract the WIN10_<version>_SOURCE.zip
Execute the Init.bat
Open the solution <path>\imx-windows-iot\build\solution\iMXPlatform\iMXPlatform.sln and build it for ARM64/Debug
Custom SECO drivers/changes
Copy the <path>\imx-windows-iot\BSP\IoTEntOnNXP\ folder to
<path>\imx-windows-iot\BSP\IoTEntOnSECO\Download the SECO-specific modifications from this wiki page and extract them into the new IoTEntOnSECO folder.
The archive contains SECO specific changes to the BSP, the installation scripts, the drivers used and the customized bootloader with the i.MX Firmware.
Building the WinPE SD Card
Execute the following command in the IoTEntOnSECO directory directory in an elevated command prompt (launched as administrator)
make-winpe-enterprise.cmd /device /patch_sdport /disable_updates /disable_transparency /test_signing /unattend
Apply the Image to an SD Card with the following command (diskmgmt.msc displays the drive numbers)
make-winpe-enterprise.cmd /apply <disk_number>
Updating the Bootloader & i.MX Firmware
It is recommended that you use the method described in section 8.2 of the i.MX Windows 10 IoT Quick Start Guide to update the Firmware.
There is an alternative way that allows you to update the firmware from the SD card in the bootloader:
Hold <esc> in the terminal emulator of your choise (e.g. TeraTerm or PuTTY) while powering up the system with the WinPE SD card inserted in the device.
The following series of commands will allow you to load the firmware binary from the SD card and write it to the boot partition 1 of the eMMC:
Select the sd card socket
mmc dev 1
View the contents of the SD Card, verify that the firmware you want to write to the eMMC is present on the SD card
fatls mmc 1:2
Load the firmware binary you want to apply (In this example we use firmware.tr8m_v2r1.bin
fatload mmc 1:2 0x40800000 firmware.tr8m_v2r1.bin
Select the boot partition 1 of the eMMC
mmc dev 0 1
Write the firmware to the selected partition with the i.MX8M Mini specific offset
mmc write 0x40800000 0x42 0x1B7B
Select the eMMC Boot Partition as boot partition
mmc partconf 0 1 1 0
Erase the bootloader environment
mmc env_erase
Restart the device. It should reboot into the applied bootloader version.
The first line of the serial output contains the build date of the bootloader.reset