Paper 2011/675

Basing Obfuscation on Simple Tamper-Proof Hardware Assumptions

Nico Döttling, Thilo Mie, Jörn Müller-Quade, and Tobias Nilges

Abstract

Code obfuscation is one of the most powerful concepts in cryptography. It could yield functional encryption, digital rights management, and maybe even secure cloud computing. However, general code obfuscation has been proven impossible and the research then focused on obfuscating very specific functions, studying weaker security definitions for obfuscation, and using tamper-proof hardware tokens to achieve general code obfuscation. Following this last line this work presents the first scheme which bases general code obfuscation of multiple programs on one single stateless hardware token. Our construction is proven secure in the UC-framework and proceeds in three steps: 1. We construct an obfuscation scheme based on fully homomorphic encryption (FHE) and a hybrid functionality conditional decrypt, which decrypts the result of a homomorphic computation given a proof that the computation was performed as intended. One difficulty of the first step are possible decryptions errors in the FHE. These decryption errors can occur whenever the randomness for the encryption is chosen maliciously by the receiver of the obfuscated code. Such decryption errors then could make a real obfuscated computation distinguishable from a black box use of the non-obfuscated program. 2. Given two common reference strings (CRS) we construct a UC-protocol realizing the functionality conditional decrypt with a stateless hardware token. As the token is stateless it is resettable by a dishonest receiver and the proofs given to the token must be resettably sound. One additional difficulty occurs when the issuer of the token can be corrupted. A malicious token can be stateful and it cannot be prevented that it aborts after a hardwired number of invocations. To prevent adaptive behavior of a malicious token the data of the receiver has to be hidden from the token and the proofs given to the token must even hide the size of the program and the length of the computation. 3. Last we construct a protocol constructing a CRS with a stateless hardware token. Care has to be taken here to not let the token learn anything about the resulting CRS which could not be simulated, because the very same token will later be used in a protocol based on the security of this CRS.

Metadata
Available format(s)
PDF
Publication info
Published elsewhere. Unknown where it was published
Keywords
ObfuscationStateless Tamper-Proof hardwareUniversal ComposabilityUniversal ArgumentsFully-Homomorphic-Encryption
Contact author(s)
nico doettling @ kit edu
History
2012-01-16: last of 4 revisions
2011-12-16: received
See all versions
Short URL
https://ia.cr/2011/675
License
Creative Commons Attribution
CC BY

BibTeX

@misc{cryptoeprint:2011/675,
      author = {Nico Döttling and Thilo Mie and Jörn Müller-Quade and Tobias Nilges},
      title = {Basing Obfuscation on Simple Tamper-Proof Hardware Assumptions},
      howpublished = {Cryptology {ePrint} Archive, Paper 2011/675},
      year = {2011},
      url = {https://eprint.iacr.org/2011/675}
}
Note: In order to protect the privacy of readers, eprint.iacr.org does not use cookies or embedded third party content.