The development environment for the IRIS HubOS is currently based on the Yocto 2.7.4 "Warrior" release. The proprietary hardware is similar to that of the BeagleBone Black for our second generation Hub, and a custom NXP imx6DualLite design for the 3rd generation Hub.
The changes to the OSS packages used are marked with "IRIS Change" additions to the files touched. A list of changes can be found in the ChangeLog_oss.txt file.
Please use a Yocto Supported Operating system. For Yocto 2.7.4, this is CentOS 7, Debian 9, Fedora 28, Fedora 29, OpenSuse 42.3, Ubuntu 16.04, and Ubuntu 18.04.
As with any Yocto project, you should be using a fairly capable system (e.g. modern core "i" series processor, 25GB or more of disk space, and ideally an SSD) to achieve reasoanble build times.
Follow the Yocto environment set up instructions in "The Packages" section at:
http://www.yoctoproject.org/docs/current/yocto-project-qs/yocto-project-qs.html
For a Ubuntu distribution, the following tools are needed:
$ sudo apt-get install gawk wget git-core diffstat unzip texinfo gcc-multilib build-essential chrpath socat libsdl1.2-dev xterm python chrpath
Arcus HubOS has added JDK support to the base Yocto build, so you will also need to install the following (assuming Ubuntu/Debian environment):
$ sudo apt-get install openjdk-8-jdk galternatives srecord
Run 'galternatives' and make sure 'keytool' and 'jar" are configured to the java8-openjdk package which was just installed.
The build outputs are put in /tftpboot to simplify finding the firmware images. Please add this directory - actual tftp server support is not needed, though.
$ sudo mkdir /tftpboot
$ sudo chmod -R 777 /tftpboot
$ sudo chown -R nobody /tftpboot
Before running the build, either create a top-level /build directory, or modify the configuration in build/conf/local.conf to comment out this line or change to another location:
SSTATE_DIR ?= "/build/sstate-cache"
A number of core modules (poky, meta-openembedded, meta-freescale and meta-freescale-3rdparty) are used as Git submodules and therefore need to be initialized after the clone of the project:
$ cd arcushubos
$ git submodule update --init
The following targets are valid:
-
hubv3 - builds release image for v3 hub
-
hubv3-dev - builds development image with added tools, etc. for v3 hub
-
hubv3-clean - cleans up v3 build outputs. Would need to remove /build/sstate-cache to truely force a complete rebuild
-
hubv3-distclean - Removes all v3 files from "clean" as well as downloaded files to mimic starting from scratch
-
hubv2 - builds release image for v2 hub
-
hubv2-dev - builds development image with added tools, etc. for v2 hub
-
hubv2-clean - cleans up v2 build outputs. Would need to remove /build/sstate-cache to truely force a complete rebuild
-
hubv2-distclean - Removes all v2 files from "clean" as well as downloaded files to mimic starting from scratch
These builds will take a hour or so (depending on your machine) to complete as it has to build all the cross-compiler toolchains as well as all packages in the build.
When complete, the outputs will be in build-ti/tmp/deploy/images
for v2
hub builds, and build-fsl/tmp/deploy/images
for v3 hub builds.
-
i2hubos_update.bin - v2 image without the build header (which includes checksum, signature, etc)
-
i2hubos_update_bootloader.bin - Above, but with v2 boot loader files as well
-
hubOS_X.Y.Z.xxx.bin - v2 Release image with Java support with release boot loader
-
hubBL_X.Y.Z.xxx.bin - v2 Release image with Java support, plus development boot loader files
-
i2hubosv3_update.bin - v3 image without the build header (which includes checksum, signature, etc)
-
i2hubosv3_update_bootloader.bin - Above, but with v3 boot loader files as well
-
hubOSv3_X.Y.Z.xxx.bin - v3 Release image with Java support with release boot loader
-
hubBLv3_X.Y.Z.xxx.bin - v3 Release image with Java support, plus development boot loader files
$ scp /tftpboot/hubOS_X.Y.Z.xxx.bin root@your_v2_hub:/tmp
$ ssh root@your_hub_ip
$ install -f file:///tmp/hubOS_X.Y.Z.xxx.bin
Bump the version number in meta-iris/recipes-core/iris-lib/files/irisversion.h
Bump the version number in meta-iris/recipes-core/iris-agent/iris-agent.bb#L40 and change the hashes of the target tar.gz file:
For development, it is not necessary to use the complete images as the validation takes additional time. Also, since the boot loader files will seldom change, using the i2hubos_update.bin (or i2hubosv3_update.bin for v3 hub) is all that is necessary in most cases. To install this file, do the following:
$ scp /tftpboot/i2hubos_update.bin root@your_hub_ip:/tmp
$ ssh root@your_hub_ip
$ fwinstall /tmp/i2hubos_update.bin
Once this install completes reboot the hub so the new firmware is used.
The current SSH root password for images built from these sources is 3XSgE27w5VJ3qvxK33dn
.
The default root password for Iris hubOS 3.x releases, regardless of hardare revision or platform is zm{[*f6gB5X($]R9
.
The earlier 2.x releases used a default password of kz58!~Eb.RZ?+bqb
.