From f4cce60e0e670af75684ae8a304d1d052de127b2 Mon Sep 17 00:00:00 2001 From: Enderson Maia Date: Thu, 11 Apr 2024 18:09:17 +0100 Subject: [PATCH] feat(cruntime): add package --- packages/cruntime/.gitignore | 1 + packages/cruntime/Dockerfile | 124 ++++++++++++++++++ packages/cruntime/README.md | 13 ++ packages/cruntime/docker-bake.hcl | 15 +++ packages/cruntime/docker-bake.override.hcl | 3 + packages/cruntime/package.json | 8 ++ .../skel/etc/cartesi-init.d/cruntime-init | 14 ++ packages/cruntime/skel/etc/subgid | 1 + packages/cruntime/skel/etc/subuid | 1 + 9 files changed, 180 insertions(+) create mode 100644 packages/cruntime/.gitignore create mode 100644 packages/cruntime/Dockerfile create mode 100644 packages/cruntime/README.md create mode 100644 packages/cruntime/docker-bake.hcl create mode 100644 packages/cruntime/docker-bake.override.hcl create mode 100644 packages/cruntime/package.json create mode 100755 packages/cruntime/skel/etc/cartesi-init.d/cruntime-init create mode 100644 packages/cruntime/skel/etc/subgid create mode 100644 packages/cruntime/skel/etc/subuid diff --git a/packages/cruntime/.gitignore b/packages/cruntime/.gitignore new file mode 100644 index 00000000..2cfbbcd6 --- /dev/null +++ b/packages/cruntime/.gitignore @@ -0,0 +1 @@ +.sunodo \ No newline at end of file diff --git a/packages/cruntime/Dockerfile b/packages/cruntime/Dockerfile new file mode 100644 index 00000000..facbf4b2 --- /dev/null +++ b/packages/cruntime/Dockerfile @@ -0,0 +1,124 @@ +# (c) Cartesi and individual authors (see AUTHORS) +# SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +# syntax=docker.io/docker/dockerfile:1 +ARG IMAGE_REGISTRY +ARG IMAGE_NAMESPACE +ARG IMAGE_NAME +ARG IMAGE_TAG +ARG TARGETARCH + +############################################################################### +# STAGE: base-image +# +# This stage creates a base-image with apt repository cache and ca-certificates +# to be used by later stages. +FROM ${IMAGE_REGISTRY}/${IMAGE_NAMESPACE}/${IMAGE_NAME}:$IMAGE_TAG AS base-image +ARG DEBIAN_FRONTEND=noninteractive +RUN apt-get update && apt-get install -y --no-install-recommends ca-certificates + + +############################################################################### +# STAGE: chisel +# +# Build the chiselled filesystem based on the desired slices. +# This image should have the machine-emulator-tools and crun dependencies +# installed. +# +#FIXME: replace the image with the official one when it's available +# from: docker.io/risv64/ubuntu to: docker.io/library/ubuntu +FROM base-image AS chisel +ARG TARGETARCH + +WORKDIR /rootfs + +# Extract machine-emulator-tools into the chiselled filesystem +ARG MACHINE_EMULATOR_TOOLS_VERSION +ADD https://github.com/cartesi/machine-emulator-tools/releases/download/v${MACHINE_EMULATOR_TOOLS_VERSION}/machine-emulator-tools-v${MACHINE_EMULATOR_TOOLS_VERSION}.deb / +RUN dpkg -x /machine-emulator-tools-v${MACHINE_EMULATOR_TOOLS_VERSION}.deb /rootfs + +# Get chisel binary +ARG CHISEL_VERSION +ADD "https://github.com/canonical/chisel/releases/download/v${CHISEL_VERSION}/chisel_v${CHISEL_VERSION}_linux_${TARGETARCH}.tar.gz" chisel.tar.gz +RUN tar -xvf chisel.tar.gz -C /usr/bin/ + +# Extract crun dependencies into the chiselled filesystem +# FIXME: remove this when crun's dependecies slices are upstream +ADD https://github.com/endersonmaia/chisel-releases.git#0ce6657c093a38267d65e7d9275a45e22b162942 /chisel-22.04 +RUN chisel cut \ + --release /chisel-22.04 \ + --root /rootfs \ + --arch=${TARGETARCH} \ + base-files_base \ + base-files_release-info \ + base-passwd_data \ + busybox-static_bins \ + libc6_libs \ + libcap2_libs \ + libgcc-s1_libs \ + libseccomp2_libs \ + libstdc++6_libs \ + libyajl2_libs \ + uidmap_bins + +# Prepare the chiselled filesystem with the necessary configuration +# some directories, dapp user and root's shell +RUN <> etc/passwd +echo "dapp:x:1000:" >> etc/group +mkdir home/dapp +chown 1000:1000 home/dapp +sed -i '/^root/s/bash/sh/g' etc/passwd +EOF +############################################################################### +# STAGE: crun-builder +# +# Build most recent version of the crun binary to be used at final image. +# +FROM base-image AS crun-builder +ARG DEBIAN_FRONTEND=noninteractive +RUN < a220ca661ce078f2c37b38c92e66cf66c012d9c1 +ADD --keep-git-dir https://github.com/containers/crun.git#a220ca661ce078f2c37b38c92e66cf66c012d9c1 /usr/local/src +RUN < /sys/fs/cgroup/cgroup.subtree_control + +# give user group access to /cruntime +UID=$(busybox id -u ${USER:-dapp}) +GID=$(busybox id -g ${USER:-dapp}) + +[ -d /run ] && busybox mkdir -p /run/crun +[ -d /run ] && busybox mkdir -p /run/cruntime +[ -d /run/crun ] && busybox chown -R $UID:$GID /run/crun +[ -d /run/cruntime ] && busybox chown -R $UID:$GID /run/cruntime diff --git a/packages/cruntime/skel/etc/subgid b/packages/cruntime/skel/etc/subgid new file mode 100644 index 00000000..0c5d3a2d --- /dev/null +++ b/packages/cruntime/skel/etc/subgid @@ -0,0 +1 @@ +dapp:100000:65536 diff --git a/packages/cruntime/skel/etc/subuid b/packages/cruntime/skel/etc/subuid new file mode 100644 index 00000000..5f6d057d --- /dev/null +++ b/packages/cruntime/skel/etc/subuid @@ -0,0 +1 @@ +dapp:100000:65536 \ No newline at end of file