The implementation of TEEMS, a Trusted Execution Environment based Metadata-protected Messaging System

Sajin 722ec34003 Manifest generation for experiment mode in run_experiments il y a 1 an
App 2c0a7349f3 Minor fix il y a 1 an
Client 409b6ceeb6 Minor tweak to close off clients silently il y a 1 an
Enclave 37b1a89d94 Handling the single server case in public routing protocol il y a 1 an
Untrusted a31e54d049 Resolving conflicts in merging aaron/public-channel il y a 1 an
Makefile 76de7e1ba6 Merging main il y a 1 an
README 5c44ca5fcd First cut at README il y a 1 an
gen_enclave_config.py 915c2eb04d Resolve merge conflict gen_enclave_config il y a 1 an
gen_manifest.py 9d3ee2a3ee Run_experiments does a diagnostic run, then sets the parameters (epoch_duration, num_WN_to_precompute, enclave memory) for the actual experiment based on these parameters il y a 1 an
logs_to_csv.py 9d3ee2a3ee Run_experiments does a diagnostic run, then sets the parameters (epoch_duration, num_WN_to_precompute, enclave memory) for the actual experiment based on these parameters il y a 1 an
mkzip 7f2dcab64b mkzip script to create the artifact zip file il y a 1 an
run_experiments.py 722ec34003 Manifest generation for experiment mode in run_experiments il y a 1 an

README

Source code for "TEEMS: Trusted Execution Environment based
Metadata-protected Messaging System"

This code produced the data reported in Section 6 of our paper.

You will need:

- A machine with one or more SGX2-enabled processors
- The SGX SDK (https://github.com/intel/linux-sgx) installed (we used
version 2.22)
- The "numactl" program installed (even if you don't have a NUMA
machine)

The code is designed to run on a single machine with two 40-core
processors (Intel 8380). We allocate 36 cores on each processor for the
servers, and the last 4 cores on each processor for the clients.

If you have a different configuration, change the cores assigned to
clients by setting "prefix" in Client/clientlaunch and the -t option to
clientlaunch in run_experiments.py. Change the cores assigned to
servers in the gen_manifest.py program. Change the maximum number of
servers for a given number of cores in the M_MAX dictionary in
run_experiments.py.

Decide what experiments you want to run:

- Set the numbers of users (N), the numbers of servers (M), and the
numbers of cores per server (T) in run_experiments.py.
- Set whether you want to test the private or public channel by setting
"private_routing:" in gen_manifest.py to True or False respectively.

Build and run the code, and collect the output:

- make
- ./run_experiments.py
- ./logs_to_csv.py Experiments_test results.csv