KEMBAR78
Multi-arch build configurations (armhf/arm64) for Travis CI by headmelted · Pull Request #24943 · microsoft/vscode · GitHub
Skip to content

Conversation

@headmelted
Copy link
Contributor

This pull request takes the subset of the work done for my Raspberry Pi / Chromebook builds that could be useful to have in the core code and adapts it for some of the restrictions encountered on Travis CI as discussed below.

Some additions have been made to the Travis scripts to support reproducible ARM builds alongside the existing Linux and OSX amd64 builds.

The changes aim to keep the existing build configurations intact and operating exactly as before (listed in the YAML as &toolchain_linux_amd64 and &toolchain_osx_amd64) to prevent breaking anything.

The YAML has been re-structured to be a little more modular owing to the greater number of build configurations (listed under the matrix: node).

The intention of this pull request is to allow for additional cross-compilation targets to more easily be added to the Travis CI builds (with a view to expanding the officially supported platforms in the future), and provides hard-float ARM (armhf) and ARMv8 (arm64) configurations right now that should build immediately.

How this works

When the CROSS_TOOLCHAIN environment variable is set to true for a build configuration, an alternate toolchain will be prepared that uses the Travis CI trusty container, and re-creates the source packages list on the host VM to scope amd64 and i386 architectures to the main Ubuntu repositories, and the current target architecture (as defined by the ARCH environment variable) to the Ubuntu Ports repository. Unfortunately, due to the Travis CI whitelist freeze, and the need to reconfigure dpkg for an additional architecture, sudo is required for this process, which slightly increases the bootstrap time for the build session (although in my testing no more than was already required for the OSX builds, and they happen in parallel). As the automated testing currently runs on the amd64 builds (which happen faster due to not requiring sudo), this change should not increase the overall time for a given commit to build and "greenlight" successfully (in my test runs the cross-compilation builds generally finish before the amd64 builds have completed running tests/coveralls).

As some dependencies are historically not as well supported on other architectures as they are on amd64, it was necessary when re-creating the architecture-scoped package lists to point to the 16.04 (Xenial Xerus) repositories rather than the 14.04 (Trusty Tahr) repositories, not least as the cross-compilation step by GCC requires that the dependencies on amd64 and a given alternate architecture are version matched also.

The target architecture is provided in the form of a triplet (by way of the GNU_TRIPLET environment variable). If the dependencies for a given target require multilib support, as is the case for the arm64 target, this can be provided by the GNU_MULTILIB_TRIPLET environment variable.

The GPP_COMPILER and GCC_COMPILER environment variables directly correspond to the CXX and CC variables, and overwrite them as a first step of the build script. The reason for not directly setting the CXX and CC variables is that Travis CI will overwrite them for the cpp image while bootstrapping the build session, and this provides a workaround.

npm and Electron have a single ARM configuration at the present time which is broadly ARMv7l armhf, which is specified to the build script by way of the NPM_ARCH and VSCODE_ELECTRON_PLATFORM variables. As ARMv8 is backwards compatible, this should not pose a problem for 64-bit users.

Some repetition could have been saved by using the triplet name to build the g++ and gcc compiler references, but I decided against doing so as this does not hold true as a pattern for all targets (mingw, for example, has a slightly alternated naming convention).

In theory, adding support for architectures such as MIPS/PowerPC/SPARC should be as simple as adding a matrix entry and the triplet name, but I'm unsure if this is overkill as it seems unlikely that there would be demand on those platforms (old pre-2006 Macs that have since switched to Linux, maybe?).

If I can be of any assistance with this change please feel free to contact me on here or on twitter (@headmelted).

This change adds support for builds that target armhf/arm64 configurations alongside the current amd64 builds, which should bring support for single-board computers such as Raspberry Pi and Odroid into the core.

Due to the Travis white-list freeze, the configuration for this process uses the 14.04 Trusty Tahr container, and uses the 16.04 Xenial Xerus repositories on ports.ubuntu.com to prepare a toolchain that contains the necessary dependencies for ARM cross-compilation.

The arm64 configuration above will also use the same armhf dependencies as those builds for things like ripgrep.  This should not pose an issue for users due to the backwards compatibility for ARMv8.
Dummy edit to trigger a final Travis CI build to test before issuing pull request
@mention-bot
Copy link

@headmelted, thanks for your PR! By analyzing the history of the files in this pull request, we identified @joaomoreno and @jrieken to be potential reviewers.

@kieferrm kieferrm mentioned this pull request May 8, 2017
44 tasks
@joaomoreno joaomoreno removed their request for review May 9, 2017 14:22
@joaomoreno joaomoreno assigned egamma and chrisdias and unassigned joaomoreno May 9, 2017
@microsoft microsoft deleted a comment from msftclas Sep 26, 2017
@microsoft microsoft deleted a comment from msftclas Sep 26, 2017
@alexdima alexdima removed this from the May 2017 milestone Dec 12, 2017
@joaomoreno
Copy link
Member

Closed per #52119 (comment)

@joaomoreno joaomoreno closed this Sep 11, 2018
@github-actions github-actions bot locked and limited conversation to collaborators Mar 30, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

8 participants