mirror of
https://chromium.googlesource.com/crosvm/crosvm
synced 2025-02-11 04:26:38 +00:00
This removes some unsafe code, improving the interface so that it cannot be misused (e.g. previously, different Vec<u8> instances could be passed to fdt functions that did not validate the contents). The new implementation also adds some extra error checking to catch invalid string values in all API entry points that accept strings, as well as out-of-order node nesting that would result in DTB data that did not conform to the spec. BUG=b:175729255 TEST=cargo test -p arch TEST=Boot Crostini on kevin (arm) TEST=diff old and new dts from `dtc -I fs -O dts /proc/device-tree` Change-Id: I567d562ed1b447aa0d282b68c71758edea13ffc0 Reviewed-on: https://chromium-review.googlesource.com/c/chromiumos/platform/crosvm/+/2713569 Reviewed-by: Zach Reizner <zachr@chromium.org> Reviewed-by: Keiichi Watanabe <keiichiw@chromium.org> Reviewed-by: Dylan Reid <dgreid@chromium.org> Tested-by: kokoro <noreply+kokoro@google.com> Commit-Queue: Daniel Verkamp <dverkamp@chromium.org>
75 lines
2.4 KiB
Docker
75 lines
2.4 KiB
Docker
# Copyright 2021 The Chromium OS Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
#
|
|
# Docker container that cross-compiles crosvm for aarch64.
|
|
|
|
# Build-argument of the image tag of dependencies to use. Set to the same
|
|
# version as `ci/image_tag`
|
|
ARG TAG
|
|
|
|
# Stage containing VM data to be used later.
|
|
# (COPY --from does not allow the use of ARGs)
|
|
FROM gcr.io/crosvm-packages/crosvm_test_vm_arm64:${TAG} as vm
|
|
|
|
# Main stage
|
|
FROM gcr.io/crosvm-packages/crosvm_base:${TAG}
|
|
|
|
# Add repositories for arm64 packages
|
|
RUN dpkg --add-architecture arm64
|
|
|
|
# Install cross-compilation and VM tooling
|
|
RUN apt-get update && apt-get install --yes --no-install-recommends \
|
|
dpkg-dev \
|
|
g++-aarch64-linux-gnu \
|
|
gcc-aarch64-linux-gnu \
|
|
ipxe-qemu \
|
|
qemu-efi-aarch64 \
|
|
qemu-system-aarch64 \
|
|
qemu-user-static
|
|
|
|
RUN apt-get install --yes --no-install-recommends -o APT::Immediate-Configure=false \
|
|
libcap-dev:arm64 \
|
|
libdbus-1-dev:arm64 \
|
|
libdrm-dev:arm64 \
|
|
libepoxy-dev:arm64 \
|
|
libssl-dev:arm64 \
|
|
libwayland-dev:arm64
|
|
|
|
RUN apt-get install --yes -t testing --no-install-recommends \
|
|
libdrm-dev:arm64 \
|
|
libepoxy-dev:arm64
|
|
|
|
# Setup rust for cross-compilation
|
|
RUN rustup target add aarch64-unknown-linux-gnu
|
|
ENV CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER=aarch64-linux-gnu-gcc \
|
|
CC_aarch64_unknown_linux_gnu=aarch64-linux-gnu-gcc \
|
|
CXX_aarch64_unknown_linux_gnu=aarch64-linux-gnu-g++ \
|
|
CARGO_BUILD_TARGET=aarch64-unknown-linux-gnu \
|
|
PKG_CONFIG=aarch64-linux-gnu-pkg-config \
|
|
PKG_CONFIG_PATH=/workspace/scratch/lib/pkgconfig
|
|
|
|
# Allow GCC/Rust to find packages and libraries stored on the scratch volume. We
|
|
# have to link to a known search path since LIBRARY_PATH is not used by
|
|
# cross-compile GCC.
|
|
RUN ln -s /workspace/scratch/lib/ /usr/local/lib/aarch64-linux-gnu
|
|
|
|
# Hack: For some reason the libgcc-10-dev-arm64-cross package does not install
|
|
# this link correctly.
|
|
RUN cd /usr/aarch64-linux-gnu/lib && ln -s libgcc_s.so.1 libgcc_s.so
|
|
|
|
# Allow qemu-aarch64-static to find aarch64 libraries
|
|
ENV QEMU_LD_PREFIX=/usr/aarch64-linux-gnu
|
|
|
|
# Include test VM inside this container
|
|
COPY --from=vm \
|
|
/workspace/vm/* \
|
|
/workspace/vm/
|
|
COPY --from=vm \
|
|
/root/.ssh /root/.ssh
|
|
|
|
# Setup entrypoint and interactive shell
|
|
WORKDIR /workspace/src/platform/crosvm
|
|
COPY bashrc /root/.bashrc
|
|
COPY entrypoint /workspace
|
|
ENTRYPOINT ["/workspace/entrypoint"]
|