1. Field of the Invention
This invention relates to systems and methods for protecting computers. In particular, this invention relates to systems and methods for protection of computers and other devices from malicious code such as viruses, spyware, undesirable code, or the like.
2. Discussion of the Background
Malicious codes such as viruses, worms, spyware, etc., can cause substantial damage to computers and other devices. Known systems that protect against malicious code are typically based on an analysis of a code before it is accepted by a computer. This analysis is usually based on a comparison of the code in question with a collection of known malicious codes contained in a “library.” If a substantial similarity is found between the code in question and a code in the library, the code is declared malicious or potentially malicious and is not accepted by the protected computer for further processing.
Detection of malicious code, such as a worm or virus, and a determination of the associated potentially devastating effects can be determined using a test chamber, such as that described in U.S. Pat. No. 5,842,002, incorporated herein by reference in its entirety.
A test chamber is a static hardware model of a protected system, such as a computer. Questionable code, such as an incoming e-mail message is placed in such a test chamber where the conditions of the actual protected system are simulated. A malicious code reacting to such simulated conditions would act according to its designed purpose in this environment. Most common types of such action would be destruction of computer files and/or replication and an attempt to spread the replicas to other computers within a given environment, such as over a LAN or via e-mail. Upon detection of such activities within the test chamber, or upon destruction of all or a portion of the test chamber, the code in question can be declared malicious and not forwarded to the protected computer.
In cases where malicious activity is not detected, the code is deemed safe and passed to the protected computer. For example, upon completion of a scan of an e-mail, and no malicious code within the e-mail detected, the e-mail can be forwarded to the protected computer.
Accordingly, legacy computer security measures are reactionary and only provide protection against already identified threats. This leaves an opening for so called “zero day” exploits which have not been identified. Thus, legacy security systems cannot protect effectively against such threats until they have been updated and/or computer systems patched. There is the possibility of identifying a zero day threat through behavioral analysis, but this can only be done after a system is breached and/or infected.
However, the above methods have at least one inherent deficiency based on the fact that, by definition, they can only detect a previously know malicious code. A previously unknown code, or a code not contained in the “library” of codes would be accepted for further processing by the protected system, thereby “infecting” the protected system. Additionally, establishing an optimal level of similarity between the library and potentially malicious codes presents a substantial difficulty since too general of a criteria of similarity can produce a high level of false positive alerts, while a too specific criteria can produce a high level of false negative results.
The static test chamber system allows for the detection of malicious code that can be incorporated into files or applications, such as an e-mail or program, or that may be self-executing. However, many malicious codes are designed to interfere with a specific operating system, a specific application, upon a specific function being performed, or on some other or combination of triggering activities. Thus, in order to have a test chamber that could account for all of the variables, the test chamber would either need to duplicate a large number of combinations of operating systems and applications, or there would need to be a plurality of test chambers duplicating different combinations of operating systems and applications. The situation is further complicated by the fact that many operating systems and applications themselves are represented by a variety of releases, different versions, and updates. All of the above variables make it difficult to effectively create and maintain test chambers that can be readily and economically maintained and upgraded.
A more attractive approach is to concentrate on the results of accepting a code in question. Obviously, testing a questionable code in an actual protected computer is not acceptable. However, generally it is possible to test a questionable code in a sacrificial “buffer” computer, using it as a “test chamber.” Nevertheless, the practicality of this approach is highly questionable for the following reasons. If the “buffer” computer is an actual computer, this would require a user to purchase two computers instead of one, and would eventually double the number of computers required to perform the same tasks. If the “buffer” computer is a “virtual machine,” this would require creating “virtual machines” for every release of every operating system. Furthermore, because malicious codes are often targeting specific applications, with both scenarios, the “buffer” machine has to contain a copy of every application of the actual protected computer. The frequency of new releases of operating systems and software applications by all vendors creates such a large number of variations to be duplicated by the protective system that it makes the approach even less practical.
One exemplary embodiment of the systems and methods of this invention allows for the automatic building and updating of a dynamic decoy machine (DM) based on a protected system. The DM can reside in the protected system, outside and connected to the protected system, as a standalone system, or a combination thereof. As the protected system goes through updates, modifications and additions, the protected system is automatically duplicated in the DM. Therefore the DM's configuration closely parallels that of the protected computer.
The exemplary methods and systems for detecting a malicious code and preventing it from being further processed by a protected computer or other device are based on, for example, the following principals. The inspection of a questionable code is based on what that code could do to a protected machine and/or its software applications and/or hardware rather than of how the questionable code looks. The protection methods and systems automatically create a code inspection system that is an accurate software copy of the protected computer or device, including relevant software applications residing on the protected machine. The code inspection system automatically updates itself, reflecting software application additions and deletions in the protected computer as well as changes in configurations. The code inspection system contains “actuators” which emulate the normal or typical use of the protected machine, i.e., opening and closing of applications, accessing of files, or the like. The code inspection system also contains a “clock accelerator” which is running the code clock to emulate passage of sufficient time on order to trigger time-delayed malicious codes. Additionally, the code inspection system contains sensors detecting negative impact of a questionable code on the protected machine.
In accordance with an exemplary embodiment of this invention, the code inspection system (CIS), comprises two major parts: a code inspection management module and a dynamic decoy machine (DM). The dynamic decoy machine (DM) further comprises two major parts: an actuator module and a sensor module. These various sensor modules can be added to the dynamic decoy machine's configuration during installations and upgrades that occur on the protected machine, or based on some other predetermined configuration.
Inspection of the questionable code by the code inspection system is performed within the dynamic decoy machine. During the inspection of incoming code, if the questionable code contains malicious code with destructive capabilities, the DM can be partially or fully destroyed or damaged, without affecting the protected system.
The actuator module emulates normal use of the protected machine, i.e., it opens and closes applications, accesses files, sends various communications, manipulates user definable parameter values, or the like, as well as “accelerating the clock” of the DM in order to trigger time-triggered malicious codes. Emulation of the normal use of the protected machine can be pre-programmed and/or updated by the MU based on the use of the protected machine.
The sensors module comprises sensors that detect undesirable actions of the questionable code. These undesirable actions can be broadly divided into three categories: command-based, access-based, and unauthorized modification based. Command-based sensors detect the invocation of one or more undesirable commands. Typical examples could be such commands as “delete.” Access-based sensors detect a questionable code's attempt to access undesirable areas of the DM such as an “address book,” registry, or the like. Unauthorized modification based sensors detect violations of the integrity of the files, such as violations of the check-sum or other authentication algorithms.
The exemplary embodiments of this invention can be performed by a computer program, hardware, or a combination thereof which resides within, outside, or a combination of inside and outside of a protected system. The code inspection system detects installations and upgrades to the protected system's operating system, installation and updates of applications, or the like, and upon such installation process, creates a duplicate of the installed software in the dynamic decoy machine. Thus, the dynamic decoy machine can be a virtual, stand alone, or dedicated dynamic decoy machine such that the configuration of the dynamic decoy machine parallels that of one or more protected computers.
The substantial duplication of pertinent aspects of the protected system in the dynamic decoy machine can be performed during changes to the protected machine's operating system, applications, and files, and those changes duplicated in the DM, thus constantly updating the DM. Alternatively, the duplication can be performed at a predetermined time, regularly or irregularly, or it can be time-based or event-based. The code inspection management module can also receive signals from the DM indicating violations detected by the sensors and block passage of the questionable code deemed undesirable to the protected machine. If the code is not declared undesirable, the code inspection management unit can deliver the code to the protected machine for further processing. For example, the systems and methods of this invention can be used in conjunction with U.S. Pat. No. 6,981,146, entitled “Method of Communications and Communication Network Intrusion Protection Methods and Intrusion Attempt Detection System,” incorporated herein by reference its entirety.
Furthermore, and in accordance with a further exemplary embodiment of the systems and methods of this invention, the code inspection system can maintain one or more dynamic decoy machines. In this embodiment, the first dynamic decoy machine can be used as the actual dynamic decoy machine in which potentially malicious code is evaluated, while the second dynamic decoy machine can act as a backup to rebuild one or more of the first dynamic decoy machine or the protected system should recovery be necessary. Likewise, by maintaining a backup of the dynamic decoy machine, the backup dynamic decoy machine can be used in the case of accidental damage to the protected computer's operating systems and/or applications.
The mirroring of the protected system by the code inspection system can be performed during upgrades of an operating system or an application. Alternatively, the mirroring can be performed at a predetermined time, the only drawback being the fact that the code inspection system may not always exactly reflect the protected system. While the code inspection system is substantially identical of that of the protected computer, the code inspection system, for example, may or may not have the same IP address, can have embedded therein sensors and recovery tools should malicious code destroy all or a portion of the software and/or hardware of the code inspection system, or the like.
Aspects of the present invention relate to computer security. In particular, the exemplary embodiments of the systems and methods of this invention relate to creation and updating of a code inspection system (CIS).
Aspects of the present invention also relate to systems and methods that are capable of maintaining a code inspection system as a protected system is modified.
Aspects of the present invention additionally relate to systems and methods of building and updating a code inspection system based on a protected computer.
Aspects of the present also relate to systems and methods that allow for a complete or partial recovery of protected system based on information stored in one or more code inspection systems.
Aspects of the present also relate to systems, methods computer program products for computer protection, including a protected computer having a protected operating system; and a secure operating system having a first virtual copy of at least a portion of the protected operating system and one or more security mechanisms configured to analyze potentially malicious code before the code is used by the protected computer.
Still other aspects, features, and advantages of the present invention are readily apparent from the following detailed description, simply by illustrating a number of exemplary embodiments and implementations, including the best mode contemplated for carrying out the present invention. The present invention also is capable of other and different embodiments, and its several details can be modified in various respects, all without departing from the spirit and scope of the present invention. Accordingly, the drawings and descriptions are to be regarded as illustrative in nature, and not as restrictive.
The embodiments of the present invention are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings, in which like reference numerals refer to similar elements, and in which:
An exemplary embodiment of the systems and methods of this invention allow a code inspection system (CIS) to produce a dynamic decoy machine that closely parallels one or more protected systems. For example, the code inspection system can analyze and monitor one or more protected systems as those protected systems are updated, altered or modified. The CIS, in which potentially malicious code is tested, can also be updated. Thus, the CIS system can accurately reflect the current state of one or more protected systems such that the potentially destructive nature, if any, of suspicious code can be evaluated as if it were in the actual environment of the protected system, without jeopardizing the security of the protected system.
While the exemplary embodiment illustrated in
Furthermore, the links 5 can be a wired or a wireless link or any other known or later developed element(s) that is capable of supplying and communicating electronic data to and from the connect elements. Additionally, the peripherals and input devices 50 can be, for example, a keyboard, a mouse, a speech-two-text converter, a computer monitor, a display, or the like. Furthermore, while the exemplary embodiments are described in relation to the protected system 20 being a computer and associated peripherals and input/output devices 50, it is to be appreciated that a protected system 20 can include a plurality of computer systems, a network, one or more subsets of applications and/or operating systems running on a computer, a LAN, or the like. In general, the code inspection management system can be scaled to any size and an associated code inspection system built.
In particular,
In operation, the code inspection management module 10 determines whether the protected system 20 is a new system. If the protected system 20 is new, the code inspection management module 10 initializes a dynamic decoy machine 40 that will be used to test potentially malicious code. In particular, the code inspection management module 10 monitors the status of the protected system 20 and updates the dynamic decoy machine 40 as the protected system 20 is built, configured, and operating systems and applications installed. Furthermore, along with paralleling the structure of the protected system 20, the code inspection management module 10 can also embed in the code inspection system 40 one or more sensor modules 44 and actuator modules 42 that monitor, detecting, track, and/or disable malicious code. This paralleling can be performed, for example, by copying files from the protected system to the dynamic decoy machine 40, or by a parallel installation process. Thus, upon a potentially malicious code being introduced to the dynamic decoy machine to determine its effects, and the actuator module 42 running the dynamic decoy machine through an exemplary operating scenario, the sensor module 42 can monitor and determine, for example, the operation of the malicious code.
For example, the dynamic decoy machine 40 can act as an intermediary or interface between the protected system and one or more other unprotected systems or devices from which potentially malicious code could originate. Specifically, the code inspection system can be arranged such that the dynamic decoy machine, cooperating with the code inspection management module 10, acts as a screening interface for all or a portion of received code. This interface can be seamless such that other users and systems are unaware that they are only in communication with the protected system via the dynamic decoy machine. As an example, the dynamic decoy machine could maintain the IP address to which all or a portion of the communications destined for the protected system are routed. As an alternative, the code inspection management module 10 and dynamic decoy machine 40 can act as an interface between, for example, the input devices for the protected system, such as the floppy or CDROM drive, and all or a portion of the code destined for the protected system routed through the dynamic decoy machine. Specifically, the code inspection system could be incorporated into, for example, the BIOS or operating system of a computer or a hard drive. Therefore, the code inspection system would have the capability of intercepting all or a portion of the inputs to the protected system.
Alternatively, code inspection management module 10 can be introduced to produce a code inspection system that minors one or more protected systems 20 already in existence. In this example, the code inspection management module 10 analyzes the protected system 20 to determine, for example, the installed operating system, installed applications, installed peripherals and input/output devices, or the like, and creates the dynamic decoy machine 40 based on the protected system 20.
In addition to the operating system and applications installed on the protected system 20 that are duplicated in the dynamic decoy machine 40, the code inspection management module can emulate the one or more peripherals and input devices 50 that are connected to the protected system 20 in a manner known as a “virtual machine.”
In this example, not only is the software replicated in the dynamic decoy machine 40 but also the hardware components. This can be useful, for example, where a potentially malicious code would activate to produce an output on one or more of the peripheral devices. This process can be simplified in a case when the simple fact of questionable code attempting to access an input/output device or a peripheral is deemed undesirable or malicious in itself.
Upon completion of creating the dynamic decoy machine 40, the code inspection system can verify the integrity of the dynamic decoy machine 40. For example, the code inspection management module 10 can run a comparison between the protected system 20 and the dynamic decoy machine 40 to ensure the systems are substantially identical, or will perform substantially identically under a given exposure to potentially malicious code, except, for example, any actuator modules 42 and sensor modules 44 the code inspection management module 10 may have embedded in the dynamic decoy machine 40.
As with a dynamic decoy machine being developed in conjunction with a newly built computer, once the dynamic decoy machine has been aligned with the protected system 20, the code inspection management module 10 monitors the protected system 20 for any updates, installations, or modifications. Upon any one or more of these triggering events, the code inspection management module 10, via link 5, can update the dynamic decoy machine 40 as well as update and/or add to the actuator and sensor modules.
For example, the code inspection management module 10 can act as a mirroring device, wherein the protected system 20 is exactly duplicated in the dynamic decoy machine 40. Alternatively, only portions of the protected system pertinent to the anticipated undesirable effects can be duplicated.
In addition to the dynamic decoy machine 40 being used to test potentially malicious code, as previously discussed, the dynamic decoy machine 40 can be used as a backup system. In particular, if one or more portions of the protected system 20 are damaged, all or a portion of the protected system 20 could be recovered from the dynamic decoy machine 40 since the dynamic decoy machine 40 is a substantial duplicate of the protected system 20. Thus, during a recovery operation, the code inspection management module 10 can remove any sensor modules or actuator modules that were embedded in the dynamic decoy machine during the dynamic decoy machine's creation.
The actuator module 42 acts in cooperation with the code inspection management module 10 place the dynamic decoy machine through various operational sequences in an effort to trigger a piece of malicious code. For example, the operational sequences can be based on a profile of expected actions of the malicious code. Thus, if an e-mail is received, the actuator module 42 could open the e-mail, and the sensor module 44 watch for access to, for example, the address book. Alternatively, if an executable is downloaded from, for example, the internet, the actuator module 42 can execute the program and the sensor module 44 monitor the registry, and any commands, such as the delete command, and, for example, halt execution of the dynamic decoy machine 40 and delete the malicious code. Alternatively, the code inspection system, upon detection of malicious code, can attempt to remove unauthorized portions of, or “disinfect,” the malicious portion of the infected code. In general, the actuator module is capable of automatically simulating operating conditions of the protected system in the dynamic decoy machine.
Furthermore, the actuator module can also be dynamic and monitor the operation of the protected system. Thus, the actuator model is capable of more accurately reflecting the operational sequences of the protected system. For example, the actuator module, in conjunction with a memory device, not shown, can track a predetermined number of operation sequences in the protected machine. These operational sequences, either in whole or part, can then be executed, with or without additional operational sequences, in the dynamic decoy machine.
The sensor module 44 can monitor, for example, changes in file sizes, access attempts to particular portions of the dynamic decoy machine, command line statements, inputs and outputs of the potentially malicious code, or the like. Thus, the sensor module 44 can react to not only how a potentially malicious code looks, but how it acts. For example, the systems and methods of this invention can work in conjunction with traditional test chamber type systems that detect malicious code based on a matching technique. Thresholds can then be set that declare a code malicious based on its activity. For example, it may be desirable to declare all codes malicious that attempt to access the address book of a mail program. Alternatively, if any code attempts to execute a command that code may be declared malicious. In general, the sensor module, or a plurality of sensor modules, can be installed the in the dynamic decoy machine to detect any type of activity, and especially any type of unwanted activity.
In step S140, the dynamic decoy machine is initialized. Control then continues to step S150. In step S150, a determination is made whether new components and/or applications have been installed. If new components and/or applications have been installed, control continues to step S160. Otherwise, control jumps to step S170.
In step S160, the dynamic decoy machine can be updated in real-time, near-real time, or at a predetermined time, and optionally, any sensor and actuator modules added. Control then continues to step S170.
In step S170, the potentially malicious code is introduced to the dynamic decoy machine. Next, in step S180, the actuator module is invoked. Then, in step S190, the sensors are monitored for malicious activity. Control then continues to step S200.
In step S200, a determination is made whether malicious code is detected. If malicious code is detected, control continues to step S210. Otherwise, control jumps to step S260.
In step S210, the operation of the dynamic decoy machine is halted. Next, in step S220, a determination is made whether to delete the malicious code. If the malicious code is to be deleted, control jumps to step S250 where the malicious code is deleted. Otherwise, control continues to step S230.
In step S230, the malicious code is attempted to be cleaned. Control then continues to step S240. In step S240, a determination is made whether the clean was successful. If the clean was successful, control continues to step S260. Otherwise, control continues to step S250 where the malicious code is deleted.
In step S260, the code is passed to the protected computer. Next, in step S270 a determination is made whether to restore all or a portion of the protected system. If a restoration is desired, control continues to step S280 where all or a portion of the protected system is restored. Control continues to step S290 where the control sequence ends.
In addition, incoming data files and/or code 92 can be stored in a so called “sandbox” environment 90 (e.g., a confined environment) and which resides outside of the virtualized OS 82, and wherein an end user 100 can access such data files and/or code 92, but wherein exploits that have not been dealt with cannot do harm to the virtualized OS 82. Advantageously, known threats can be identified and dealt with, for example, by the security measures 84, before they ever reach the end user's virtualized OS 82.
In a further exemplary embodiment, another copy 220 of the virtualized OS 82 can be run in a quarantined environment 200, for example, for performing behavioral analysis, and the like, with the virtualized OS 220 date, time, and the like, set ahead. Advantageously, with such novel functionality, undocumented threats, for example, zero day exploits, and the like, can be identified and counteracted by the security measures 84 on the working copy 220 of the end users virtualized OS 82. In addition, if the end user's virtualized OS 82 is inadvertently breached and/or infected, the infected main OS 82 can be rolled back to a state corresponding to a moment in time before the breach/infection occurred based on the working copy 220.
The devices and subsystems of the code inspection system of the exemplary embodiments can be implemented either on a single programmed general purpose computer or a separate programmed general purpose computer. However, the code inspection system can also be implemented on a special purpose computer, a programmed microprocessor or microcontroller and peripheral integrated circuit element, an ASIC or other integrated circuit, a digital signal processor, a hardwired electronic or logic circuit such as a discrete element circuit, a programmable logic device such as PLD, PLA, FPGA, PAL, or the like. In general, any device capable of implementing a finite state machine that is in turn capable of implementing the methods of the exemplary embodiments can be used to implement the code inspection system according to this invention.
Furthermore, the disclosed methods may be readily implemented in software using object or object-oriented software development environments that provide portable source code that can be used on a variety of computer or workstation hardware platforms. Alternatively, the disclosed test chamber management system can be implemented partially or fully in hardware using standard logic circuits or VLSI design. Whether software or hardware is used to implement the systems in accordance with this invention is dependent on the speed and/or efficiency requirements of the system, the particular function, and the particular software and/or hardware systems or microprocessor or microcomputer systems being utilized. However, the code inspection system and method illustrated herein can be readily implemented in hardware and/or software using any known or later-developed systems or structures, devices and/or software by those of ordinary skill in the applicable art from the functional description provided herein and with a general basic knowledge of the computer arts.
Moreover, the disclosed methods may be readily implemented as software executed on a programmed general purpose computer, a special purpose computer, a microprocessor, or the like. In these instances, the methods and systems of this invention can be implemented as a program embedded on a personal computer, such as a JAVA® or CGI script, as a resource residing on a server or workstation, a routine embedded on a dedicated code inspection system, a web browser, a PDA, a dedicated code inspection system, or the like. The code inspection system can also be implemented by physically incorporating the system into a software and/or hardware system, such as the hardware and software systems of a computer workstation or dedicated code inspection system.
Thus, the devices and subsystems of the exemplary embodiments can include computer readable medium or memories for holding instructions programmed according to the teachings of the present invention and for holding data structures, tables, records, and/or other data described herein. Computer readable medium can include any suitable medium that participates in providing instructions to a processor for execution. Such a medium can take many forms, including but not limited to, non-volatile media, volatile media, etc. Non-volatile media can include, for example, optical or magnetic disks, magneto-optical disks, and the like. Volatile media can include dynamic memories, and the like. Transmission media can include coaxial cables, copper wire, fiber optics, and the like. Common forms of computer-readable media can include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other suitable magnetic medium, a CD-ROM, CDRW, DVD, any other suitable optical medium, a RAM, a PROM, an EPROM, a FLASH-EPROM, any other suitable memory chip or cartridge, or any other suitable medium from which a computer can read.
It is, therefore, apparent there has been provided in accordance with the present invention, systems and methods for code inspection. While this invention has been described in conjunction with a number of embodiments, it is evident that many alternatives, modifications, and variations would be or are apparent those of ordinary skill in the applicable art. Accordingly, the invention is intended to embrace all such alternatives, modifications, equivalents and variations that are within the spirit and scope of this invention.
The present invention claims benefit of priority to U.S. Provisional Patent Application Ser. No. 61/213,190 of KERSEBOOM et al., entitled “SYSTEMS AND METHODS FOR COMPUTER SECURITY EMPLOYING VIRTUAL COMPUTER SYSTEMS,” filed on May 15, 2009, the entire disclosure of which is hereby incorporated by reference herein.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US2010/035037 | 5/14/2010 | WO | 00 | 11/14/2011 |
Number | Date | Country | |
---|---|---|---|
61213190 | May 2009 | US |