Design and evaluation of software obfuscations

Show simple item record

dc.contributor.advisor Prof. Clark D. Thomborson en
dc.contributor.advisor Dr. Stephen J. Drape en
dc.contributor.author Majumdar, Anirban en
dc.date.accessioned 2008-10-21T21:23:57Z en
dc.date.available 2008-10-21T21:23:57Z en
dc.date.issued 2008 en
dc.identifier.citation Thesis (PhD--Computer Science)--University of Auckland, 2008. en
dc.identifier.uri http://hdl.handle.net/2292/3107 en
dc.description Whole document restricted, but available by request, use the feedback form to request access. en
dc.description.abstract Software obfuscation is a protection technique for making code unintelligible to automated program comprehension and analysis tools. It works by performing semantic preserving transformations such that the difficulty of automatically extracting the computational logic out of code is increased. Obfuscating transforms in existing literature have been designed with the ambitious goal of being resilient against all possible reverse engineering attacks. Even though some of the constructions are based on intractable computational problems, we do not know, in practice, how to generate hard instances of obfuscated problems such that all forms of program analyses would fail. In this thesis, we address the problem of software protection by developing a weaker notion of obfuscation under which it is not required to guarantee an absolute blackbox security. Using this notion, we develop provably-correct obfuscating transforms using dependencies existing within program structures and indeterminacies in communication characteristics between programs in a distributed computing environment. We show how several well known static analysis tools can be used for reverse engineering obfuscating transforms that derive resilience from computationally hard problems. In particular, we restrict ourselves to one common and potent static analysis tool, the static slicer, and use it as our attack tool. We show the use of derived software engineering metrics to indicate the degree of success or failure of a slicer attack on a piece of obfuscated code. We address the issue of proving correctness of obfuscating transforms by adapting existing proof techniques for functional program refinement and communicating sequential processes. The results of this thesis could be used for future work in two ways: first, future researchers may extend our proposed techniques to design obfuscations using a wider range of dependencies that exist between dynamic program structures. Our restricted attack model using one static analysis tool can also be relaxed and obfuscations capable of withstanding a broader class of static and dynamic analysis attacks could be developed based on the same principles. Secondly, our obfuscatory strength evaluation techniques could guide anti-malware researchers in the development of tools to detect obfuscated strains of polymorphic viruses. en
dc.language.iso en en
dc.publisher ResearchSpace@Auckland en
dc.relation.ispartof PhD Thesis - University of Auckland en
dc.relation.isreferencedby UoA1842652 en
dc.rights Whole document restricted but available by request. Items in ResearchSpace are protected by copyright, with all rights reserved, unless otherwise indicated. en
dc.rights.uri https://researchspace.auckland.ac.nz/docs/uoa-docs/rights.htm en
dc.rights.uri http://creativecommons.org/licenses/by-nc-sa/3.0/nz/ en
dc.subject obfuscation en
dc.subject software security en
dc.subject program transformation en
dc.subject global state monitoring en
dc.subject slicing en
dc.subject distributed computing en
dc.title Design and evaluation of software obfuscations en
dc.type Thesis en
thesis.degree.discipline Computer Science en
thesis.degree.grantor The University of Auckland en
thesis.degree.level Doctoral en
thesis.degree.name PhD en
dc.subject.marsden Fields of Research::280000 Information, Computing and Communication Sciences::280300 Computer Software en
dc.rights.holder Copyright: The author en
pubs.local.anzsrc 08 - Information and Computing Sciences en
pubs.org-id Faculty of Science en
dc.identifier.wikidata Q112877800


Files in this item

Find Full text

This item appears in the following Collection(s)

Show simple item record

Share

Search ResearchSpace


Browse

Statistics