summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRunar Borge <runar@borge.nu>2020-07-09 23:09:21 +0200
committerRunar Borge <runar@borge.nu>2020-07-14 12:30:40 +0200
commit60d36ca64f43167595077edff287d7ef29eb3b60 (patch)
treee2f299171d349cf634152031f4de9b4b02d94397
parentc7b0a8897cfa8573993f593fc2ed61e981a745a0 (diff)
downloadvyos-build-60d36ca64f43167595077edff287d7ef29eb3b60.tar.gz
vyos-build-60d36ca64f43167595077edff287d7ef29eb3b60.zip
T1927: arm: Readd CI build of emulated ARM64 container
After a successfull CI build of this container it is considered working and is possible to add back to the build as a standard target. The container is changed so it handles an architecture change without changing the dockerfile
-rw-r--r--Jenkinsfile43
-rw-r--r--docker/Dockerfile28
2 files changed, 34 insertions, 37 deletions
diff --git a/Jenkinsfile b/Jenkinsfile
index c2ec90a5..17f0ca51 100644
--- a/Jenkinsfile
+++ b/Jenkinsfile
@@ -49,11 +49,7 @@ node('Docker') {
script {
dir('docker') {
sh """
- mkdir -p x86-64
- cp Dockerfile x86-64/Dockerfile
- cp entrypoint.sh x86-64/entrypoint.sh
-
- docker build -t ${env.DOCKER_IMAGE} x86-64
+ docker build -t ${env.DOCKER_IMAGE} .
"""
if ( ! isCustomBuild()) {
withDockerRegistry([credentialsId: "DockerHub"]) {
@@ -81,26 +77,23 @@ node('Docker') {
// }
// }
// },
-// 'arm64': {
-// script {
-// dir('docker') {
-// sh """
-// cp Dockerfile arm64/Dockerfile
-// cp entrypoint.sh arm64/entrypoint.sh
-// sed -i 's#^FROM.*#FROM multiarch/debian-debootstrap:arm64-buster-slim#' arm64/Dockerfile
-// docker build -t ${env.DOCKER_IMAGE_ARM64} arm64
-//
-// """
-//
-// if ( ! isCustomBuild()) {
-// withDockerRegistry([credentialsId: "DockerHub"]) {
-// sh "docker push ${env.DOCKER_IMAGE_ARM64}"
-//
-// }
-// }
-// }
-// }
-// }
+ 'arm64': {
+ script {
+ dir('docker') {
+ sh """
+ docker build -t ${env.DOCKER_IMAGE_ARM64} --build-arg ARCH=arm64v8/ .
+
+ """
+
+ if ( ! isCustomBuild()) {
+ withDockerRegistry([credentialsId: "DockerHub"]) {
+ sh "docker push ${env.DOCKER_IMAGE_ARM64}"
+
+ }
+ }
+ }
+ }
+ }
)
}
}
diff --git a/docker/Dockerfile b/docker/Dockerfile
index b2a5315c..c892b64b 100644
--- a/docker/Dockerfile
+++ b/docker/Dockerfile
@@ -17,22 +17,26 @@
# volume mapped in order to easy export images
# This Dockerfile is installable on both x86, x86-64, armhf and arm64 systems
-# To install using native cpu instructionset use the default docker `FROM` statement
-# (Use this to build on an x86/x86-64 pc/server and on an ARM system, eg. RaspberryPi)
-FROM debian:buster
+ARG ARCH=
+FROM ${ARCH}debian:buster
# It is also possible to emulate an arm system inside docker,
# execution of this emulated system needs to be executed on an x86 or x86-64 host.
-# To install an qemu emulated armhf or arm64 cpu comment out the default `FROM` statement
-# and use one of the following instead.
-# ARMHF:
-#FROM multiarch/debian-debootstrap:armhf-buster-slim
-# ARM64:
-#FROM multiarch/debian-debootstrap:arm64-buster-slim
-
-# Prior of installing an emulated qemu build you need to install qemu, qemu-user-static
-# and register qemu inside docker using:
+# To install using a non-native cpu instructionset use the `--build-arg ARCH=<ARCH>/`
+# Supported architectures:
+# arm32v6/
+# arm32v7/
+# arm64v8/
+# Example bo byukd natively:
+# docker build -t vyos-build:current .
+# Example to build on armhf:
+# docker build -t vyos-build:current-armhf --build-arg ARCH=arm32v7/ .
+# Example to build on arm64:
+# docker build -t vyos-build:current-arm64 --build-arg ARCH=arm64v8/ .
+
+# On some versions of docker the emulation framework is not installed by default and
+# you need to install qemu, qemu-user-static and register qemu inside docker manually using:
# `docker run --rm --privileged multiarch/qemu-user-static:register --reset`