@inproceedings{7ed8932e9325480bb69285f347ad1efc,
title = "SecV: Secure Code Partitioning via Multi-Language Secure Values",
abstract = "Trusted execution environments like Intel SGX provide enclaves, which offer strong security guarantees for applications. Running entire applications inside enclaves is possible, but this approach leads to a large trusted computing base (TCB). As such, various tools have been developed to partition programs written in languages such as C or Java into trusted and untrusted parts, which are run in and out of enclaves respectively. However, those tools depend on language-specific taint-analysis and partitioning techniques. They cannot be reused for other languages and there is thus a need for tools that transcend this language barrier. We address this challenge by proposing a multi-language technique to specify sensitive code or data, as well as a multi-language tool to analyse and partition the resulting programs for trusted execution environments like Intel SGX. We leverage GraalVM's Truffle framework, which provides a language-agnostic abstract syntax tree (AST) representation for programs, to provide special AST nodes called secure nodes that encapsulate sensitive program information. Secure nodes can easily be embedded into the ASTs of a wide range of languages via Truffle's polyglot API. Our technique includes a multi-language dynamic taint tracking tool to analyse and partition applications based on our generic secure nodes. Our extensive evaluation with micro- and macro-benchmarks shows that we can use our technique for two languages (Javascript and Python), and that partitioned programs can obtain up to 14.5\% performance improvement as compared to unpartitioned versions.",
keywords = "GraalVM, Intel SGX, Java, Managed Execution Environments, Truffle, Trusted Execution Environments",
author = "Peterson Yuhala and Pascal Felber and Hugo Guiroux and Lozi, \{Jean Pierre\} and Alain Tchana and Valerio Schiavoni and Ga{\"e}l Thomas",
note = "Publisher Copyright: {\textcopyright} 2023 ACM.; 24th ACM/IFIP International Middleware Conference, Middleware 2023 ; Conference date: 11-12-2023 Through 15-12-2023",
year = "2023",
month = nov,
day = "27",
doi = "10.1145/3590140.3629116",
language = "English",
series = "Middleware 2023 - Proceedings of the 24th ACM/IFIP International Middleware Conference",
publisher = "Association for Computing Machinery, Inc",
pages = "207--219",
booktitle = "Middleware 2023 - Proceedings of the 24th ACM/IFIP International Middleware Conference",
}