aboutsummaryrefslogtreecommitdiff
path: root/docker
diff options
context:
space:
mode:
Diffstat (limited to 'docker')
-rw-r--r--docker/aarch64/build.sh3
-rwxr-xr-xdocker/aarch64/qemu-aarch64-staticbin0 -> 3451880 bytes
-rwxr-xr-xdocker/aarch64/resin-xbuildbin0 -> 1422176 bytes
-rw-r--r--docker/aarch64/resin-xbuild.go66
4 files changed, 69 insertions, 0 deletions
diff --git a/docker/aarch64/build.sh b/docker/aarch64/build.sh
new file mode 100644
index 00000000..d864f4b3
--- /dev/null
+++ b/docker/aarch64/build.sh
@@ -0,0 +1,3 @@
+#!/bin/bash
+
+go build -ldflags "-w -s" resin-xbuild.go
diff --git a/docker/aarch64/qemu-aarch64-static b/docker/aarch64/qemu-aarch64-static
new file mode 100755
index 00000000..f44233bc
--- /dev/null
+++ b/docker/aarch64/qemu-aarch64-static
Binary files differ
diff --git a/docker/aarch64/resin-xbuild b/docker/aarch64/resin-xbuild
new file mode 100755
index 00000000..3996ea53
--- /dev/null
+++ b/docker/aarch64/resin-xbuild
Binary files differ
diff --git a/docker/aarch64/resin-xbuild.go b/docker/aarch64/resin-xbuild.go
new file mode 100644
index 00000000..84cf7b66
--- /dev/null
+++ b/docker/aarch64/resin-xbuild.go
@@ -0,0 +1,66 @@
+package main
+
+import (
+ "log"
+ "os"
+ "os/exec"
+ "syscall"
+)
+
+func crossBuildStart() {
+ err := os.Remove("/bin/sh")
+ if err != nil {
+ log.Fatal(err)
+ }
+ err = os.Link("/usr/bin/resin-xbuild", "/bin/sh")
+ if err != nil {
+ log.Fatal(err)
+ }
+}
+
+func crossBuildEnd() {
+ err := os.Remove("/bin/sh")
+ if err != nil {
+ log.Fatal(err)
+ }
+ err = os.Link("/bin/sh.real", "/bin/sh")
+ if err != nil {
+ log.Fatal(err)
+ }
+}
+
+func runShell() error {
+ cmd := exec.Command("/usr/bin/qemu-aarch64-static", append([]string{"-0", "/bin/sh", "/bin/sh"}, os.Args[1:]...)...)
+ cmd.Stdin = os.Stdin
+ cmd.Stdout = os.Stdout
+ cmd.Stderr = os.Stderr
+ return cmd.Run()
+}
+
+func main() {
+ switch os.Args[0] {
+ case "cross-build-start":
+ crossBuildStart()
+ case "cross-build-end":
+ crossBuildEnd()
+ case "/bin/sh":
+ code := 0
+ crossBuildEnd()
+
+ if err := runShell(); err != nil {
+ code = 1
+ if exiterr, ok := err.(*exec.ExitError); ok {
+ if status, ok := exiterr.Sys().(syscall.WaitStatus); ok {
+ code = status.ExitStatus()
+ }
+ }
+ }
+
+ crossBuildStart()
+
+ // Hack to bypass apk issues with triggering
+ code = 0
+
+ os.Exit(code)
+ }
+}