本项目提供提供了以Docker容器形式的构建开发环境,可以使用如下命令拉取构建开发环境的镜像。
docker pull ghcr.io/inclavare-containers/rats-rs:master
或者也可以直接以Dockerfile的形式构建
git clone [email protected]:inclavare-containers/rats-rs.git
cd rats-rs
docker build --tag rats-rs:master .
接着根据不同的TEE类型,使用相应命令启动环境
-
SGX实例:
docker run -it --privileged --device=/dev/sgx_enclave --device=/dev/sgx_provision rats-rs:master bash
-
TDX实例:
docker run -it --privileged --device=/dev/tdx_guest rats-rs:master bash
下面提供Ubuntu 22.04发行版上的依赖安装流程,在其它发行版上的流程比较类似,可以参考Intel_SGX_SW_Installation_Guide_for_Linux.pdf。
-
安装基础依赖库
echo "deb http://cn.archive.ubuntu.com/ubuntu bionic main" >> /etc/apt/sources.list apt-get update apt-get install -y libprotobuf10 make git vim clang-format-9 gcc \ pkg-config protobuf-compiler debhelper cmake \ wget net-tools curl file gnupg tree libcurl4-openssl-dev \ libbinutils libseccomp-dev libssl-dev binutils-dev libprotoc-dev \ clang jq
-
安装Rust工具链
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y --no-modify-path
将下面语句添加到
~/.bashrc
末尾export PATH=/root/.cargo/bin:$PATH
(Optional)安装用于计算代码覆盖率的工具
llvm-tools-preview
rustup component add llvm-tools-preview
-
本项目使用just工具来封装本项目的构建、测试、运行流程,因此首先需要安装just。
cargo install just
-
安装Intel SGX LVI mitigated toolchain
wget https://download.01.org/intel-sgx/sgx-linux/$SGX_SDK_VERSION/as.ld.objdump.r4.tar.gz && \ tar -zxvf as.ld.objdump.r4.tar.gz && cp -rf external/toolset/ubuntu20.04/* /usr/local/bin/ && \ rm -rf external && rm -rf as.ld.objdump.r4.tar.gz
-
安装Intel SGX SDK
依赖于Intel SGX SDK version >= 2.23
SGX_SDK_VERSION=2.23 SGX_SDK_RELEASE_NUMBER=2.23.100.2 wget https://download.01.org/intel-sgx/sgx-linux/$SGX_SDK_VERSION/distro/ubuntu20.04-server/sgx_linux_x64_sdk_$SGX_SDK_RELEASE_NUMBER.bin && \ chmod +x sgx_linux_x64_sdk_$SGX_SDK_RELEASE_NUMBER.bin && \ echo -e 'no\n/opt/intel\n' | ./sgx_linux_x64_sdk_$SGX_SDK_RELEASE_NUMBER.bin
-
安装SGX DCAP软件包
引入Intel官方提供的在线apt repo
echo "deb [arch=amd64] https://download.01.org/intel-sgx/sgx_repo/ubuntu focal main" | tee /etc/apt/sources.list.d/intel-sgx.list && \ wget -qO - https://download.01.org/intel-sgx/sgx_repo/ubuntu/intel-sgx-deb.key | apt-key add - apt-get update -y
安装SGX DCAP软件包
SGX_SDK_VERSION=2.23 SGX_DCAP_VERSION=1.20 apt-get update -y && apt-get install -y libsgx-headers="$SGX_SDK_VERSION*" \ libsgx-uae-service="$SGX_SDK_VERSION*" \ libsgx-dcap-quote-verify-dev="$SGX_DCAP_VERSION*" \ libsgx-dcap-ql-dev="$SGX_DCAP_VERSION*" \ libsgx-dcap-default-qpl-dev="$SGX_DCAP_VERSION*"
-
安装occlum,用于在occlum环境中运行rats-rs样例程序
echo 'deb [arch=amd64] https://occlum.io/occlum-package-repos/debian focal main' | tee /etc/apt/sources.list.d/occlum.list wget -qO - https://occlum.io/occlum-package-repos/debian/public.key | apt-key add - apt-get update apt-get install -y libfuse2 occlum occlum-toolchains-glibc
将下面语句添加到
~/.bashrc
末尾export PATH="/opt/occlum/build/bin:${PATH}"
-
(针对TDX实例)安装TDX Attestation library
SGX_DCAP_VERSION=1.20 apt-get install -y libtdx-attest-dev="$SGX_DCAP_VERSION*"
如果你准备单独构建该项目,或者简单尝试该项目中提供的样例程序,可以使用如下方法来构建代码
-
拉取源码
git clone [email protected]:inclavare-containers/rats-rs.git cd rats-rs
-
准备
just prepare-repo
-
构建项目
cargo build
-
(可选)构建样例程序
cargo build -p spdm
对于如何运行样例程序,请参考examples目录下的例子。