Sok: General Purpose Compilers for Secure Multi-Party Computation
Total Page:16
File Type:pdf, Size:1020Kb
SoK: General Purpose Compilers for Secure Multi-Party Computation Marcella Hastings, Brett Hemenway, Daniel Noble, and Steve Zdancewic University of Pennsylvania f mhast, fbrett, dgnoble, stevez g @cis.upenn.edu Abstract—Secure multi-party computation (MPC) allows [89], [136] and satellite collision detection [78], [79], a group of mutually distrustful parties to compute a joint [90]. function on their inputs without revealing any informa- Despite the demand for MPC technology, practical tion beyond the result of the computation. This type of computation is extremely powerful and has wide-ranging adoption has been limited, partly due to the efficiency applications in academia, industry, and government. Pro- of the underlying protocols. General-purpose MPC pro- tocols for secure computation have existed for decades, but tocols, capable of securely computing any function, have only recently have general-purpose compilers for executing been known to the cryptographic community for 30 years MPC on arbitrary functions been developed. These projects [33], [73], [131], [132]. Until recently such protocols rapidly improved the state of the art, and began to make MPC accessible to non-expert users. However, the field is were mainly of theoretical interest, and were considered changing so rapidly that it is difficult even for experts to too inefficient (from the standpoint of computation and keep track of the varied capabilities of modern frameworks. communication complexity) to be useful in practice. In this work, we survey general-purpose compilers To address efficiency concerns, cryptographers have for secure multi-party computation. These tools provide developed highly-optimized, special-purpose MPC pro- high-level abstractions to describe arbitrary functions and execute secure computation protocols. We consider tocols for a variety of use-cases. Unfortunately, this eleven systems: EMP-toolkit, Obliv-C, ObliVM, TinyGar- mode of operation does not foster widespread deploy- ble, SCALE-MAMBA (formerly SPDZ), Wysteria, Share- ment or adoption of MPC in the real world. Even if mind, PICCO, ABY, Frigate and CBMC-GC. We evaluate these custom-tailored MPC protocols are theoretically these systems on a range of criteria, including language ex- efficient enough for practical use, designing, analyzing pressibility, capabilities of the cryptographic back-end, and accessibility to developers. We advocate for improved doc- and implementing a custom-tailored protocol from the umentation of MPC frameworks, standardization within ground up for each application is not a scalable solution. the community, and make recommendations for future General-purpose MPC compilers, could drastically directions in compiler development. Installing and running reduce the burden of designing multiple custom proto- these systems can be challenging, and for each system, we also provide a complete virtual environment (Docker cols and could allow non-experts to quickly prototype container) with all the necessary dependencies to run the and deploy secure computations. Using compilers, the compiler and our example programs. engineering effort devoted to making general-purpose MPC protocols practical and secure can be amortized I. INTRODUCTION across all of the uses of such a system. Secure multi-party computation (MPC) provides a Many significant challenges arise when designing and mechanism by which a group of data-owners can com- building an MPC compiler. In general, implementing pute joint functions of their private data, where the any type of multi-round, distributed protocol robustly execution of the protocol reveals nothing more about and efficiently is a major engineering challenge, but the underlying data than what is revealed by the output the MPC compilers have additional requirements that alone. MPC can be viewed as a cryptographic method make them especially challenging to build correctly. for providing the functionality of a trusted party—who For efficiency, both the compiler and the cryptographic would accept private inputs, compute a function and back-end need to be highly optimized. For usability, the return the result to the stakeholders—without the need front-end compiler needs to be expressive, flexible, and for mutual trust. intuitive for non-experts, and should abstract away many Thanks to these strong security guarantees, MPC has of the complexities of the underlying MPC protocol, broad potential for practical applications, ranging from including circuit-level optimizations (e.g. implementing general computations of secure statistical analysis [23], floating-point operations as a Boolean circuit) and back- [24], [26], [57], [58], [59], [60], [100], to more domain- end protocol choice (e.g. selecting an optimal protocol specific uses like financial oversight [2], [22], [27], [63], for a particular computation). With today’s compilers, biomedical computations [38], [34], [80], [88], [86], optimizing performance often still requires a fair degree of knowledge and effort on the part of the user. Casual readers may wish to skim Section VI, which Fairplay [103] was the first publicly available MPC discusses each framework in greater depth, and focus on compiler. It translated code written in a high-level Secure the final discussion section, where we advocate for im- Function Definition Language (SFDL) into a garbled proved documentation and standardization and suggest circuit representation, which could then be (securely) future directions in compiler research. evaluated by two parties. Fairplay was subsequently Many of these frameworks are themselves research extended to allow for true multi-party computation in projects or works-in-progress: they have non-trivial build FairplayMP [15], using a modified version of the BMR dependencies and complicated work flows. Indeed, im- protocol [10]. It was followed shortly by VIFF [68], plementing our simple example programs in each sys- [50] and SEPIA [29], which used the same basic ar- tem required significant engineering effort: we estimate chitecture: they took programs written in fairly high- over 750 person-hours. To allow others to experiment level languages, converted them to a circuit format, and more easily with these systems, we have created an executed the circuit using a secure computation protocol. on-line Github repository1 with two artifacts: (1) a These early compilers showed that general-purpose set of Docker containers, each of which provides a MPC was achievable, and, although their performance development environment configured with the required rendered them unsuitable for most real-world applica- software infrastructure for each MPC framework, along tions, they launched what is now a very active field of with executable examples of our test cases, and (2) a wiki research in MPC compiler design and implementation. page that collects much of the evaluation presented here Thanks to these efforts, dramatic improvements in with additional documentation about each framework. secure computation algorithms coupled with a steady a) Related Work: Archer et al.’s survey [6] of se- increase in hardware performance have made MPC a cure computation tools across several paradigms, includ- viable solution to a large class of real-world problems. ing garbled circuit schemes, defines a maturity taxonomy Modern MPC protocol implementations are fast enough that aims to describe the practical readiness of several to securely evaluate complex functions on moderately- schemes. Shan et al.’s survey [121] outlines different large data sets, such as the numerous implementations threat models and computation techniques for securely of secure regression analyses with tens to hundreds outsourcing many specific types of computation. The of thousands of observations, and tens to hundreds of authors of Frigate [105] include a short survey of existing variables [24], [41], [67], [91], [108]. MPC frameworks, which focuses on correctness and The rush of activity in this field can be difficult covers a slightly older body of work. The SSC protocol to navigate: dozens of new compilers and supporting comparison tool [109], [110], [111] allows users to find frameworks encompass a wide variety of architectures published protocols matching certain security or pri- and features which influence their efficiency, usability vacy criteria, but this tool classifies theoretical protocols and suitability for different tasks. The goal of this rather than implementations and does not include proto- Systematization of Knowledge paper is to provide a cols developed in the past few years. The awesome-mpc guide to the powerful new breed of MPC compilers, and repository [119] provides an up-to-date list of compilers, is primarily aimed at four distinct types of readers. back-ends and special-purpose protocols, with a short 1) Developers looking to choose a compiler with description of each. To the best of our knowledge, these which to implement a specific secure computation previous works did not actually install and experiment 2) Theoretical cryptographers looking to understand with each of the systems they surveyed, but drew their state-of-the-art in practical, secure computation conclusions based on the descriptions of the systems 3) Compiler designers looking to understand the lim- in their published papers and documentation. Unfortu- itations of existing technology and identify new nately, we have found that the features, functionality research directions and syntax of the actual implementations do not always 4) Managers and policy-makers looking to under- match those