Skip to content

Fork of the GT/KAIST OpenSGX repository to better match expected real hardware and develop new APIs

Notifications You must be signed in to change notification settings

patrickb314/janusSGX

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

89 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

JanusSGX: A modification of OpenSGX for developing new enclave APIs. Most of the original old OpenSGX runtime, which relies on non-standard hardware behavior, has been stripped away and things are closer to what real hardware will need.

Quickstart Build Instructions

  1. Build qemu:

     (cd qemu; ./configure-arch; make)
    
  2. Build libsgx and mbedtls (currently using stock mbed TLS 1.3.11)

     make -C libsgx
    
  3. Build rest of enclave fake kernel/user runtime/enclave runtime/example enclave and test code:

     make -C user
    
  4. Generate a local key for signing enclaves:

      ./opensgx -k
    
  5. Run a simple enclave test using a fake sigstruct/einittoken that is signs using the user/conf/test.key key and a pre-known launch key:

     cd user
     ../opensgx ./sgx-test ./test/simple-arg.sgx
    
  6. Use this key to sign the sigstruct of the test case above using the GT tools (generates user/test/simple-arg.conf, uses a pre-set launch key for making the einittoken)

     ../opensgx -s test/simple-arg.sgx --key ../sign.key
    
  7. Run using this actual sigstruct and einittokey:

     ../opensgx sgx-test test/simple-arg.sgx test/simple-arg.conf
    
  8. Sign the launch enclave with the "intel" key so it can start up and use egetkey to access the processor launch key:

     ../opensgx -s bootstrap/launch-enclave.sgx -I
    
  9. Run the launch enclave to verify we can generate a proper launch token for a sigstruct using egetkey/etc.

     ../opensgx launch-test bootstrap/launch-enclave.sgx bootstrap/launch-enclave.conf conf/intel.key test/simple-arg.conf
     # Generated einittoken MAC should match what the GT user tools generated with the launch key they'd extracted/generated using by knowing the "hardware fuses".
    

Debugging JanusSGX Programs

To debug enclave code in JanusSGX, you can use the qemu linux-user GDB stub and GDB remote debugging support. In addition to normal remote GDB commands, you will also want to load symbols for the (runtime-loaded) enclave code. Below is a simple example:

  1. Run the test program with remote GDB support in the background:

     ../opensgx -d 1234 sgx-test test/simple-arg.sgx test/simple-arg.conf &
    
  2. Run, attach GDB to the emulator, and set a breakpoint immediately prior to running in the enclave

     gdb sgx-test
     (gdb) target remote localhost:1234
     Remote debugging using localhost:1234
     Reading symbols from /lib64/ld-linux-x86-64.so.2...(no debugging symbols found)...done.
     Loaded symbols for /lib64/ld-linux-x86-64.so.2
     0x0000004000801cf0 in _start () from /lib64/ld-linux-x86-64.so.2
     Missing separate debuginfos, use: debuginfo-install glibc-2.20-8.fc21.x86_64
     (gdb) break sgx-test.c:62
     Breakpoint 1 at 0x401b08: file sgx-test.c, line 62.
     (gdb) c
     Continuing.
    
     Breakpoint 1, main (argc=2, argv=0x4000800028) at sgx-test.c:62
     62	    	enclave1_call(stat.tcs, exception_handler, &a_val);
    
  3. Because the enclave code is loaded separately, you must explicitly tell GDB about symbols in it for it to be able to backtrace and debug enclave code. Note that the sgx-test program is configured to compute and print out the gdb command that you need to run to do this.

     (gdb) add-symbol-file test/simple-arg.sgx 0x4000c10c
     add symbol table from file "test/simple-arg.sgx" at
     	.text_addr = 0x4000c10c
     (y or n) y
     Reading symbols from test/simple-arg.sgx...done.
     (gdb) break enclave_main
     Breakpoint 2 at 0x4000c114: file test/simple-arg.c, line 7.
     (gdb) c
     Continuing.
    
     Breakpoint 2, enclave_main (arg=0x63692c <a_val>) at test/simple-arg.c:7
     7	    *arg += 1;
    
     (gdb)
    

At this point, any errors in the program can be backtraced, enclave state debugged, and breakpoints set in the enclave.

OpenSGX: An open platform for Intel SGX

Contribution Guides

  • coding style
  • make sure all the test/unit cases pass
  • license

Environments & Prerequisites

  • Tested: Ubuntu 14.04-15.04, Arch
  • Requisite:
    • Ubuntu: apt-get build-dep qemu
    • Fedora: yum-builddep qemu
$ cd qemu
$ ./configure-arch
$ make -j $(nproc)

$ cd ..
$ make

Run your first OpenSGX program

  • Take user/demo/hello.c as an example.
#include <sgx-lib.h>

void enclave_main()
{
    char *hello = "hello sgx"\n";
    sgx_puts(hello);
    sgx_exit(NULL);
}
$ ./opensgx -k
generate sign.key
$ ./opensgx -c user/demo/hello.c
generate hello.sgx
$ ./opensgx -s user/demo/hello.sgx --key sign.key
generate hello.conf
$ ./opensgx user/demo/hello.conf
run the program

Testing

$ cd user
$ ./test.sh test/simple
...
$ ./test.sh --help
[usage] ./test.sh [option]... [binary]
-a|--all  : test all cases
-h|--help : print help
-i|--instuct-test : run an instruction test
-ai|--all-instruction-tests  : run all instruction test cases
--perf|--performance-measure : measure SGX emulator performance metrics
[test]
 test/exception-div-zero.c     :  An enclave test case for divide by zero exception.
 test/fault-enclave-access.c   :  An enclave test case for faulty enclave access.
 test/simple-aes.c             :  An enclave test case for simple encryption/decryption using openssl library.
 test/simple-attest.c          :  test network send
 test/simple.c                 :  The simplest enclave enter/exit.
 test/simple-func.c            :  The simplest function call inside the enclave.
 test/simple-getkey.c          :  hello world
 test/simple-global.c          :  The simplest enclave which accesses a global variable
 test/simple-hello.c           :  Hello world enclave program.
 test/simple-network.c         :  test network recv
 test/simple-openssl.c         :  test openssl api
 test/simple-quote.c           :  test network recv
 test/simple-recv.c            :  An enclave test case for sgx_recv.
 test/simple-send.c            :  An enclave test case for sgx_send.
 test/simple-sgxlib.c          :  An enclave test case for sgx library.
 test/simple-stack.c           :  The simplest enclave enter/exit with stack.
 test/stub.c                   :  An enclave test case for stub & trampoline interface.
 test/stub-malloc.c            :  An enclave test case for using heap
 test/stub-realloc.c           :  An enclave test case for sgx_realloc

Pointers

  • QEMU side

    • qemu/target-i386/helper.h : Register sgx helper functions (sgx_encls, sgx_enclu, ...).
    • qemu/target-i386/cpu.h : Add sgx-specific cpu registers (see refs-rev2 5.1.4).
    • qemu/target-i386/translate.c : Emulates enclave mode memory access semantics.
    • qemu/target-i386/sgx.h : Define sgx and related data structures.
    • qemu/target-i386/sgx-dbg.h : Define debugging function.
    • qemu/target-i386/sgx-utils.h : Define utils functions.
    • qemu/target-i386/sgx-perf.h : Perforamce evaluation.
    • qemu/target-i386/sgx_helper.c: Implement sgx instructions.
  • User side

    • user/sgx-kern.c : Emulates kernel-level functions.
    • user/sgx-user.c : Emulates user-level functions.
    • user/sgxLib.c : Implements user-level API.
    • user/sgx-utils.c : Implements utils functions.
    • user/sgx-signature.c : Implements crypto related functions.
    • user/sgx-runtime.c : sgx runtime.
    • user/sgx-test-runtime.c : sgx runtime for test cases.
    • user/include/ : Headers.
    • user/conf/ : Configuration files.
    • user/test/ : Test cases.
    • user/demo/ : Demo case.

Contact

Email: OpenSGX team.

Authors

NOTE. All authors at Gatech and KAIST equally contributed to the project

About

Fork of the GT/KAIST OpenSGX repository to better match expected real hardware and develop new APIs

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published