Skip to content

Commit

Permalink
Try #764: --target x86_64-unknown-linux-gnu --target x86_64-unknown-l…
Browse files Browse the repository at this point in the history
…inux-gnu.centos
  • Loading branch information
bors[bot] authored Jun 14, 2022
2 parents 6a63e3a + 80891e7 commit ff0a3db
Show file tree
Hide file tree
Showing 7 changed files with 67 additions and 24 deletions.
13 changes: 8 additions & 5 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -102,15 +102,15 @@ jobs:
selects=()
for target in "${targets[@]}"; do
selects+=(".target == \"${target}\"")
selects+=(".target + (if .sub then \".\" + .sub else \"\" end) == \"${target}\"")
done
query=$(printf " or %s" "${selects[@]}")
query="${query:4}"
if [[ "${#targets[@]}" != "0" ]]; then
echo "Only running targets matching '${targets[@]}'."
matrix=$(
yq --output-format json '[.[] | select('"${query}"')]' <<< "${matrix}"
yq --output-format json <<< "${matrix}" | jq '[.[] | select('"${query}"')]'
)
else
echo 'Running all targets.'
Expand All @@ -134,6 +134,7 @@ jobs:
- { target: x86_64-unknown-linux-musl, os: ubuntu-latest, std: 1, run: 1, deploy: true }
- { target: x86_64-pc-windows-msvc, os: windows-2019, cpp: 1, std: 1, run: 1, deploy: true }
- { target: x86_64-unknown-linux-gnu, sub: centos, os: ubuntu-latest, cpp: 1, dylib: 1, std: 1, run: 1, runners: native qemu-user qemu-system }
- { target: aarch64-unknown-linux-gnu, os: ubuntu-latest, cpp: 1, dylib: 1, std: 1, run: 1, runners: qemu-user qemu-system }
- { target: arm-unknown-linux-gnueabi, os: ubuntu-latest, cpp: 1, dylib: 1, std: 1, run: 1 }
- { target: arm-unknown-linux-gnueabihf, os: ubuntu-latest, cpp: 1, dylib: 1, std: 1, run: 1 }
Expand Down Expand Up @@ -225,13 +226,14 @@ jobs:
labels: |
org.opencontainers.image.title=cross (for ${{ matrix.target }})
org.opencontainers.image.licenses=MIT OR Apache-2.0
- name: Build and push Docker image
- name: Build Docker image
id: build-docker-image
if: runner.os == 'Linux'
timeout-minutes: 60
run: cargo xtask build-docker-image -v "${TARGET}"
run: cargo xtask build-docker-image -v "${TARGET}${SUB:+.$SUB}"
env:
TARGET: ${{ matrix.target }}
SUB: ${{ matrix.sub }}
LABELS: ${{ steps.docker-meta.outputs.labels }}
shell: bash
- name: Set Docker image for test
Expand Down Expand Up @@ -287,9 +289,10 @@ jobs:
github.ref == format('refs/heads/{0}', github.event.repository.default_branch) ||
startsWith(github.ref, 'refs/tags/v')
)
run: cargo xtask build-docker-image -v --push "${TARGET}"
run: cargo xtask build-docker-image -v --push "${TARGET}${SUB:+.$SUB}"
env:
TARGET: ${{ matrix.target }}
SUB: ${{ matrix.sub }}
LABELS: ${{ steps.docker-meta2.outputs.labels }}
shell: bash

Expand Down
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ This project adheres to [Semantic Versioning](http://semver.org/).
- #725 - support `CROSS_DEBUG` and `CROSS_RUNNER` on android images.
- #714 - use host target directory when falling back to host cargo.
- #713 - convert relative target directories to absolute paths.
- #501 - x86_64-linux: lower glibc version requirement to 2.17 (compatible with centos 7)
- #501 (reverted, see #764) - x86_64-linux: lower glibc version requirement to 2.17 (compatible with centos 7)
- #500 - use runner setting specified in Cross.toml
- #498 - bump linux-image version to fix CI
- Re-enabled `powerpc64-unknown-linux-gnu` image
Expand Down
11 changes: 7 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -318,11 +318,12 @@ terminate.
| `x86_64-pc-windows-gnu` | N/A | 7.3 || N/A ||
| `x86_64-unknown-freebsd` | 1.5 | 6.4.0 || N/A | |
| `x86_64-unknown-dragonfly` [2] [3] | 6.0.1 | 5.3.0 || N/A | |
| `x86_64-unknown-linux-gnu` | 2.17 | 4.8.5 || 4.2.1 ||
| `x86_64-unknown-linux-gnu` | 2.23 | 5.4.0 || 5.1.0 ||
| `x86_64-unknown-linux-gnu:centos` [5] | 2.17 | 4.8.5 || 4.2.1 ||
| `x86_64-unknown-linux-musl` | 1.1.24 | 9.2.0 || N/A ||
| `x86_64-unknown-netbsd` [3] | 9.2.0 | 9.4.0 || N/A | |
<!--| `asmjs-unknown-emscripten` [5] | 1.2.2 | 3.1.10 | ✓ | N/A | ✓ |-->
<!--| `wasm32-unknown-emscripten` [5] | 1.2.2 | 3.1.10 | ✓ | N/A | ✓ |-->
<!--| `asmjs-unknown-emscripten` [6] | 1.2.2 | 3.1.10 | ✓ | N/A | ✓ |-->
<!--| `wasm32-unknown-emscripten` [6] | 1.2.2 | 3.1.10 | ✓ | N/A | ✓ |-->
<!--| `sparcv9-sun-solaris` [3] | 2.11 | 5.3.0 | ✓ | N/A | |-->
<!--| `x86_64-sun-solaris` [3] | 2.11 | 5.3.0 | ✓ | N/A | |-->

Expand All @@ -339,7 +340,9 @@ terminate.

[4] libc = newlib

<!--[5] libc = musl, gcc = emcc. The Docker images for these targets are currently not built automatically
[5] Must change `image = "x86_64-unknown-linux-gnu:centos"` in `Cross.toml` for `[target.x86_64-unknown-linux-gnu]` to use the CentOS7-compatible target.

<!--[6] libc = musl, gcc = emcc. The Docker images for these targets are currently not built automatically
due to a [compiler bug](https://github.com/rust-lang/rust/issues/85821), you will have to build them yourself for now.-->

## Debugging
Expand Down
9 changes: 2 additions & 7 deletions docker/Dockerfile.x86_64-unknown-linux-gnu
Original file line number Diff line number Diff line change
@@ -1,12 +1,6 @@
FROM ubuntu:16.04
ARG DEBIAN_FRONTEND=noninteractive

COPY lib.sh /
COPY linux-image.sh /
RUN /linux-image.sh x86_64

FROM centos:7

COPY common.sh lib.sh /
RUN /common.sh

Expand All @@ -22,7 +16,8 @@ RUN /qemu.sh x86_64 softmmu
COPY dropbear.sh /
RUN /dropbear.sh

COPY --from=0 /qemu /qemu
COPY linux-image.sh /
RUN /linux-image.sh x86_64

COPY linux-runner /

Expand Down
29 changes: 29 additions & 0 deletions docker/Dockerfile.x86_64-unknown-linux-gnu.centos
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
FROM ubuntu:16.04
ARG DEBIAN_FRONTEND=noninteractive

COPY lib.sh /
COPY linux-image.sh /
RUN /linux-image.sh x86_64

FROM centos:7

COPY common.sh lib.sh /
RUN /common.sh

COPY cmake.sh /
RUN /cmake.sh

COPY xargo.sh /
RUN /xargo.sh

COPY qemu.sh /
RUN /qemu.sh x86_64 softmmu

COPY dropbear.sh /
RUN /dropbear.sh

COPY --from=0 /qemu /qemu

COPY linux-runner /

ENV CARGO_TARGET_X86_64_UNKNOWN_LINUX_GNU_RUNNER="/linux-runner x86_64"
19 changes: 13 additions & 6 deletions xtask/src/build_docker_image.rs
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,13 @@ pub fn build_docker_image(
}

let dockerfile = format!("Dockerfile.{target}");

let (target, sub) = if let Some((t, sub)) = target.split_once('.') {
(t.to_owned(), format!("-{sub}"))
} else {
(target.to_owned(), "".to_owned())
};

let image_name = format!("{}/{target}", repository);
let mut tags = vec![];

Expand All @@ -129,28 +136,28 @@ pub fn build_docker_image(
if version != tag_version {
eyre::bail!("git tag does not match package version.")
}
tags.push(format!("{image_name}:{version}"));
tags.push(format!("{image_name}:{version}{sub}"));
// Check for unstable releases, tag stable releases as `latest`
if version.contains('-') {
// TODO: Don't tag if version is older than currently released version.
tags.push(format!("{image_name}:latest"))
tags.push(format!("{image_name}:latest{sub}"))
}
}
(Some(ref_type), Some(ref_name)) if ref_type == "branch" => {
tags.push(format!("{image_name}:{ref_name}"));
tags.push(format!("{image_name}:{ref_name}{sub}"));

if ["staging", "trying"]
.iter()
.any(|branch| branch != &ref_name)
{
tags.push(format!("{image_name}:edge"));
tags.push(format!("{image_name}:edge{sub}"));
}
}
_ => {
if push && tag_override.is_none() {
panic!("Refusing to push without tag or branch. Specify a repository and tag with `--repository <repository> --tag <tag>`")
}
tags.push(format!("{image_name}:local"))
tags.push(format!("{image_name}:local{sub}"))
}
}

Expand All @@ -164,7 +171,7 @@ pub fn build_docker_image(
} else {
docker_build.args(&[
"--cache-from",
&format!("type=registry,ref={image_name}:main"),
&format!("type=registry,ref={image_name}:main{sub}"),
]);
}

Expand Down
8 changes: 7 additions & 1 deletion xtask/src/target_info.sh
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,9 @@ max_glibc_version() {
# glibc versions have the following format:
# `libc-$major-$minor.so.$abi`, where the `.$abi` may be optional.
# shellcheck disable=SC2207
local -a paths=( $(ls "${1}"/libc-[0-9]*.[0-9]*.so*) )
local -a paths=( $(ls "${1}"/libc-[0-9]*.[0-9]*.so* 2>/dev/null) )
# shellcheck disable=SC2128
[ -z "$paths" ] && return 0
local major=0
local minor=0
local version
Expand Down Expand Up @@ -196,6 +198,10 @@ case "${target}" in
x86_64-unknown-linux-gnu)
libdir="/lib64/"
libc=$(max_glibc_version "${libdir}")
if [ "$libc" == "" ]; then
libdir="/lib/x86_64-linux-gnu/"
libc=$(max_glibc_version "${libdir}")
fi
;;
*-*-linux-gnu*)
toolchain_prefix="${!cc_var//-gcc/}"
Expand Down

0 comments on commit ff0a3db

Please sign in to comment.