Piracy prevention using unique module translation

Information

  • Patent Grant
  • 7603552
  • Patent Number
    7,603,552
  • Date Filed
    Wednesday, May 4, 2005
    20 years ago
  • Date Issued
    Tuesday, October 13, 2009
    16 years ago
Abstract
A method for providing solidified software in a computing environment includes creating a new reference for a function in a function table; copying an address of the function and associating the address with the new reference; replacing the address associated with an old reference of the function with a dummy address; and substituting each old reference in normal code with the new reference, where injected code is not able to execute in the computing environment. The function table entries can be further randomized by reordering the entries, introducing intermediate mappings, or providing non-operative entries. Alternatively, all or part of the code of the function can be copied and moved to a different storage location and associated with the new reference. The copied code can be further randomized by the insertion of dummy code, utilizing reverse peephole techniques, varying the size of the copied portion, or interleaving non-operative code.
Description
BACKGROUND

1. Field


The present invention relates to computer systems, and more particularly to the solidification of software to maintain the integrity of software and computer systems using unique module translation.


2. Related Art


The set of software available for execution on a computer is generally dynamic and modifiable, even when such modification is not desirable. Restricting the ability of users or administrators of a computer to install and remove software or to modify configuration of the existing software is enforced with passwords or verbal and written policies and guidelines. However, when passwords are used, possessors of administrative passwords generally have access beyond their immediate responsibilities.


Accordingly, there is a need for a technique for providing solidified (or “frozen”) software for maintaining the integrity of software and computer systems. The present invention addresses such a need.


SUMMARY

A method for providing solidified software in a computing environment includes creating a new reference for at least one function in a function table; copying an address of the at least one function and associating the address with the new reference; replacing the address associated with an old reference of the at least one function with a dummy address; and substituting each old reference in normal code with the new reference, where injected code is not able to execute in the computing environment. The function table entries can be further randomized. The randomization can include reordering the entries, introducing intermediate mappings, or providing non-operative entries with the operative entries. Alternatively, all or part of the code of the function can be copied and moved to a different storage location and associated with the new reference. To save storage space, a portion of the code can be copied and moved, with the copied portion referencing the remaining portion of the code at its original location. The copied code can be further randomized. The randomization can include the insertion of dummy code, utilizing reverse peephole techniques, varying the size of the copied portion, or interleaving non-operative code with the copied code. In the above manner, the code for the function is solidified.





BRIEF DESCRIPTION OF DRAWINGS


FIGS. 1A-1B illustrate a first embodiment of a method for providing solidified software for maintaining the integrity of software and computer systems.



FIGS. 2A-2C illustrate a second embodiment of a method for providing solidified software for maintaining the integrity of software and computer systems.



FIG. 3 illustrates a third embodiment of a method for providing solidified software for maintaining the integrity of software and computer systems.



FIGS. 4A-4B illustrate a fourth embodiment a method for providing solidified software for maintaining the integrity of software and computer systems.



FIG. 5 illustrates a fourth embodiment a method for providing solidified software for maintaining the integrity of software and computer systems.





DETAILED DESCRIPTION

The following serves as a glossary of terms as used herein:


Computer: Any computing system comprising an operating system providing a set of resources for use by one or more pieces of software for execution on the computing system.


Injected Code. A set of instructions attempting to access a computing environment that has not been determined to have authorization to be installed or be executed in the computing environment.


Interface: A language, protocol or other boundary for providing a service or making available a resource to a piece of software on a computer. An interface comprises a name space, knowledge of which is needed for successful usage of the interface. For a given interface to a service or resource, an implementation of the service or resource fulfills requests made through the interface. One example of an interface comprises an Application Programming Interface (API) such as a system call interface of an operating system, wherein the name space comprises system call names or system call addresses, and the implementation comprises the portion of the operating system implementing the actual system calls. Another example of an interface comprises a set of function calls to a library, wherein the name space comprises function names or function addresses, and the implementation comprises the actual library code implementing the functions. Other interface examples include language APIs (such as a PERL API, Java API, PHP API, shell script APIs, etc.), database APIs, an interface to a file system of a computer (wherein the name space comprises a set of file names), and any interface to a container of data.


Normal Code: A set of instructions for execution on a computer that has been determined to have authorization to install and execute in a computing environment.


Reference: A thing that relates to an instruction for execution on a computer. The thing can be any mechanism, such as a name, a direct or indirect address for the location of the instruction, a number, a place in a data structure, an index in a list, an entry in a table, or an object in a data structure of any kind.


Software: Any set of instructions for execution on a computer. A piece of software may use one or more services or resources as provided by the computer through one or more interfaces.


Solidification: Creation of a unique computing system by converting uniform systems into functionally equivalent but logically unique systems, generally by breaking assumptions about a computer that software programs normally make in order to execute on that computer.



FIGS. 1A-1B illustrate a first embodiment of a method for providing solidified software for maintaining the integrity of software and computer systems. Referring to FIG. 1A, a new reference for at least one function in a function table is created, via step 101. Next, the address of the function is copied and associated with the new reference, via step 102. The address of the function is then replaced with a dummy address, via step 103. Next, the name of the function in the normal code is substituted with the new reference, via step 104.


For example, referring to FIG. 1B, assume that the references are names for three functions {N1, N2, N3} at addresses {A1, A2, A3}, respectively, stored in the function table. New names {N1′, N2′, N3′} are created for each function, via step 101. The addresses of each function {A1, A2, A3} are copied and associated with the new names {N1′, N2′, N3′}, via step 102. The addresses of the functions associated with the old names {N1, N2, N3} are replaced with dummy addresses, {Ax, Ax, Ax}, via step 103. Then, the names of the functions {N1, N2, N3} in the normal code are substituted with the new names {N1′, N2′, N3′}, via step 104. In this manner, if an injected code attempts to access function N1, it is directed to the dummy address Ax and thus does not call the actual function. The code for the function is thus solidified. Although in the example, the reference is a name, the reference can be a number instead.


The dummy address, Ax, can initiate any number of operations. The dummy address can point to an invalid address, a function that performs nothing, a function that performs an alternative function (execution exception, logging, etc.), or any other possible operation.



FIGS. 2A-2C illustrate a second embodiment of a method for providing solidified software for maintaining the integrity of software and computer systems. Referring to FIG. 2A, first, new references for a plurality of functions in a function table are created, via step 201. Next, the addresses of the functions are copied and associated with the new references, via step 202. The addresses of the functions are replaced with dummy addresses, via step 203. Then, the plurality of functions with the new references in the function table is further randomized, via step 204. The references of these functions in the normal code are substituted with the new references, via step 205.


The randomization can be one of any number of techniques. One randomization technique is the reordering of the new function entries. For example, referring to FIG. 2B, new names {N1′, N2′, N3′} are created for the functions with old names {N1, N2, N3}, via step 201, the addresses {A1, A2, A3} are copied and associating with the new names {N1′, N2′, N3′}, via step 202, along with each of their ordinal numbers {1, 2, 3}. The addresses {A1, A2, A3} for the functions with the old names {N1, N2, N3} are replaced with dummy addresses {Ax, Ax, Ax}, via step 203. Then, the new names {N1′, N2′, N3′} are further randomized by recording them {2, 1, 3}, via step 204. In this manner, injected code cannot locate the actual function addresses by identifying the order patterns.


Another randomization technique is to introduce an intermediate mapping for the ordinal numbers. For example, referring to FIG. 2C, after performing the creating, copying, and replacing steps 201-203, an intermediate mapping is introduced for the ordinal numbers {f(1), f(2), f(3)}. The pattern of the ordinal numbers {1, 2, 3} is thus changed, such that injected code cannot identify the pattern as that belonging to ordinal numbers. Other randomization techniques are also possible, such as introducing dead space between the table entries. In each of the randomization techniques, the pattern of the entries is randomized so that it is not recognizable by injected code.


Thus, in both randomization techniques, the place in a data structure cannot be used as a reference.



FIG. 3 illustrates a third embodiment of a method for providing solidified software for maintaining the integrity of software and computer systems. First, a new reference for at least one function in the function table is created, via step 301, where the code for the function is at a first storage location. The storage location can be on any storage medium, such as memory or a disk. Next, the code for the function is copied and placed in a second storage location, and the addresses of the copied code is associated with the new reference, via step 302, by making the corresponding changes in the function table. The code at the first storage location is replaced with dummy code, via step 303. The normal code is scanned, and each reference to the reference of the function in the normal code is then substituted with the new reference, via step 304. The dummy code can perform the same types of operations as the dummy functions. In this manner, the address of the code for the function cannot be used as a reference. When injected code attempts to access the code at the first storage location, it does not actually call the function.



FIGS. 4A-4B illustrate a fourth embodiment a method for providing solidified software for maintaining the integrity of software and computer systems. Referring to FIG. 4A, a new reference for at least one function in the function table is created, via step 401, where the code for the function is at a first storage location. Then, a portion of the code for the function is copied and placed at a second storage location, via step 402. The addresses of the copied code is associated with the new reference, where the end of the copied portion references the address of a second portion of the code for the function at the first storage location. The portion of the code at the first storage location is then replaced with dummy code, via step 403. The normal code is scanned, and each reference to the function in the normal code is then substituted with the new reference, via step 404.


For example, referring to FIG. 4B, assume that the code for functions with names {N1, N2, N3} in the function table are located at the addresses {A1, A2, A3}. New names {N1′, N2′, N3′ } for the functions are created, via step 401. A first portion (shaded) of the code for each function are then copied and placed at the addresses {A1′, A2′, A3′}, via step 402, and associated with the new names {N1′, N2′, N3′} by making corresponding changes in the function table. The end of the copied portions references the addresses of the second portions of the code {A1°, A2°, A3°} for the functions at the first locations {A1, A2, A3}. Thus, once the code at the addresses {A1′, A2′, A3′} are executed, the execution of the function continues with the code at the referenced addresses {A1°, A2°, A3°}. In this manner, the amount of copied code is less than the entire code for a function, saving storage space, while also preventing injected code from calling the actual functions by accessing the original addresses for the functions.


Although the example of FIG. 4B illustrates names as references, one or ordinary skill in the art will understand that the same technique of copying and moving a portion of the code is also applicable when the addresses {A1, A2, A3} themselves are the references, without the use of names for the functions, without departing from the spirit and scope of the present invention.



FIG. 5 illustrates a fourth embodiment a method for providing solidified software for maintaining the integrity of software and computer systems. First, a new reference for at least one function in the function table is created, via step 501, where the code for the function is at a first storage location. The code for the function is then copied and placed in a second storage location, and the address of the copied code is associated with the new reference, via step 502. Alternatively, a portion of the code for the function can be copied, as described above with FIG. 4A. The code at the first storage location is replaced with dummy code, via step 503. The normal code is then scanned, and each reference to the function in the normal code is substituted with the new reference, via step 504. Then, the copied code is randomized, via step 505, such that the pattern of the randomized code does not match the pattern of the copied code, where the randomized code is semantically invariant from the copied code.


The randomization can be any number of techniques, such as the insertion of dummy code, a reverse peephole technique, varying the size of the portion of code copied, and interleaving dead space into the copied code. Other randomization techniques can be used. By randomizing normal code in this manner, the normal code is able to continue executing in the computing environment while injected code that is not authorized to be installed or executed in the computing environment is not.


The various randomizations of the entries in the function table or of the function code described above can be used in any combination without departing from the spirit and scope of the present invention.


Foregoing described embodiments of the invention are provided as illustrations and descriptions. They are not intended to limit the invention to precise form described. In particular, it is contemplated that functional implementation of invention described herein may be implemented equivalently in hardware, software, firmware, and/or other available functional components or building blocks, and that networks may be wired, wireless, or a combination of wired and wireless. Other variations and embodiments are possible in light of above teachings, and it is thus intended that the scope of invention not be limited by this Detailed Description, but rather by Claims following.

Claims
  • 1. A method for providing solidified software in a computing environment, comprising: (a) creating a new reference for at least one function in a function table;(b) copying an address of the at least one function and associating the address with the new reference;(c) replacing the address associated with an old reference of the at least one function with a dummy address; and(d) substituting each old reference in normal code with the new reference, wherein injected code is not able to execute in the computing environment.
  • 2. The method of claim 1, wherein the normal code comprises a set of instructions for execution on a computer that has been determined to have authorization to be install and execute in the computing environment.
  • 3. The method of claim 1, wherein the injected code comprises a set of instructions attempting to access the computing environment that has not been determined to have authorization to be installed or be executed in the computing environment.
  • 4. The method of claim 1, further comprising: (e) randomizing entries for a plurality of functions with new references in the function table.
  • 5. The method of claim 4, wherein the randomizing (e) comprises: (e1) reordering the entries.
  • 6. The method of claim 4, wherein the randomizing (e) comprises: (e1) providing an intermediate mapping for the entries.
  • 7. The method of claim 4, wherein the randomizing (e) comprises: (e1) providing non-operating entries into the function table.
  • 8. The method of claim 1, wherein the reference comprises one or more of the group consisting of: a name;a number;an address; anda place in a data structure.
  • 9. A method for providing solidified software in a computing environment, comprising: (a) creating a new reference for at least one function in a function table, wherein code for the at least one function is at a first storage location;(b) copying the code and placing the code in a second storage location and associating an address of the copied code with the new reference;(c) replacing the code at the first storage location with dummy code; and(d) substituting each reference of the at least one function in normal code with the new reference, wherein injected code is not able to execute in the computing environment.
  • 10. The method of claim 9, wherein the normal code comprises a set of instructions for execution on a computer that has been determined to have authorization to be install and execute in the computing environment.
  • 11. The method of claim 9, wherein the injected code comprises a set of instructions attempting to access the computing environment that has not been determined to have authorization to be installed or be executed in the computing environment.
  • 12. The method of claim 9, further comprising: (e) randomizing the copied code, such that a pattern of the randomized code does not match a pattern of the copied code, wherein the randomized code is semantically invariant from the copied code.
  • 13. The method of claim 12, wherein the randomizing (e) comprises: (e1) inserting dummy code.
  • 14. The method of claim 12, wherein the randomizing (e) comprises: (e1) utilizing a reverse peephole technique.
  • 15. The method of claim 12, wherein the randomizing (e) comprises: (e1) interleaving non-operative instructions into the copied code.
  • 16. The method of claim 12, wherein the randomizing (e) comprises: (e1) varying a size of the copied code.
  • 17. The method of claim 9, wherein the reference comprises one or more of the group consisting of: a name;a number;an address; anda place in a data structure.
  • 18. A method for providing solidified software in a computing environment, comprising: (a) creating a new reference for at least one function in a function table, wherein code for the at least one function is at a first storage location;(b) copying a first portion of the code for the at least one function and placing the copied code at a second storage location;(c) associating an address of the copied code with the new reference, wherein an end of the copied code references an address of a second portion of the code for the at least one function at the first storage location;(d) replacing the first portion of the code at the first storage location with dummy code; and(e) substituting each reference of the function in normal code with the new reference, wherein injected code is not able to execute in the computing environment.
  • 19. The method of claim 18, wherein the normal code comprises a set of instructions for execution on a computer that has been determined to have authorization to be install and execute in the computing environment.
  • 20. The method of claim 18, wherein the injected code comprises a set of instructions attempting to access the computing environment that has not been determined to have authorization to be installed or be executed in the computing environment.
  • 21. The method of claim 18, further comprising: (e) randomizing the copied code, such that a pattern of the randomized code does not match a pattern of the copied code, wherein the randomized code is semantically invariant from the copied code.
  • 22. The method of claim 21, wherein the randomizing (e) comprises: (e1) inserting dummy code.
  • 23. The method of claim 21, wherein the randomizing (e) comprises: (e1) utilizing a reverse peephole technique.
  • 24. The method of claim 21, wherein the randomizing (e) comprises: (e1) interleaving non-operative instructions into the copied code.
  • 25. The method of claim 21, wherein the randomizing (e) comprises: (e1) varying a size of the copied code.
  • 26. The method of claim 18, wherein the reference comprises one or more of the group consisting of: a name;a number;an address; anda place in a data structure.
US Referenced Citations (49)
Number Name Date Kind
4688169 Joshi Aug 1987 A
4982430 Frezza et al. Jan 1991 A
5222134 Waite et al. Jun 1993 A
5390314 Swanson Feb 1995 A
5521849 Adelson et al. May 1996 A
5560008 Johnson et al. Sep 1996 A
5699513 Feigen et al. Dec 1997 A
5778349 Okonogi Jul 1998 A
5787427 Benantar et al. Jul 1998 A
5842017 Hookway et al. Nov 1998 A
5907709 Cantey et al. May 1999 A
6141698 Krishnan et al. Oct 2000 A
6275938 Bond et al. Aug 2001 B1
6338149 Ciccone, Jr. et al. Jan 2002 B1
6356957 Sanchez, II et al. Mar 2002 B2
6393465 Leeds May 2002 B2
6442686 McArdle et al. Aug 2002 B1
6587877 Douglis et al. Jul 2003 B1
6769115 Oldman Jul 2004 B1
6832227 Seki et al. Dec 2004 B2
6834301 Hanchett Dec 2004 B1
6918110 Hundt et al. Jul 2005 B2
6930985 Rathi et al. Aug 2005 B1
6988101 Ham et al. Jan 2006 B2
7065767 Kambhammettu et al. Jun 2006 B2
7082456 Mani-Meitav et al. Jul 2006 B2
7139916 Billingsley et al. Nov 2006 B2
7177267 Oliver et al. Feb 2007 B2
7251655 Kaler et al. Jul 2007 B2
7290266 Gladstone et al. Oct 2007 B2
7302558 Campbell et al. Nov 2007 B2
7353501 Tang et al. Apr 2008 B2
7363022 Whelan et al. Apr 2008 B2
7441265 Staamann et al. Oct 2008 B2
20020099671 Mastin Crosbie et al. Jul 2002 A1
20030073894 Chiang et al. Apr 2003 A1
20030074552 Olkin et al. Apr 2003 A1
20030120811 Hanson et al. Jun 2003 A1
20030120935 Teal et al. Jun 2003 A1
20040015554 Wilson Jan 2004 A1
20040051736 Daniell Mar 2004 A1
20040143749 Tajalli et al. Jul 2004 A1
20040230963 Rothman et al. Nov 2004 A1
20040255161 Cavanaugh Dec 2004 A1
20050018651 Yan et al. Jan 2005 A1
20050228990 Kato et al. Oct 2005 A1
20050262558 Usov Nov 2005 A1
20070039049 Kupferman et al. Feb 2007 A1
20070101435 Konanka et al. May 2007 A1