This application claims the benefit of U.S. Provisional Application No. 61/606,236, filed Mar. 2, 2012, which is hereby incorporated by reference.
The present invention relates to computer security and in particular to techniques for preventing the reverse engineering and/or other forms of attack on computer software.
Disassembling and mapping the flow of control between blocks of instructions in a computer program is by far the most common and easiest way for an attacker to reverse engineer and gain an understanding of the inner workings of a computer program. The mapping of the flow of control can produce a static control flow graph. In order to obtain this static control flow graph which shows the mapping of the flow of control between blocks, a disassembler has to perform two fundamental operations: (1) for each byte in the binary code, decide if this byte is part of an instruction or data and (2) map the flow of control between instructions. Techniques which impede or prevent this procedure can be used to prevent the reverse engineering of the software program. U.S. Pat. No. 7,779,270 describes an approach to obfuscate a computer program in a manner which impedes or prevents reverse engineering of the computer program.
The obfuscation of the control flow of computer software can be obtained by using one or more of the embodiments described herein. In one embodiment, a method for obfuscating the control flow includes receiving a first version of software and identifying each branch point in a set of branch points in the first version of software and then replacing, in each branch point in the set, a representation of a target of the branch point with a computed value that depends upon at least one prior computed value in a stream of instructions in the first version of software. The at least one prior computed value can be from a prior branch point in the set of branch points in the stream of instructions. In one embodiment, all of the branch points in a particular set of branch points can modify a variable during the execution of the program in order to create computed values for each branch point such that the computed value for a particular branch point depends upon all of the prior computed values for the prior branch points. By updating the variable throughout the program and by taking into account previous values, it becomes more difficult to reverse engineer the flow of control between blocks. In one embodiment, the first version of software is an intermediate representation of a high level source code description of the software, wherein this first version is generated by a compiler. The target of the branch point in the first version of the software before it is replaced can be specified by one of: (a) a call name; (b) a function name; or (c) a logical address or pointer, etc. In one embodiment, the target can be specified, after the replacing operation, by an entry in a jump table that uses the computed value in a branch point as an index into the jump table. The target, after the replacing, can be stored as a masked target in an entry in the jump table that uses the computed value as an index, and the target is revealed at run time of the software by an unmasking of the masked target.
In one embodiment, a method according to the present invention can also include the addition of non-executed code at the beginning of a target of at least one of the branch points in the set of targets. This non-executed code can be referred to as “fake” code but in fact in one embodiment it can have the same binary opcodes as executed or “real” code. In one embodiment, the non-executed code is selected so that it is statistically matched with or based on the executed code as described herein.
The methods of the present invention can be used to create software according to one or more embodiments described herein. Also, certain embodiments of the present invention also include software programs created by these one or more methods. Such computer software will compute, in one embodiment, at each branch point in the set of branch points, a branch point value that depends upon prior computed branch point values in the obfuscated software program. In one embodiment the software program can also retrieve, using the branch point value a target or masked target from a jump table. Further, the software program can also include “fake” code inserted into the beginning of a target of a branch.
Embodiments of the present invention also include machine readable non-transitory storage media containing executable instructions which when executed cause the data processing system to perform any one of the methods described herein.
Other features of the present invention will be apparent from the accompanying drawings and from the detailed description which follows.
The above summary does not include an exhaustive list of all aspects of the present invention. It is contemplated that the invention includes all systems and methods that can be practiced from all suitable combinations of the various aspects summarized above, and also those disclosed in the Detailed Description below.
The present invention is illustrated by way of example, and not limitation, in the figures of the accompanying drawings in which like references indicate similar elements.
Various embodiments and aspects of the inventions will be described with reference to details discussed below, and the accompanying drawings will illustrate the various embodiments. The following description and drawings are illustrative of the invention and are not to be construed as limiting the invention. Numerous specific details are described to provide a thorough understanding of various embodiments of the present invention. However, in certain instances, well-known or conventional details are not described in order to provide a concise discussion of embodiments of the present invention.
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in conjunction with the embodiment can be included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification do not necessarily all refer to the same embodiment. The processes depicted in the figures that follow are performed by processing logic that comprises hardware (e.g. circuitry, dedicated logic, etc.), software, or a combination of both. Although the processes are described below in terms of some sequential operations, it should be appreciated that some of the operations described may be performed in a different order. Moreover, some operations may be performed in parallel rather than sequentially.
A method for obfuscating a software program is shown in
In another embodiment, an obfuscator can process specified portions of code with a greater level of obfuscation than unspecified portions of code. In one embodiment, levels of obfuscation are implemented by adding or removing a combination of one or more of: amount of fake code, number of branch points, complexity of encode/decode functions, and masked jump tables. In one embodiment, when minimal code size or minimal code complexity is advantageous (e.g., code executed by portable or low processing power devices), the obfuscator can specify sections of code (e.g., code that executes security or data protection related functions) that can receive more layers of obfuscation while reducing layers of obfuscation from other less critical sections of ode. Selecting specific sections of code for obfuscation can provide for a minimal performance impact when implementing code obfuscation while still providing enhanced protection to specific sections of code. In one embodiment, the source code input 701 contains instructions to automatically trigger varying layers or levels of obfuscation for selected sections of code while other sections can have less obfuscation or no obfuscation.
The following pseudo code example shows an embodiment in which an initial program is modified to add computed branch values according to one embodiment of the present invention.
The following is a program that computes the Fibonacci number n:
This algorithm takes 4 parameters:
mask and unmask, two inverse functions such that for any x, unmask(mask(x))==x.
encode and decode, two functions such that:
encode(x,y)==k
decode(k,y)==y
Given the knowledge of x, they are used to conceal a parameter y and pass it as an encoded value k. Let JumpTable be a global array and i and j be indices into this array such that:
JumpTable[i]f(compute) and JumpTable[j]=f(exit)
The example program protected with an embodiment of algorithm described herein would be:
A non-trivial decode function uses a computation based on k, so that tampering with k yields a different result, and the value of k has to be known to discovery. For instance, for decode (x=56, 12) we could use:
y=x−44
or
y=x%22.
Encode may use random inputs, such that two runs of encode(x, y) may return distinct values. The index used to select the address of the next block in the JumpTable can always be updated with the following pattern:
index=decode(index, . . . )
This means to discover the successor(s) of the current block, an attacker needs to know at least one predecessor of the current block. This example does not use the insertion of the garbage data (“fake” code) that looks like code. Fake code, if added in this example would make it unclear exactly where the compute label is and where the exit label is. Unmask and mask work similarly to encode and decode, but do not require prior knowledge of the value to be masked, because the masked value may change when the program is loaded in memory, during relocation. Also, the mask function can be chosen carefully to let the dynamic loader operate on the masked values.
A display controller and display device 909 can provide a visual user interface for the user; this interface may include a graphical user interface which is similar to that shown on a Macintosh computer when running OS X operating system software or iOS software on an iPhone or iPad. The system 900 can include one or more wireless transceivers 903 to communicate with another data processing system. A wireless transceiver may be a WLAN transceiver (e.g. WiFi), an infrared transceiver, a Bluetooth transceiver, and/or a wireless cellular telephony transceiver. It will be appreciated that additional components, not shown, may also be part of the system 900 in certain embodiments, and in certain embodiments fewer components than shown in
The data processing system 900 also can include one or more input devices 913 which are provided to allow a user to provide input to the system. These input devices may be a keypad or a keyboard or a touch panel or a multi-touch panel which is overlaid and integrated with a display device such as display device 909. The data processing system 900 can also include an optional input/output device which may be a connector for a dock. It will be appreciated that one or more buses, not shown, may be used to interconnect the various components as is well known in the art. The data processing system shown in
Data processing system 900 can optionally include one or more hardware devices designed to digitize and store human speech received by the microphone in Audio I/O 905.
At least certain embodiments of the inventions may be part of a digital media player, such as a portable music and/or video media player, which may include a media processing system to present the media, a storage device to store the media and may further include a radio frequency (RF) transceiver (e.g., an RF transceiver for a cellular telephone) coupled with an antenna system and the media processing system. In certain embodiments, media stored on a remote storage device may be transmitted to the media player through the RF transceiver. The media may be, for example, one or more of music or other audio, still pictures, or motion pictures. Moreover, the software which is obfuscated using one or more embodiments described herein can be software that is used to play the music or motion pictures or other content.
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope of the invention as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.
Number | Name | Date | Kind |
---|---|---|---|
7779270 | Horning et al. | Aug 2010 | B2 |
20070234070 | Horning et al. | Oct 2007 | A1 |
20090235089 | Ciet et al. | Sep 2009 | A1 |
20100199354 | Eker et al. | Aug 2010 | A1 |
20100332759 | Vauclair | Dec 2010 | A1 |
20110138351 | Monsifrot et al. | Jun 2011 | A1 |
20110167414 | Lattner et al. | Jul 2011 | A1 |
20110283115 | Junod | Nov 2011 | A1 |
Number | Date | Country |
---|---|---|
10-2010-0113269 | Oct 2010 | KR |
Entry |
---|
Linn et al. Obfuscation of Executable Code to Improve Resistance to Static Disassembly, Oct. 27-31, 2003, Department of Computer Science University of Arizona, pp. 290-299. |
Number | Date | Country | |
---|---|---|---|
20130232323 A1 | Sep 2013 | US |
Number | Date | Country | |
---|---|---|---|
61606236 | Mar 2012 | US |