Published January 1, 2011 | Version v1
Book chapter Open

Can a Program Reverse-Engineer Itself?

Description

Shape-memory alloys are metal pieces that "remember" their original cold-forged shapes and return to the pre-deformed shape after heating. In this work we construct a software analogous of shape-memory alloys: programs whose code resists obfuscation. We show how to pour arbitrary functions into protective envelops that allow recovering the functions' exact initial code after obfuscation. We explicit the theoretical foundations of our method and provide a concrete implementation in Scheme.

Files

article.pdf

Files (313.8 kB)

Name Size Download all
md5:bed6b11c2377e19e9a783992d0eeec5c
313.8 kB Preview Download