Skip to content

Commit

Permalink
compose: deploy aesmd service in SGX HW mode (#90)
Browse files Browse the repository at this point in the history
* compose: deploy aesmd service in SGX HW mode

* compose: move all aesmd initialisation to create command
  • Loading branch information
csegarragonz authored Aug 21, 2024
1 parent a183dae commit ede471a
Showing 1 changed file with 27 additions and 4 deletions.
31 changes: 27 additions & 4 deletions faasmctl/util/compose.py
Original file line number Diff line number Diff line change
Expand Up @@ -113,11 +113,12 @@ def get_compose_env_vars(faasm_checkout, mount_source, ini_file=None):
else:
env["FAASM_WASM_VM"] = wasm_vm

if "FAASM_CLI_IMAGE" in environ and "sgx" not in wasm_vm:
env["FAASM_CLI_IMAGE"] = environ["FAASM_CLI_IMAGE"]
# Work out the CLI image
if "FAASM_CLI_IMAGE" in environ and "sgx" not in wasm_vm:
env["FAASM_CLI_IMAGE"] = environ["FAASM_CLI_IMAGE"]

if "FAASM_SGX_CLI_IMAGE" in environ and "sgx" in wasm_vm:
env["FAASM_CLI_IMAGE"] = environ["FAASM_SGX_CLI_IMAGE"]
if "FAASM_SGX_CLI_IMAGE" in environ and "sgx" in wasm_vm:
env["FAASM_CLI_IMAGE"] = environ["FAASM_SGX_CLI_IMAGE"]

env["FAASM_OVERRIDE_CPU_COUNT"] = DEFAULT_FAASM_OVERRIDE_CPU_COUNT
if "FAASM_OVERRIDE_CPU_COUNT" in environ:
Expand Down Expand Up @@ -151,10 +152,31 @@ def deploy_compose_cluster(faasm_checkout, workers, mount_source, ini_file):
# Generate random compose project name
env["COMPOSE_PROJECT_NAME"] = "faasm-{}".format(generate_gid())

# In a compose cluster with SGX in HW mode, we need to manually set-up
# the AESMD volume and socket for remote attestation (in a k8s deployment
# on AKS, this is done automatically for us)
must_start_sgx_aesmd = env["FAASM_WASM_VM"] == "sgx"

if must_start_sgx_aesmd:
docker_cmd = [
"docker",
"volume create",
"--driver local",
"--opt type=tmpfs",
"--opt device=tmpfs",
"--opt o=rw",
"aesmd-socket",
]
docker_cmd = " ".join(docker_cmd)
run(docker_cmd, shell=True, check=True)

env["SGX_DEVICE_MOUNT_DIR"] = "/dev/sgx"

# Deploy the compose cluster (0 workers <=> cli-only cluster)
cmd = [
"docker compose up -d",
"--scale worker={}".format(workers) if int(workers) > 0 else "",
"aesmd" if must_start_sgx_aesmd else "",
"worker" if int(workers) > 0 else "faasm-cli",
]
cmd = " ".join(cmd)
Expand Down Expand Up @@ -271,6 +293,7 @@ def wait_for_venv(ini_file, cli):
sleep(3)


# TODO: make this method callable for when things go sideways
def populate_host_sysroot(faasm_checkout, clean=False):
"""
Populate the host's sysroot under `./dev/faasm-local` to be shared by
Expand Down

0 comments on commit ede471a

Please sign in to comment.