To build a full release including all supported combinations of boards and modules,
- Create a new release JSON file under
release_specs/<version>.json
. - Run
./mangoh_release.py release_specs/<version>.json
When complete, the output will be found under build/leaf/remote
.
It will have an index file called mangOH.json
, so you can add that as a leaf remote
and test the packages.
leaf remote add release_1.2.3-rc1_test file://$HOME/release_build/1.2.3-rc1/build/leaf/remote/mangOH.json
mkdir test_dir
cd test_dir
leaf setup -p mangOH-yellow-wp76xx_1.2.3-rc1
leaf shell
git clone --recursive /~https://github.com/mangOH/mangOH
cd mangOH
make yellow
Some operations require authenticated access to Gerrit. The value of the GERRIT_USER
environment
variable will be used to obtain the user name for access to Gerrit. If GERRIT_USER
is not set,
mangoh_release.py
will set GERRIT_USER
to the same value as USER
.
The specification format is a JSON object. Each subsection below describes a member of that object.
Specifies details of the mangOH release.
"mangoh": {
"ref": "646592902e6d5d748560a60da7e3db0c0f57b360",
"wget": [
{
"url": "https://community.bosch-sensortec.com/varuj77995/attachments/varuj77995/bst_community-mems-forum/44/1/BSEC_1.4.7.2_GCC_CortexA7_20190225.zip",
"dir": "components/boschBsec",
"unpack": "unzip"
}
],
"requires": [
"swi-license_1.2",
"swi-verify-license_latest"
],
"depends": [
"swi-legato_latest",
"swi-vscode-support_latest"
]
}
"ref" contains the git ref to be checked out from the main mangOH repository (MANGOH_MAIN_REPO) when fetching the mangOH source code.
"wget" is an optional member, which directs the build to use wget to download a list of files under the MANGOH_ROOT directory and optionally unpack them. The "wget" member is an array of objects. Each of those objects must have a "url" member and a "dir" member (which is a relative path from MANGOH_ROOT of a directory into which the file will be downloaded. If an "unpack" member is present, it specifies the method to be used to unpack the downloaded file. Presently, only "unzip" is supported.
"requires" is a list of leaf packages to be added to the "requires" section of all generated SDK master leaf packages.
"depends" is a list of leaf packages to be added to the "depends" section of all generated SDK master leaf packages.
Specifies the Legato source to fetch using Google's "repo" tool, as well as optional patches to apply to the Legato source code before building it.
"legato": {
"manifest_repo": "ssh://${GERRIT_USER}@master.gerrit.legato:29418/manifest.git",
"base_manifest": "legato/releases/20.04.0/legato.xml",
"patches": [
{
"purpose": "LE-14705: Fix SecStore to enable recovery from corrupted keys file.",
"dir": ".",
"cherry_pick": "f9cc1f29d4b36e9999d3365a2ecf85e358eb4efd"
},
{
"purpose": "LE-14639: [Octave][CoAP]AV does not reply to CoAP retry on CoAP data for application",
"dir": "3rdParty/Lwm2mCore/3rdParty/wakaama",
"gerrit_review": {
"project": "external/eclipse/wakaama",
"patch_set": "63/60163/1"
}
}
]
}
"manifest_repo" is a string containing the URL of the repo manifest repository. Environment variables can be used to add a Gerrit user name, for example.
"base_manifest" is the path to the manifest XML file within the manifest repository.
"patches" is an array of objects. All such objects must have a "dir" member containing a the path to the directory under LEGATO_ROOT at which the patch should be applied. (When the patch is to be applied to LEGATO_ROOT, use "." or "" as the "dir" path, or omit the "dir" member altogether.)
The "purpose" member is an optional string used as a human-readable comment to document the reason why the patch is being applied.
In addition to "dir", all objects in the "patches" array must have either a "cherry_pick" member or a "gerrit_review" member.
The "cherry_pick" member is used when a fix is needed that has passed review and been submitted to the Legato master, but that was not included in the version of Legato that is checked out by the base manifest. This is typically needed to patch up known issues that have been fixed but have not yet made it into a Legato release. If the "cherry_pick" member is used, it must contain the git commit ID of a commit to be git cherry-picked into the HEAD from the same repository.
The "gerrit_review" member is used when the patch required has not yet even passed review in
Sierra Wireless's internal Gerrit instance.This is intended for emergency use only. The
value of the GERRIT_USER
environment variable will be used as the Gerrit user name when
fetching the patch.
The "gerrit_review" member is an object with two members:
- "project" specifies the Gerrit project name to fetch from within Sierra Wireless's internal Gerrit.
- "patch_set" identifies the Gerrit patch set to fetch and cherry-pick.
"octave": {
"ref": "BROOKLYN-2626_fix_makefile",
"version": "3.0.0.pre03Jun2020-mangOH-1"
}
Specifies the Octave Edge Package git repository ref to fetch and checkout when building Octave into the release. Also specifies the version string that is to be reported to the Octave cloud to ensure that the Octave cloud knows (and uses) the correct set of capabilities of the device's Octave Edge Package apps.
Specifies all board + module combinations to be built for, and what component parts need to be included in those builds.
"boards": {
"yellow": {
"wp76xx": {
"depends": [
"wp76-modem-image_13.3"
],
"modem_firmware": "9999999_9908787_SWI9X07Y_02.28.03.05_00_SIERRA_001.032_000.spk",
"yocto": {
"manifest_repo": "ssh://${GERRIT_USER}@master.gerrit.legato:29418/manifest.git",
"base_manifest": "mdm9x28/tags/SWI9X07Y_02.37.07.00.xml",
"add": [
{
"url": "/~https://github.com/mangOH/meta-mangoh",
"ref": "mdev_update_for_ecm",
"dir": "meta-mangoh"
}
]
}
},
"wp77xx": {
"depends": [
"wp77-modem-image_12"
],
"modem_firmware": "9999999_9908788_SWI9X06Y_02.32.02.00_00_SIERRA_001.027_000.spk",
"yocto": {
"manifest_repo": "/~https://github.com/mangOH/manifest.git",
"base_manifest": "mangOH/releases/v0.6.0/wp77xx.xml"
}
}
},
"red": {
"wp85": {
"depends": [
"wp85-toolchain_SWI9X15Y_07.14.01.00-linux64",
"wp85-linux-image_SWI9X15Y_07.14.01.00",
"wp85-modem-image_17"
],
"modem_firmware": "9999999_9904559_SWI9X15Y_07.14.01.00_00_GENERIC_001.042_000.spk"
}
}
}
"boards" is an object in which each member it an object that represents a single board, such as "red" or "yellow". The name of the member is the name of the board, and the value of the member is an object whose members represent modules, such as Sierra Wireless WP76xx.
The name of the module member must be the legato build "target" name, such as "wp85" or "wp76xx".
All modules must have a "depends" member, which is a list of all the leaf packages to be installed in the workspace when building for this module on this board. These leaf packages will also be added to the "depends" list within the mangOH SDK master leaf package for this particular board + module combination.
"depends": [
"wp85-toolchain_SWI9X15Y_07.14.01.00-linux64",
"wp85-linux-image_SWI9X15Y_07.14.01.00",
"wp85-modem-image_17"
],
The "modem_firmware" member specifies the name of the modem firmware SPK file from which the modem firmware files will be extracted for inclusion in the final release SPK file.
"modem_firmware": "9999999_9908787_SWI9X07Y_02.28.03.05_00_SIERRA_001.032_000.spk",
A "yocto" member can (optionally) be added when a custom Yocto linux distribution must be built for this module on this board. It specifies the Gerrit manifest repository URL and the path to the manifest XML file within that repository that is to be used to fetch the Yocto sources. Environment variables can be used within the fields to, for example, add the appropriate user name for gerrit.
"yocto": {
"manifest_repo": "ssh://${GERRIT_USER}@master.gerrit.legato:29418/manifest.git",
"base_manifest": "mdm9x28/tags/SWI9X07Y_02.37.07.00.xml",
"add": [
{
"url": "/~https://github.com/mangOH/meta-mangoh",
"ref": "mdev_update_for_ecm",
"dir": "meta-mangoh"
}
]
}
The "add" member within the "yocto" object is optional. It can be used to specify a list of other Git repositories that need to be cloned and checked out into the Yocto source tree before it is built. The "dir" path is relative to the root of the Yocto source tree.