Browse Source

Update README by reorganize the section of building Graphene-SGX (#236)

Li Lei 6 years ago
parent
commit
cd87b11b6f
1 changed files with 53 additions and 15 deletions
  1. 53 15
      README.md

+ 53 - 15
README.md

@@ -74,7 +74,7 @@ To build Graphene library OS with debug symbols, run "make DEBUG=1" instead of
 
 
 __** Note: this step is optional. **__
 __** Note: this step is optional. **__
 
 
-__** Note: for building with Intel:registered: SGX support, skip this step. **__
+__** Note: for building with Intel:registered: SGX support, skip this step, go to section 2.2 **__
 
 
 __** Disclaimer: this feature is experimental and may contain bugs. Please do
 __** Disclaimer: this feature is experimental and may contain bugs. Please do
    no use in production system before further assessment.__
    no use in production system before further assessment.__
@@ -103,32 +103,31 @@ For more details about the building and installation, see the Graphene github
 Wiki page: <https://github.com/oscarlab/graphene/wiki>.
 Wiki page: <https://github.com/oscarlab/graphene/wiki>.
 
 
 
 
-### 2-1. BUILD WITH INTEL:registered: SGX SUPPORT
+### 2.2 BUILD WITH INTEL:registered: SGX SUPPORT
 
 
-To build Graphene Library OS with Intel SGX support, run "make SGX=1" instead
-of "make". "DEBUG=1" can be used to build with debug symbols. Using "make SGX=1"
-in the test or regression directory will automatically generate the enclave
-signatures (in .sig files).
+__2.1.1 Prerequisites 
 
 
+(1) Generating signing keys
 A 3072-bit RSA private key (PEM format) is required for signing the enclaves.
 A 3072-bit RSA private key (PEM format) is required for signing the enclaves.
-The default enclave key is placed in 'host/Linux-SGX/signer/enclave-key.pem',
-or the key can be specified through environment variable 'SGX_ENCLAVE_KEY'
-when building Graphene with Intel SGX support. If you don't have a private key,
-create it with the following command:
+If you don't have a private key, create it with the following command:
 
 
     openssl genrsa -3 -out enclave-key.pem 3072
     openssl genrsa -3 -out enclave-key.pem 3072
 
 
+You could either put the generated enclave key to the default path,
+'host/Linux-SGX/signer/enclave-key.pem', or specify the key through environment
+variable 'SGX_ENCLAVE_KEY' when building Graphene with SGX support. 
+
 After signing the enclaves, users may ship the application files with the
 After signing the enclaves, users may ship the application files with the
 built Graphene Library OS, along with a SGX-specific manifest (.manifest.sgx
 built Graphene Library OS, along with a SGX-specific manifest (.manifest.sgx
-files) and the signatures, to the Intel SGX-enabled hosts. The Intel SGX
-Linux SDK is required for running Graphene Library OS. Download and install
+files) and the signatures, to the SGX-enabled hosts.
+
+(2) Installing Intel SGX SDK and driver
+The Intel SGX Linux SDK is required for running Graphene Library OS. Download and install
 from the official Intel github repositories:
 from the official Intel github repositories:
 
 
    - <https://github.com/01org/linux-sgx>
    - <https://github.com/01org/linux-sgx>
    - <https://github.com/01org/linux-sgx-driver>
    - <https://github.com/01org/linux-sgx-driver>
 
 
-__(The SDK and driver version must be 1.9 or LOWER)__
-
 A Linux driver must be installed before runing Graphene Library OS in enclaves.
 A Linux driver must be installed before runing Graphene Library OS in enclaves.
 Simply run the following command to build the driver:
 Simply run the following command to build the driver:
 
 
@@ -139,10 +138,49 @@ __** Please make sure the GCC version is either 4 or 5 **__
     (The console will be prompted to ask for the path of Intel SGX driver code)
     (The console will be prompted to ask for the path of Intel SGX driver code)
     sudo ./load.sh
     sudo ./load.sh
 
 
-Finally generating the runtime enclave tokens by running "make SGX_RUN=1".
+__2.1.2 Building Graphene-SGX
+
+To build Graphene Library OS with Intel SGX support, in the root directory of Graphene repo, run following command:
+
+    make SGX=1
+
+To build with debug symbols, run the command:
+
+    make SGX=1 DEBUG=1
+
+Using "make SGX=1" in the test or regression directory will automatically generate the enclave signatures (.sig files).
+
+__2.1.3 Run Built-in Examples in Graphene-SGX
+
+There are a few built-in examples under LibOS/shim/test/. The "native" folder includes a rich set of C programs and "apps" folder includes a few tested applications, such as GCC, Python, and Apache.
+
+(1) Build and run a Hello World program with Graphene on SGX
+- go to LibOS/shim/test/native, build the enclaves via command:
+    
+      make SGX=1
+  
+  The command will build enclaves for all the programs in the folder
+- Generate the token from aesmd service, via command:
+
+      make SGX_RUN=1
 
 
+- Run Hello World program with Graphene on SGX:
+  
+      SGX=1 ./pal_loader helloworld   or  ./pal_loader SGX helloworld
+  
+(2) Build and run python helloworld script in Graphene on SGX
+- go to LibOS/shim/test/apps/python, build the enclave:
+  
+      make SGX=1
+      
+- Generate token:
 
 
+      make SGX_RUN=1
+      
+- Run python helloworld with Graphene-SGX via:
 
 
+      SGX=1 ./python.manifest.sgx scripts/helloworld.py
+       
 
 
 ## 3. HOW TO RUN AN APPLICATION IN GRAPHENE?
 ## 3. HOW TO RUN AN APPLICATION IN GRAPHENE?