forked from keystone-enclave/keystone-demo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathquick-start.sh
executable file
·93 lines (76 loc) · 2.61 KB
/
quick-start.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/bin/bash
set -e
echo -e "This is a quick-start build script for the Keystone Demo, it
will clone and build all the necessary parts to run the demo
server/applcation and client on a RISC-V platform (ex: qemu). Please
ensure you have cloned keystone completely and that you have fully
built the sdk tests and run them successfully in qemu.
You must set KEYSTONE_SDK_DIR to the install directory of Keystone SDK.
You must have the riscv64 gcc on-path as well. (e.g. run
'source source.sh' in the Keystone directory.
If you have already started building libsodium/etc, it is not
recommended to use this script."
read -r -p "Continue? [Y/n] " response
response=${response,,}
if [[ "$response" =~ ^(no|n)$ ]]
then
exit 0
fi
# Check location/tools
if [[ ! -v KEYSTONE_SDK_DIR ]]
then
echo "KEYSTONE_SDK_DIR not set! Please set this to the location where Keystone SDK has been installed."
exit 0
fi
if [[ ! -v SM_HASH ]]
then
echo "SM_HASH is not set! Please follow README to generate the expected hash"
exit 0
fi
if [[ ! $(command -v riscv64-unknown-linux-gnu-gcc) ]]
then
echo "No riscv64 gcc available. Make sure you've run \"source source.sh\" in the Keystone directory (or equivalent.)";
exit 0
fi
DEMO_DIR=$(pwd)
set -e
mkdir -p libsodium_builds
cd libsodium_builds
# Clone, checkout, and build the server libsodium
if [ ! -d libsodium_server ]
then
git clone https://github.com/jedisct1/libsodium.git libsodium_server
cd libsodium_server
git checkout 4917510626c55c1f199ef7383ae164cf96044aea
patch -p1 < $DEMO_DIR/sodium_patches/configure.ac.patch
./autogen.sh
./configure --host=riscv64-unknown-linux-gnu --disable-ssp --disable-asm --without-pthreads
make
cd ..
fi
export LIBSODIUM_DIR=$(pwd)/libsodium_server/src/libsodium/
# Clone, checkout, and build the client libsodium
if [ ! -d libsodium_client ]
then
git clone https://github.com/jedisct1/libsodium.git libsodium_client
cd libsodium_client
git checkout 4917510626c55c1f199ef7383ae164cf96044aea
./configure --host=riscv64-unknown-linux-gnu --disable-ssp --disable-asm --without-pthreads
make
cd ..
fi
export LIBSODIUM_CLIENT_DIR=$(pwd)/libsodium_client/src/libsodium/
cd ..
# Copy the expected hash over
echo "Copying expected sm hash from riscv-pk, this may be incorrect!"
cp $SM_HASH include/
# Build the demo
mkdir -p build
cd build
cmake -DCMAKE_BUILD_TYPE=Debug ..
make
make packagedemo
# Done!
echo -e "************ Demo binaries built and copied into overlay directory. ***************
Run 'make image' in the Keystone build dir, and the demo binaries should
be available in qemu next time you start it!"