Skip to content

Commit

Permalink
use Dockerfile for reproducible build
Browse files Browse the repository at this point in the history
The reproducibility of td-shim is limited by the same system user and
source code path, so we can use Docker container to reproduce binaries.

Signed-off-by: Jiaqi Gao <[email protected]>
  • Loading branch information
gaojiaqi7 committed Oct 9, 2023
1 parent 4da7dfc commit 8ce4afb
Show file tree
Hide file tree
Showing 3 changed files with 72 additions and 0 deletions.
12 changes: 12 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,18 @@ REF: https://github.com/tianocore/edk2-staging/tree/TDVF
./launch-rust-td.sh
```

## Reproducible Build
Reproducible build of td-shim binary requires same system user and
source code path (see https://github.com/confidential-containers/td-shim/issues/604).

The [Dockerfile](./Dockerfile) is provided to build the docker image with
the `td-shim` compilation environment for reproducible build. You can use
the [docker.sh](./sh_script/docker.sh) to build and run the docker container:

```
./sh_script/docker.sh -f devtools/dev_container
```

## Code Contributions

1. install [pre-commit](https://pre-commit.com/#install)
Expand Down
2 changes: 2 additions & 0 deletions devtools/dev_container/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -37,3 +37,5 @@ RUN set -eux; \
git clone https://github.com/sslab-gatech/Rudra.git; \
cd Rudra; \
./install-release.sh;

RUN git clone https://github.com/confidential-containers/td-shim.git
58 changes: 58 additions & 0 deletions sh_script/docker.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#!/bin/bash
set -e

FOLDER=""

usage() {
cat << EOM
Usage: $(basename "$0") [OPTION]...
-d <docker file> Path of Dockerfile.
EOM
}

error() {
echo -e "\e[1;31mERROR: $*\e[0;0m"
exit 1
}

process_args() {
while getopts ":f:h" option; do
case "$option" in
f) FOLDER=$OPTARG;;
h) usage
exit 0
;;
*)
echo "Invalid option '-$OPTARG'"
usage
exit 1
;;
esac
done

if [[ -z ${FOLDER} ]]; then
error "Please specify the folder of where the Dockerfile is located through -f."
fi

if [[ ! -f "${FOLDER}/Dockerfile" ]]; then
error "Dockerfile does not exist."
fi
}

process_args $@

pushd ${FOLDER}

# If the docker image does not exist, build the docker image
set +e && docker image inspect tdshim.build.env:latest > /dev/null 2>&1 && set -e
if [ $? != 0 ]; then
docker build -t tdshim.build.env \
--build-arg https_proxy=$https_proxy \
--build-arg http_proxy=$http_proxy \
.
fi

popd

# Run the docker image
docker run -it --rm tdshim.build.env

0 comments on commit 8ce4afb

Please sign in to comment.