summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Dockerfile12
1 files changed, 12 insertions, 0 deletions
diff --git a/Dockerfile b/Dockerfile
index 08b48f97fe..1abd6c2230 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -547,6 +547,12 @@ WORKDIR /go/src/github.com/docker/docker
ENV GO111MODULE=off
ENV CGO_ENABLED=1
ARG DEBIAN_FRONTEND
+RUN --mount=type=cache,sharing=locked,id=moby-build-aptlib,target=/var/lib/apt \
+ --mount=type=cache,sharing=locked,id=moby-build-aptcache,target=/var/cache/apt \
+ apt-get update && apt-get install --no-install-recommends -y \
+ clang \
+ lld \
+ llvm
ARG TARGETPLATFORM
RUN --mount=type=cache,sharing=locked,id=moby-build-aptlib,target=/var/lib/apt \
--mount=type=cache,sharing=locked,id=moby-build-aptcache,target=/var/cache/apt \
@@ -573,6 +579,12 @@ ARG PACKAGER_NAME
# PREFIX overrides DEST dir in make.sh script otherwise it fails because of
# read only mount in current work dir
ENV PREFIX=/tmp
+RUN <<EOT
+ # in bullseye arm64 target does not link with lld so configure it to use ld instead
+ if xx-info is-cross && [ "$(xx-info arch)" = "arm64" ]; then
+ XX_CC_PREFER_LINKER=ld xx-clang --setup-target-triple
+ fi
+EOT
RUN --mount=type=bind,target=. \
--mount=type=tmpfs,target=cli/winresources/dockerd \
--mount=type=tmpfs,target=cli/winresources/docker-proxy \