CRPLOct 31, 2013

Thread-Based Obfuscation through Control-Flow Mangling

arXiv:1311.0044v11 citations
Originality Highly original
AI Analysis

This addresses security for programs in cloud environments, offering a new approach to code obfuscation.

The paper tackles the problem of program security in cloud computing by proposing a novel method that automatically partitions serial threads into parallel threads at the basic-block level, significantly complicating reverse engineering by generating m^n different execution combinations.

The increasing use of cloud computing and remote execution have made program security especially important. Code obfuscation has been proposed to make the understanding of programs more complicated to attackers. In this paper, we exploit multi-core processing to substantially increase the complexity of programs, making reverse engineering more complicated. We propose a novel method that automatically partitions any serial thread into an arbitrary number of parallel threads, at the basic-block level. The method generates new control-flow graphs, preserving the blocks' serial successor relations and guaranteeing that one basic-block is active at a time using guards. The method generates m^n different combinations for m threads and n basic-blocks, significantly complicating the execution state. We provide a correctness proof for the algorithm and implement the algorithm in the LLVM compilation framework.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes