Skip to content

Commit

Permalink
[nix] replace streamLayeredImage to buildImage
Browse files Browse the repository at this point in the history
Proot have too many bugs to be fixed, it is better to use qemu to build
the docker image.

Signed-off-by: Avimitin <[email protected]>
  • Loading branch information
Avimitin committed May 27, 2024
1 parent c44bc92 commit 99087d3
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 24 deletions.
8 changes: 6 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -73,11 +73,15 @@ docker pull ghcr.io/chipsalliance/t1-blastoise:latest
```

Or build the image using nix and load it into docker

```bash
nix build -L ".#t1.$config.release.docker-layers.final-image"
docker load -i ./result/image.tar
nix build -L ".#t1.$config.release.docker-image" --out-link docker-image.tar.gz
docker load -i ./docker-image.tar.gz
```

> Using nix to build docker-image required KVM feature, so this derivation might not be available
> for some platform that has no QEMU/KVM support.
### Nix setup
We use Nix Flake as our primary build system. If you have not installed nix, install it following the [guide](https://nixos.org/manual/nix/stable/installation/installing-binary.html), and enable flake following the [wiki](https://nixos.wiki/wiki/Flakes#Enable_flakes). Or you can try the [installer](https://github.com/DeterminateSystems/nix-installer) provided by Determinate Systems, which enables flake by default.

Expand Down
2 changes: 1 addition & 1 deletion nix/t1/release/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ lib.makeScope newScope (scope: rec {
--add-flags "--emulator-path ${ip.emu-trace}/bin/emulator"
'';

docker-layers = scope.callPackage ./docker-layers.nix { };
docker-image = scope.callPackage ./docker-image.nix { };

doc = stdenvNoCC.mkDerivation {
name = "${configName}-typst-release-doc";
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
{ lib
# build deps
, dockerTools
, buildEnv
, runCommand
, runtimeShell

# Runtime deps
, bashInteractive
Expand All @@ -17,24 +19,27 @@
}:

let
# Don't use buildImage which relies on KVM feature
self = dockerTools.streamLayeredImage {
# dockerTools.buildImage relies on KVM feature, don't run it inside VMs
self = dockerTools.buildImage rec {
name = "chipsalliance/t1-${configName}";
tag = "latest";

contents = with dockerTools; [
usrBinEnv
binSh
copyToRoot = buildEnv {
name = "${name}.imageroot";
paths = with dockerTools; [
usrBinEnv
binSh

bashInteractive
which
bashInteractive
which

emulator-wrapped
]
++ rv32-stdenv.initialPath;
emulator-wrapped
] ++ rv32-stdenv.initialPath;
pathsToLink = [ "/bin" ];
};

enableFakechroot = true;
fakeRootCommands = ''
runAsRoot = ''
#!${runtimeShell}
echo "Start finalizing rootfs"
echo "Creating testcase directory"
Expand All @@ -46,21 +51,13 @@ let
done
chmod u+w -R /workspace/cases
mkdir /tmp
mkdir -p /tmp
'';

config = {
# Cmd = [ ];
WorkingDir = "/workspace";
};

passthru = {
final-image = runCommand "convert-layer-to-final-image" { } ''
mkdir $out
${bashInteractive}/bin/bash ${self} > $out/image.tar
'';
};
};
in
self

0 comments on commit 99087d3

Please sign in to comment.