This Isar layer contains recipes, configuration and other artifacts that are specific to Debian-based IOT2050 product.
Before building the system, you will need to install docker on build host. For example under Debian Linux
sudo apt install docker.io
If you want to run docker as non-root user then you need to add your user to the docker group:
sudo usermod -aG docker $USER
You may need to re-login or issue newgrp.
Then open the menu to select the desired image and options:
./kas-container menu
After the build completed, the final image is under
build/tmp/deploy/images/iot2050/iot2050-image-example-iot2050-debian-iot2050.wic
To build the example image with EIO subsystem, for example when building for
IOT2050 SM variant, the EIO firmware & binaries must be downloaded from
Siemens Industry Online Support
and extracted to recipes-app/iot2050-eio-manager/files/bin
before the building.
Then build with
./kas-container build kas-iot2050-example.yml:kas/opt/eio.yml
(or select EIO subsystem support
in kas menu
)
A tool to upgrade the customized signal module (SENS SM) firmware is also avaiable, to build it with:
./kas-container build kas-iot2050-example.yml:kas/opt/eio.yml:kas/opt/module.yml
To build the example image with the Hailo8 AI card support:
./kas-container build kas-iot2050-example.yml:kas/opt/meta-hailo.yml
Please visit meta-hailo for the details.
Note: Current SDK only supports Linux x86-64 host machine
./kas-container build kas-iot2050-example.yml:kas/opt/sdk.yml
(or select SDK in kas menu
)
After the build completed, the SDK tarball is located at
build/tmp/deploy/images/iot2050/sdk-isar-arm64.tar.xz
Please follow the further instruction file README.sdk
in the SDK tarball.
The SDK is also available as docker image. To import it into a docker host, run
docker load -i build/tmp/deploy/images/iot2050/sdk-iot2050-debian-arm64-docker-archive.tar.xz
To boot IOT2050 image from qemu, you need a customized image for proper booting. Please use kas menu with the following command and select qemu image for target build with example image or example image with swupdate support
./kas-container menu
Then below command can be used to boot qemu image on a platform that qemu-system-aarch64 is installed.
Run qemu:
/bin/sh start-qemu-iot2050.sh"
./kas-container --isar clean
Under Linux, insert an unused SD card. Assuming the SD card takes device /dev/mmcblk0, use dd to copy the image to it. For example:
$ sudo dd if=build/tmp/deploy/images/iot2050/iot2050-image-example-iot2050-debian-iot2050.wic \
of=/dev/mmcblk0 bs=4M oflag=sync
Alternatively, install the bmap-tools package and run the following command which is generally faster and safer:
$ sudo bmaptool copy build/tmp/deploy/images/iot2050/iot2050-image-example-iot2050-debian-iot2050.wic /dev/mmcblk0
The example image starts with the IP 192.168.200.1 preconfigured on the first Ethernet interface, and use DHCP at another. You can use ssh to connect to the system.
The BSP image does not configure the network. If you want to ssh into the system, you can use the root terminal via UART to ifconfig the IP address and use that to ssh in.
NOTE: To login, the default username and password is root
. And you are
required to change the default password when first login.
During the very first boot of the image from an SD card or USB stick, you can request the installation to the eMMC. For that, press the USER button while the status LED is blinking orange during that first boot. Hold the button for at least 5 seconds to start the installation.
NOTE: All content of the eMMC will be overwritten by this procedure!
The ongoing installation is signaled by a fast blinking status LED. Wait for several minutes until the LED stops blinking and the device reboots to the eMMC. You can safely remove the SD card or USB stick at that point.
The installation can also be triggered automatically by creating the file
/etc/install-on-emmc
on the vanilla image by mounting it under Linux and
executing, e.g., touch <mountpoint>/etc/install-on-emmc
.
By default, the boot loader will pick the first bootable device. If that device may no longer fully start, you can select an alternative boot device in the U-Boot shell. Attach a USB-UART adapter to X14, connect it to a host PC and open a terminal program on that port. Reset the device and interrupt the boot when it counts down ("Hit any key to stop autoboot"). Then type
=> setenv boot_targets mmc0
=> run distro_bootcmd
to boot from the microSD card. Use usb0
for the first USB mass storage device.
NOTE: This selection is not persistent. The boot loader will fall back to its default boot order after reset.
It is possible to create an image with a SWUpdate based double copy
root file
system
for Over-The-Air updates by selecting the option Example image with SWUpdate support
during the image configuration with ./kas-container menu
. You can also build the image by calling:
./kas-container build kas-iot2050-example.yml:kas/opt/swupdate-example.yml
You can find the final image under
build/tmp/deploy/images/iot2050/iot2050-image-swu-example-iot2050-debian-iot2050.wic
.
This image holds the necessary partition layout with two root file
systems. The image
iot2050-image-swu-example-iot2050-debian-iot2050.wic
can be flashed
directly to a SD card as described in section Booting the image from SD
card.
NOTE: As the image contains 2 root file systems, it has a size of 7 Gigabytes.
It also will create a binary for updating the system at
build/tmp/deploy/images/iot2050/iot2050-image-swu-example-iot2050-debian-iot2050.swu
The following steps are necessary to update an image created with SWUpdate support.
-
Transfer the SWUpdate binary
iot2050-image-swu-example-iot2050-debian-iot2050.swu
to the target system. -
Update the system with SWUpdate by executing:
$ swupdate -i iot2050-image-swu-example-iot2050-debian-iot2050.swu
You can find more details and options for the command swupdate
in the
SWUpdate
documentation.
NOTE: The used SWUpdate package does not contain a web-app example.
SWUpdate will write the image to the unused root partition and updates the EFI Boot Guard state. EFI Boot Guard is the bootloader that controls which of the two kernels and root file systems are booted.
-
Reboot the system into the new root file system. The switch between the root file systems occurs automatically and requires no user interaction.
-
Confirm that the new root file system is correctly booted.
After a reboot, the device boots into the new root file system. If the boot is successful the update process needs to be completed by calling:
$ complete_update.sh
The script sets the update state in the EFI Boot Guard configuration to the "success" state. It shall be considered as a placeholder for a more precise logic which first needs to validate if the new image version is sufficiently functional to accept the next update. The exact condition for this depends on the concrete integration and the way how updates are deployed to the device. If the update happens over network, checking the connection to the update server first before confirming the update is strongly recommended.
If the update is deemed failed, resetting the device will select the previous root file system.
The bootloader environment needs to be adapted to select the correct root file
system during boot. This adaptation occurs automatically during the first boot
by executing the patch-u-boot-env.service
. This systemd-service activates the
hardware watchdog in the U-Boot environment, setting it to 60 seconds by
default.
If it is necessary to revert to the default U-Boot environment the following command can be used:
$ fw_setenv -f /etc/u-boot-initial-env