Code injection technique for remediation at an endpoint of a network

Information

  • Patent Grant
  • 10474813
  • Patent Number
    10,474,813
  • Date Filed
    Friday, October 23, 2015
    8 years ago
  • Date Issued
    Tuesday, November 12, 2019
    4 years ago
Abstract
A technique injects code into a suspicious process containing malware executing on a node to enable remediation at the node. Illustratively, the technique may inject code into the suspicious process during instrumentation of the malware in a micro-virtual machine (VM) to monitor malicious behavior and to enable remediation of that behavior at a node embodied as an endpoint. According to the technique, code may be injected into the suspicious process during instrumentation in the micro-VM of the endpoint to restore states of kernel resources (e.g., memory) that may be infected (i.e., altered) by behavior (actions) of the malware.
Description
BACKGROUND
Technical Field

The present disclosure relates to malware detection systems and, more specifically, to code injection for remediation at an endpoint of a network.


Background Information

Data communication in a network involves the exchange of data between two or more entities interconnected by communication links and sub-networks (segments). The entities are typically software processes executing in operating systems of computers, such as end nodes and intermediate nodes. The intermediate nodes interconnect the communication links and segments to enable transmission of data between the end nodes. A local area network (LAN) is an example of segment that provides relatively short distance communication among the interconnected nodes, whereas a wide area network (WAN) enables long distance communication over links provided by telecommunications facilities. The Internet is an example of a WAN that connects disparate computer networks throughout the world, providing global communication between nodes on various networks.


Malicious software (malware) has become a pervasive problem for nodes coupled to networks, such as the Internet. Malware is often embedded within downloadable content intended to adversely influence or attack normal operations of a node. Whereas operating system vulnerabilities have traditionally been common targets of such malware content, attackers have broaden their attack to exploit vulnerabilities in processes or applications, such as web browsers. For example, malware content may be embedded within objects associated with a web page hosted by a malicious web site.


Various types of security enhanced nodes are often deployed at different segments of the networks. These nodes often employ virtualization systems to provide the enhanced security needed to uncover the presence of malware embedded within ingress content propagating over the different segments. The enhanced security may include anti-virus scanning software that scans the ingress content for viruses and other forms of malware, as well as virtual machines that replay the content to monitor its behavior during execution to detect anomalies that may indicate the presence of malware. However, increasingly sophisticated malware may be able to infect the nodes by, e.g., altering states of resources of the nodes. Moreover, strict specifications for some nodes (e.g., endpoints) may require execution of software, despite known vulnerabilities and potential of infection by malware. Thus, a technique to remediate malware infection in running software is needed.





BRIEF DESCRIPTION OF THE DRAWINGS

The above and further advantages of the embodiments herein may be better understood by referring to the following description in conjunction with the accompanying drawings in which like reference numerals indicate identically or functionally similar elements, of which:



FIG. 1 is a block diagram of a network environment that may be advantageously used with one or more embodiments described herein;



FIG. 2 is a block diagram of a node that may be advantageously used with one or more embodiments described herein;



FIG. 3 is a block diagram of the threat-aware microvisor that may be advantageously used with one or more embodiments described herein;



FIG. 4 is a block diagram of a malware detection endpoint architecture that may be advantageously used with one or more embodiments described herein;



FIG. 5 is a block diagram of a malware detection appliance architecture that may be advantageously used with one or more embodiments described herein; and



FIG. 6 is a block diagram of endpoint remediation using code injection that may be advantageously used with one or more embodiments described herein.





OVERVIEW

The embodiments described herein provide a technique for injecting code into a suspicious process containing malware executing on a node to enable remediation of the malware at the node. Illustratively, the technique may inject code into the suspicious process during instrumentation of the malware in a micro-virtual machine (micro-VM) to monitor malicious behavior and to enable remediation of that behavior at a node embodied as an endpoint. According to the technique, code may be injected into the suspicious process during instrumentation in the micro-VM of the endpoint to restore states of kernel resources (e.g., memory) that may be infected (i.e., altered) by behavior (actions) of the malware. In one embodiment, execution of the suspicious process and malware on the endpoint may eventually be terminated after monitoring of the malware behavior, while in another embodiment, an operating system image (binary) containing the suspicious process may not be changed. In either embodiment, the code is illustratively injected to provide dynamic, in-process vulnerability patching that enables remediation of the malware behavior at the endpoint.


DESCRIPTION


FIG. 1 is a block diagram of a network environment 100 that may be advantageously used with one or more embodiments described herein. The network environment 100 illustratively includes a plurality of networks organized as a public network 120, such as the Internet, and a private network 130, such an organization or enterprise (e.g., customer) network. The networks 120, 130 illustratively include a plurality of network links and segments connected to a plurality of nodes 200. The network links and segments may include local area networks (LANs) 110 and wide area networks (WANs) 150, including wireless networks, interconnected by intermediate nodes 200I to form an internetwork of nodes, wherein the intermediate nodes 200I may include network switches, routers and/or one or more malware detection system (MDS) appliances (intermediate nodes 200M) described further herein. As used herein, an appliance may be embodied as any type of general-purpose or special-purpose computer, including a dedicated electronic computing device, adapted to implement a variety of software architectures relating to exploit and malware detection functionality. The term “appliance” should therefore be taken broadly to include such arrangements, in addition to any systems or subsystems configured to perform a management function for exploit and malware detection, and associated with other equipment or systems, such as a network computing device interconnecting the WANs and LANs. The LANs 110 may, in turn, interconnect end nodes 200E which, in the case of private network 130, may be illustratively embodied as endpoints.


In an embodiment, the endpoints may illustratively include, e.g., client/server desktop computers, laptop/notebook computers, process controllers, medical devices, data acquisition devices, mobile devices, such as smartphones and tablet computers, and/or any other intelligent, general-purpose or special-purpose electronic device having network connectivity and, particularly for some embodiments, that may be configured to implement a virtualization system. The nodes 200 illustratively communicate by exchanging packets or messages (i.e., communication traffic) according to a predefined set of protocols, such as the Transmission Control Protocol/Internet Protocol (TCP/IP); however, it should be noted that other protocols, such as the HyperText Transfer Protocol Secure (HTTPS), may be advantageously used with the embodiments herein. In the case of private network 130, the intermediate node 200I may include a firewall or other network device configured to limit or block certain communication (network) traffic in an attempt to protect the endpoints from unauthorized users. Unfortunately, such conventional attempts often fail to protect the endpoints, which may be compromised.



FIG. 2 is a block diagram of a node 200, e.g., endpoint 200E or MDS appliance 200M, that may be advantageously used with one or more embodiments described herein. The node 200 illustratively includes one or more central processing unit (CPUs) 212, a memory 220, one or more network interfaces 214 and one or more devices 216 connected by a system interconnect 218, such as a bus. The devices 216 may include various input/output (I/O) or peripheral devices, such as storage devices, e.g., disks. The disks may be solid state drives (SSDs) embodied as flash storage devices or other non-volatile, solid-state electronic devices (e.g., drives based on storage class memory components), although, in an embodiment, the disks may also be hard disk drives (HDDs). Each network interface 214 may include one or more network ports containing the mechanical, electrical and/or signaling circuitry needed to connect the node to the network 130 to thereby facilitate communication over the network. To that end, the network interface 214 may be configured to transmit and/or receive messages using a variety of communication protocols including, inter alia, TCP/IP and HTTPS.


In one or more embodiments where the MDS appliance 200M is communicatively coupled with the network 130, the network interface 214 may operate as a data capturing device (sometimes referred to as a “tap” or “network tap”) that is configured to receive incoming network (data) traffic propagating from public network 120 and into private network 130, and provide at least some of this data traffic or a duplicated copy of the traffic for malware detection. In one embodiment, the MDS appliance may be positioned (deployed) behind the firewall at an ingress point into the private network 130, and at least partially in-line with network devices (e.g., endpoints) so as to subject the incoming traffic to analysis (e.g., through static analysis) and potentially block that traffic which is classified as malware from reaching its destination (e.g., the endpoints). In another embodiment, the static analysis may be at least partially performed by the firewall or other intermediate device, or performed by the network interface 214 (e.g., by CPU 212 and/or a digital signal processor on a network interface card).


The memory 220 may include a plurality of locations that are addressable by the CPU(s) 212 and the network interface(s) 214 for storing software program code (including application programs) and data structures associated with the embodiments described herein. The CPU 212 may include processing elements or logic adapted to execute the software program code, such as threat-aware microvisor 300 as well as modules of malware detection architectures described herein, and manipulate the data structures. Exemplary CPUs may include families of instruction set architectures based on the x86 CPU from Intel Corporation of Santa Clara, Calif. and the x64 CPU from Advanced Micro Devices of Sunnyvale, Calif.


An operating system kernel 230, portions of which are typically resident in memory 220 and executed by the CPU, functionally organizes the node by, inter alia, invoking operations in support of the software program code and application programs executing on the node. A suitable operating system kernel 230 may include the Windows® series of operating systems from Microsoft Corp of Redmond, Wash., the MAC OS® and IOS® series of operating systems from Apple Inc. of Cupertino, Calif., the Linux operating system and versions of the Android™ operating system from Google, Inc. of Mountain View, Calif., among others. Suitable application programs may include Adobe Reader® from Adobe Systems Inc. of San Jose, Calif. and Microsoft Word from Microsoft Corp of Redmond, Wash. Illustratively, the software program code may be implemented as operating system processes of the kernel 230. As used herein, a process (e.g., a user mode process) is an instance of software program code (e.g., an application program) executing in the operating system that may be separated (decomposed) into one or more threads, wherein each thread is a sequence of execution within the process.


It will be apparent to those skilled in the art that other types of processing elements and memory, including various computer-readable media, may be used to store and execute program instructions pertaining to the embodiments described herein. Also, while the embodiments herein are described in terms of software program code, processes, and computer, e.g., application, programs stored in memory, alternative embodiments also include the code, processes and programs being embodied as engines and/or modules consisting of hardware, software, firmware, or combinations thereof.


Threat-Aware Microvisor



FIG. 3 is a block diagram of the threat-aware microvisor 300 that may be advantageously used with one or more embodiments described herein. The threat-aware microvisor (hereinafter “microvisor”) may be configured to facilitate run-time security analysis, including exploit and malware detection and threat intelligence, of operating system processes executing on the node 200. To that end, the microvisor may be embodied as a light-weight module disposed or layered beneath (underlying, i.e., directly on native hardware) the operating system kernel 230 of the node to thereby virtualize the hardware and control privileges (i.e., access control permissions) to kernel (e.g., hardware) resources of the node 200 that are typically controlled by the operating system kernel. Illustratively, the kernel resources may include (physical) CPU(s) 212, memory 220, network interface(s) 214, and devices 216. The microvisor 300 may be configured to control access to one or more of the resources in response to a request by an operating system process to access the resource.


As a light-weight module, the microvisor 300 may provide a virtualization layer having less functionality than a typical hypervisor. Therefore, as used herein, the microvisor 300 is a module (component) that underlies the operating system kernel 230 and includes the functionality of a micro-kernel (e.g., protection domains, execution contexts, capabilities and scheduling), as well as a subset of the functionality of a hypervisor (e.g., hyper-calls to implement a virtual machine monitor). The microvisor may cooperate with a unique virtual machine monitor (VMM), i.e., a type 0 VMM, to provide additional virtualization functionality in an operationally and resource efficient manner. Unlike a type 1 or type 2 VMM (hypervisor), the type 0 VMM (VMM 0) does not fully virtualize the kernel (hardware) resources of the node and supports execution of only one entire operating system/instance inside one virtual machine, i.e., VM 0. VMM 0 may thus instantiate VM 0 as a container for the operating system kernel 230 and its kernel resources. In an embodiment, VMM 0 may instantiate VM 0 as a module having instrumentation logic 360 directed to determination of an exploit or malware in any suspicious operating system process (kernel or user mode). Illustratively, VMM 0 is a pass-through module configured to expose the kernel resources of the node (as controlled by microvisor 300) to the operating system kernel 230. VMM 0 may also expose resources such as virtual CPUs (threads), wherein there is one-to-one mapping between the number of physical CPUs and the number of virtual CPUs that VMM 0 exposes to the operating system kernel 230. To that end, VMM 0 may enable communication between the operating system kernel (i.e., VM 0) and the microvisor over privileged interfaces 315 and 310.


The VMM 0 may include software program code (e.g., executable machine code) in the form of instrumentation logic 350 (including decision logic) configured to analyze one or more interception points originated by one or more operating system processes to invoke the services, e.g., accesses to the kernel resources, of the operating system kernel 230. As used herein, an interception point is a point in an instruction stream where control passes to (e.g., is intercepted by) either the microvisor, VMM 0 or another virtual machine. Illustratively, VMM 0 may contain computer executable instructions executed by the CPU 212 to perform operations that initialize and implement the instrumentation logic 350, as well as operations that spawn, configure, and control/implement VM 0 and its instrumentation logic 360.


In an embodiment, the microvisor 300 may be organized to include a protection domain illustratively bound to VM 0. As used herein, a protection domain is a container for various data structures, such as execution contexts, scheduling contexts, and capabilities associated with the kernel resources accessible by an operating system process. Illustratively, the protection domain may function at a granularity of an operating system process (e.g., a user mode process) and, thus, is a representation of the process. Accordingly, the microvisor may provide a protection domain for the process and its run-time threads executing in the operating system. A main protection domain (PD 0) of the microvisor controls all of the kernel resources available to the operating system kernel 230 (and, hence, the user mode process) of VM 0 via VMM 0 and, to that end, may be associated with the services provided to the user mode process by the kernel 230.


An execution context 320 is illustratively a representation of a thread (associated with an operating system process) and, to that end, defines a state of the thread for execution on CPU 212. In an embodiment, the execution context may include inter alia (i) contents of CPU registers, (ii) pointers/values on a stack, (iii) a program counter, and/or (iv) allocation of memory via, e.g., memory pages. The execution context 320 is thus a static view of the state of thread and, therefore, its associated process. Accordingly, the thread executes within the protection domain associated with the operating system process of which the thread is a part. For the thread to execute on a CPU 212 (e.g., as a virtual CPU), its execution context 320 is tightly linked to a scheduling context 330, which may be configured to provide information for scheduling the execution context 320 for execution on the CPU 212. Illustratively, the scheduling context information may include a priority and a quantum time for execution of its linked execution context on CPU 212.


In an embodiment, the capabilities 340 may be organized as a set of access control permissions to the kernel resources to which the thread may request access. Each time the execution context 320 of a thread requests access to a kernel resource, the capabilities 340 are examined. There is illustratively one set of capabilities 340 for each protection domain, such that access to kernel resources by each execution context 320 (i.e., each thread of an execution context) of a protection domain may be defined by the set of capabilities 340. For example, physical addresses of pages of memory 220 (resulting from mappings of virtual addresses to physical addresses) may have associated access permissions (e.g., read, write, read-write) within the protection domain. To enable an execution context 320 to access a kernel resource, such as a memory page, the physical address of the page may have a capability 340 that defines how the execution context 320 may reference that page. Illustratively, the capabilities may be examined by hardware (e.g., a hardware page fault upon a memory access violation) or by program code. A violation of a capability in a protection domain may be an interception point, which returns control to the VM (e.g., VM 0) bound to the protection domain.


Malware Detection Endpoint Architecture


In an embodiment, the threat-aware microvisor 300 may be deployed in a micro-virtualization architecture as a module of a virtualization system executing on the endpoint 200E to provide exploit and malware detection within the network environment 100. FIG. 4 is a block diagram of a malware detection endpoint architecture 400 that may be advantageously used with one or more embodiments described herein. Illustratively, the architecture 400 may organize the memory 220 of the endpoint 200E as a user space 402 and a kernel space 404. In an embodiment, the microvisor may underlie the operating system kernel 230 and execute in the kernel space 404 of the architecture 400 to control access to the kernel resources of the endpoint 200E for any operating system process (kernel or user mode). Notably, the microvisor 300 executes at the highest privilege level of the hardware (CPU) to thereby virtualize access to the kernel resources of the endpoint in a light-weight manner that does not share those resources among user mode processes 410 when requesting the services of the operating system kernel 230. That is, there is one-to-one mapping between the resources and the operating system kernel, such that the resources are not shared.


A system call illustratively provides an interception point at which a change in privilege levels occurs in the operating system, i.e., from a privilege level of the user mode process to a privilege level of the operating system kernel. VMM 0 may intercept the system call and examine a state of the process issuing (sending) the call. The instrumentation logic 350 of VMM 0 may analyze the system call to determine whether the call is suspicious and, if so, instantiate (spawn) one or more “micro” virtual machines (VMs) equipped with monitoring functions that cooperate with the microvisor to detect anomalous behavior which may be used in determining an exploit or malware.


As used herein, an exploit may be construed as information (e.g., executable code, data, one or more commands provided by a user or attacker) that attempts to take advantage of a computer program or system vulnerability, often employing malware. Typically, a vulnerability may be a coding error or artifact of a computer program that allows an attacker to alter legitimate control flow during processing of the computer program by an electronic device (such as a node) and, thus, causes the electronic device to experience undesirable or unexpected behaviors. The undesired or unexpected behaviors may include a communication-based or execution-based anomaly which, for example, could (1) alter the functionality of the electronic device executing application software in a malicious manner; (2) alter the functionality of the electronic device executing the application software without any malicious intent; and/or (3) provide unwanted functionality which may be generally acceptable in another context. To illustrate, a computer program may be considered a state machine where all valid states (and transitions between states) are managed and defined by the program, in which case an exploit may be viewed as seeking to alter one or more of the states (or transitions) from those defined by the program. Malware may be construed as computer code that is executed by an exploit to harm or co-opt operation of an electronic device or misappropriate, modify or delete data. Conventionally, malware may often be designed with malicious intent, and may be used to facilitate an exploit. For convenience, the term “malware” may be used herein to describe a malicious attack, and encompass both malicious code and exploits detectable in accordance with the disclosure herein.


As used herein, the term “micro” VM denotes a virtual machine serving as a container that is restricted to a process (as opposed to VM 0 which is spawned as a container for the entire operating system.) Such spawning of a micro-VM may result in creation of an instance of another module (i.e., micro-VM N) that is substantially similar to VM 0, but with different (e.g., additional) instrumentation logic 360N illustratively directed to determination of malware in the suspicious process by, e.g., monitoring its behavior. In an embodiment, the spawned micro-VM illustratively encapsulates an operating system process, such as a user mode process 410. In terms of execution, operation of the process is controlled and synchronized by the operating system kernel 230; however, in terms of access to kernel resources, operation of the encapsulated process is controlled by VMM 0. Notably, the resources appear to be isolated within each spawned micro-VM such that each respective encapsulated process appears to have exclusive control of the resources. In other words, access to kernel resources is synchronized among the micro-VMs and VM 0 by VMM 0 rather than virtually shared. Similar to VM 0, each micro-VM may be configured to communicate with the microvisor (via VMM 0) over privileged interfaces (e.g., 315n and 310n).


In an embodiment, the privileged interfaces 310 and 315 may be embodied as a set of defined hyper-calls, which are illustratively inter process communication (IPC) messages exposed (available) to VMM 0 and VM 0 (including any spawned micro-VMs). The hyper-calls are generally originated by VMM 0 and directed to the microvisor 300 over privileged interface 310, although VM0 and the micro-VMs may also originate one or more hyper-calls (IPC messages) directed to the microvisor over privileged interface 315. However, the hyper-calls originated by VM 0 and the micro-VMs may be more restricted than those originated by VMM 0.


In an embodiment, the microvisor 300 may be organized to include a plurality of protection domains (e.g., PD 0-N) illustratively bound to VM 0 and one or more micro-VMs, respectively. For example, the spawned micro-VM (e.g., micro-VM N) is illustratively associated with (bound to) a copy of PD 0 (e.g., PD N) which, in turn, may be bound to the process, wherein such binding may occur through memory context switching. In response to a decision to spawn the micro-VM N, VMM 0 may issue a hyper-call over interface 310 to the microvisor requesting creation of the protection domain PD N. Upon receiving the hyper-call, the microvisor 300 may copy (i.e., “clone”) the data structures (e.g., execution contexts, scheduling contexts and capabilities) of PD 0 to create PD N for the micro-VM N, wherein PD N has essentially the same structure as PD 0 except for the capabilities associated with the kernel resources. The capabilities for PD N may limit or restrict access to one or more of the kernel resources as instructed through one or more hyper-calls from, e.g., VMM 0 and/or micro-VM N over interface 310n to the microvisor. Accordingly, the microvisor 300 may contain computer executable instructions executed by the CPU 212 to perform operations that initialize, clone and configure the protection domains.


Advantageously, the microvisor 300 may be organized as separate protection domain containers for the operating system kernel 230 (PD 0) and one or more operating system processes (PD N) to facilitate further monitoring and/or understanding of behaviors of a process and its threads. Such organization of the microvisor also enforces separation between the protection domains to control the activity of the monitored process. Moreover, the microvisor 300 may enforce access to the kernel resources through the use of variously configured capabilities of the separate protection domains. Unlike previous virtualization systems, separation of the protection domains to control access to kernel resources at a process granularity enables detection of anomalous behavior of malware. That is, in addition to enforcing access to kernel resources, the microvisor enables analysis of the operation of a process within a spawned micro-VM to detect exploits or other malicious code threats that may constitute malware.


The user mode processes 410 and operating system kernel 230 may execute in the user space 402 of the endpoint architecture 400, although it will be understood to those skilled in the art that the user mode processes may execute in another address space defined by the operating system kernel. Illustratively, the operating system kernel 230 may execute under control of the microvisor at a privilege level (i.e., a logical privilege level) lower than a highest privilege level of the microvisor, but at a higher CPU privilege level than that of the user mode processes 410. In addition, VMM 0 and its spawned VMs (e.g., VM 0 and micro-VM N) may execute in user space 402 of the architecture 400. As a type 0 virtual machine monitor, VMM 0 (and its spawned VM 0 and micro-VMs) may execute at the highest (logical) privilege level of the microvisor. That is, VMM 0 (and its spawned VM 0 and micro-VMs) may operate under control of the microvisor at the highest microvisor privilege level, but may not directly operate at the highest CPU (hardware) privilege level.


Illustratively, the instrumentation logic of VMM 0 (and its spawned micro-VMs) may include monitoring logic configured to monitor and collect capability violations (e.g., generated by CPU 212) in response to one or more interception points to thereby infer malware. Inference of malware may also be realized through sequences of interception points wherein, for example, a system call followed by another system call having certain parameters may lead to an inference that the process sending the calls is malware. The interception point thus provides an opportunity for VMM 0 to perform “light-weight” (i.e., limited so as to maintain user experience at the endpoint with little performance degradation) analysis to evaluate a state of the process in order to detect possible malware without requiring any policy enforcement. VMM 0 may then decide to spawn a micro-VM and configure the capabilities of its protection domain to enable deeper monitoring and analysis (e.g., through interception points and capability violations) in order to determine whether the process includes malware. Notably, the analysis may also classify the process as a type of malware (e.g., a stack overflow) and may even identify the same. As a result, the invocation of instrumentation and monitoring logic of VMM 0 and its spawned VMs in response to interception points originated by operating system processes and capability violations generated by the microvisor advantageously enhance the virtualization system described herein to provide an exploit and malware detection system configured for run-time security analysis of the operating system processes executing on the endpoint.


VMM 0 may also log the state of the monitored process within system logger 470. In an embodiment, the state of the process may be realized through the contents of the execution context 320 (e.g., CPU registers, stack, program counter, and/or allocation of memory) executing at the time of each capability violation. In addition, the state of the process may be realized through correlation of various activities or behavior of the monitored process. The logged state of the process may thereafter be exported from the system logger 470 to the MDS 200M of the network environment 100 by, e.g., forwarding the state as one or more IPC messages through VMM 0 (VM 0) and onto a network protocol stack (not shown) of the operating system kernel. The network protocol stack may then format the messages as one or more packets according to, e.g., a syslog protocol such as RFC 5434 available from IETF, for transmission over the network to the MDS appliance 200M.


Malware Detection


Exploit and malware detection on the endpoint may be performed in accordance with one or more processes embodied as software modules or engines containing computer executable instructions executed by the CPU to detect suspicious and/or malicious behaviors of an operating system process (including an application program) when, e.g., executing contents of an object, and to correlate and classify the detected behaviors as indicative of malware (i.e., a matter of probability). Notably, the endpoint may perform (implement) exploit and malware detection as background processing (i.e., minor use of endpoint resources) with data processing being implemented as its primary processing (e.g., in the foreground having majority use of endpoint resources), whereas the MDS appliance implements such detection as its primary processing (i.e., majority use of appliance resources). Detection of a suspicious and/or malicious object may be performed at the endpoint by static and dynamic analysis of the object. As used herein, an object may include a logical entity such as, for example, a web page, email, email attachment, file or universal resource locator (URL). Static analysis may perform light-weight (quick) examination of the object to determine whether it is suspicious, while dynamic analysis may instrument the behavior of the object as the operating system process executes (runs) via capability violations of, e.g., operating system events. A correlation engine 410 and a classifier 420 may thereafter cooperate to perform correlation and classification of the detected behaviors as malicious or not. That is, the correlation engine 410 and classifier 420 may cooperate to analyze and classify observed behaviors of the object (based on the events) as indicative of malware.


In an embodiment, the static analysis may perform light-weight examination of the object (including a network packet) to determine whether it is suspicious and/or malicious. To that end, the static analysis may include a static inspection engine 430 and a heuristics engine 440 executing as user mode processes of the operating system kernel 230. The static inspection engine 430 and heuristics engine 440 may employ statistical analysis techniques, including the use of vulnerability/exploit signatures and heuristics, to perform non-behavioral analysis in order to detect anomalous characteristics (i.e., suspiciousness and/or malware) without execution (i.e., monitoring run-time behavior) of the object. For example, the static inspection engine 430 may employ signatures (referred to as vulnerability or exploit “indicators”) to match content (e.g., bit patterns) of the object with patterns of the indicators in order to gather information that may be indicative of suspiciousness and/or malware. The heuristics engine 440 may apply rules and/or policies to detect anomalous characteristics of the object in order to identify whether the object is suspect and deserving of further analysis or whether it is non-suspect (i.e., benign) and not in need of further analysis. The statistical analysis techniques may produce static analysis results that include, e.g., identification of communication protocol anomalies and/or suspect source addresses of known malicious servers.


The dynamic analysis may include exploit detection performed by, e.g., the microvisor 300 and micro-VM N to observe behaviors of the object. In an embodiment, exploit detection at the endpoint does not generally wait for results from the static analysis. The behaviors of the object may be observed by instrumenting the object (using, e.g., instrumentation logic 360N) as the operating system process runs at micro-VM N, wherein the observed run-time behaviors may be captured by the microvisor 300 and VMM 0, and provided to the correlation engine 410 as dynamic analysis results.


Illustratively, monitors may be employed during the dynamic analysis to monitor the run-time behaviors of the object and capture any resulting activity. The monitors may be embodied as capability violations configured to trace particular operating system events. During instrumenting of the object at the micro-VM, the system events may trigger capability violations (e.g., exceptions or traps) generated by the microvisor 300 to enable monitoring of the object's behaviors during run-time.


The static analysis results and dynamic analysis results may be stored in memory 220 (e.g., in system logger 470) and provided to the correlation engine 410, which may provide correlation information to the classifier 420. Alternatively, the results or events may be provided or reported to the MDS appliance 200M for correlation. The correlation engine 410 may be configured to operate on correlation rules that define, among other things, sequences of known malicious events (if-then statements with respect to, e.g., attempts by a process to change memory in a certain way that is known to be malicious). The events may collectively correlate to malicious behavior. As noted, a micro-VM may be spawned to instrument a suspect process (object) and cooperate with the microvisor 300 and VMM 0 to generate capability violations in response to interception points, which capability violations are provided as dynamic analysis result inputs to the correlation engine 410. The rules of the correlation engine 410 may then be correlated against those dynamic analysis results, as well as static analysis results, to generate correlation information pertaining to, e.g., a level of risk or a numerical score used to arrive at a decision of (deduce) maliciousness. The classifier 420 may be embodied as a classification engine executing as a user mode process of the operating system kernel 230 and configured to use the correlation information provided by correlation engine 410 to render a decision as to whether the object is malicious. Illustratively, the classifier 420 may be configured to classify the correlation information, including monitored behaviors (expected and unexpected/anomalous) and capability violations, of the object relative to those of known malware and benign content.


Malware Detection Appliance Architecture


In one or more embodiments, the MDS appliance 200M may be embodied as an intermediate node configured to analyze communication traffic associated with one or more endpoints 200E coupled to a network segment, such as segment 110, of a network, such as private network 130. The MDS appliance 200M may be illustratively positioned (e.g., as an ingress/egress point) within the private network 130 or segment 110 to intercept (i.e., capture) the traffic. In one or more embodiments, the MDS appliance may manage each endpoint by, e.g., requesting replay and instrumentation of the traffic by the endpoint 200E. The intercepted traffic may also be replayed and instrumented (i.e., monitored) at the appliance. Thereafter, the instrumented traffic may be correlated at the MDS appliance 200M, and the appliance may be configured to communicate with and instruct the endpoint to, e.g., perform an action and receive notification of that action being performed.


Illustratively, the MDS appliance 200M may include functionality directed to replaying of communication traffic and correlating instrumentation of that traffic with actions resulting from that traffic at the endpoint. For every network packet received, the appliance may run a heuristic to compute a flow, as appropriate, for the packet, and then create (spawn) a virtual machine (VM) to emulate the endpoint using an image of an operating system (guest operating system and one or more applications) configured to replicate a software processing environment of the endpoint, e.g., based on a payload (object) of the packet to be replayed and instrumented. As noted, an object may include a logical entity such as, for example, a web page, an email or email attachment, an executable (i.e., binary or script), a file (which may contain an executable), or URL. Information as to an appropriate processing environment may be provided by the packet itself, e.g., the packet header may identify the packet type, for example, a document such as a Portable Document Format (PDF) document and, thus, the processing environment may include a document reader, such as a PDF reader from Adobe Systems Inc. Additionally, or in alternative embodiments, information may also be provided by the endpoint (such as the destination endpoint as specified in the packet) to the MDS appliance indicating a type of application software (process) executing within the operating system on the endpoint. The appliance may then launch a copy of the application along with appropriate instrumentation to process each object. For example, assume the MDS appliance 200M replays HTTPS traffic received at the endpoint which executes, inter alia, an application (i.e., a web browser). The appliance may capture the communication (HTTPS) traffic destined to the endpoint, spawn the VM and launch a copy of the web browser along with instrumentation to monitor the traffic.


In an embodiment, the threat-aware microvisor 300 may be deployed in a virtualization architecture as a module of a virtualization system executing on the MDS appliance 200M to provide exploit and malware detection within the network environment 100. FIG. 5 is a block diagram of a malware detection appliance architecture 500 that may be advantageously used with one or more embodiments described herein. Illustratively, the architecture 500 may organize the memory 220 of the MDS appliance 200M as a user space 502 and a kernel space 504. The microvisor may underlie the operating system kernel 230 and execute at the highest privilege level of the CPU within the kernel space 504 of the architecture 500 to control access to the kernel resources of the appliance 200M for any operating system process (kernel or user mode). User mode processes 510 and operating system kernel 230 may execute in the user space 502 of the appliance architecture 500. Illustratively, the operating system kernel 230 may execute under control of the microvisor at a privilege level (i.e., a logical privilege level) lower than a highest privilege level of the microvisor, but at a higher CPU privilege level than that of the user mode processes 510. In addition, VMM 0 and VM 0 may execute in user space 502 under control of the microvisor at the highest microvisor privilege level, but may not directly operate at the highest CPU (hardware) privilege level.


One or more hypervisors, e.g., type 1 VMM, may be disposed as one or more modules over the microvisor 300 and operate in user space 502 of the architecture 500 under control of the microvisor at the highest microvisor privilege level to provide additional layers of virtualization for the MDS appliance 200M. Illustratively, each hypervisor provides full virtualization of kernel (hardware) resources and supports execution of one or more entire operating system instances (i.e., guest operating system) inside one or more full virtual machines. In one or more embodiments, the full virtual machine (VM) may simulate a computer (machine) based on specifications of a hypothetical (abstract) computer or based on an architecture and functions of an actual (real) computer. To that end, a hypervisor (e.g., VMM 1) may instantiate a full VM (e.g., VM 1) as a module provisioned with a software profile that includes a guest operating system (e.g., guest operating system 515) and any associated application programs (e.g., application 525), as well as instrumentation logic (e.g., instrumentation logic 360A) directed to determination of malware in any suspicious object or application executing on the guest operating system. Illustratively, the hypervisor may instantiate the full VM from a pool of VMs configured to closely simulate various target operating environments (e.g., software profiles) in which the malware is to be analyzed. The software profile (e.g., guest operating system and/or application program) provisioned and configured in the VM may be different (e.g., in vendor, type and/or version) from the software profile provisioned and configured in other instantiated VMs (e.g., VM N).


The instantiated VM (e.g., VM 1) is illustratively associated with (bound to) a copy of PD 0 (e.g., PD 1), wherein such binding may occur through memory context switching. In response to a decision to instantiate (spawn) the VM 1, VMM 1 may issue a hyper-call over interface 310b to the microvisor requesting creation of the protection domain PD 1. Upon receiving the hyper-call, the microvisor 300 may copy (i.e., “clone”) the data structures (e.g., execution contexts, scheduling contexts and capabilities) of PD 0 to create PD 1 for the VM 1, wherein PD 1 has essentially the same structure as PD 0 except for the capabilities associated with the kernel resources. The capabilities for PD 1 may limit or restrict access to one or more of the kernel resources as instructed through one or more hyper-calls from, e.g., VMM 1 and/or VM 1 over interface 310b to the microvisor.


Illustratively, each hypervisor (e.g., VMM 1-N) may contain computer executable instructions executed by the CPU 212 to perform operations that initialize and configure the instrumentation logic (e.g., instrumentation logic 350A-N), as well as operations that spawn, configure, and control/implement the VM (e.g., VM 1-N) and their instrumentation logic (e.g., 360A). In an embodiment, there is illustratively one hypervisor (e.g., VMM 1-N) for each VM (e.g., VMs 1-N), wherein each VM may be used to emulate an endpoint. The MDS appliance 200M may not emulate every endpoint on, e.g., a segment of the network 130, but when a suspicious object (such as, e.g., a file of a network packet) is identified, the VMM 1 of the appliance may create (spawn) a full VM 1 to analyze that object. The virtualization layers of the MDS appliance 200M may cooperate to implement an abstraction of virtual devices exposed as, e.g., virtual network interfaces to the VMs, as opposed to the real network interfaces exposed to the micro-VMs of the endpoint.


The user mode processes 510 executing on the MDS appliance 200M may include a heuristic engine 530 that, in response to receiving communication traffic, is configured to run one or more heuristics to determine whether the traffic (e.g., an object of a packet) is suspicious. Illustratively, the heuristic engine may use pre-defined anomalous behaviors (monitored activity) of verified exploits and malware to, e.g., identify communication protocol anomalies and/or suspect source addresses of known malicious servers. For example, the heuristic engine may examine metadata or attributes of the object and/or a code image (e.g., a binary image of an executable) of the object to determine whether a portion of the object matches a predetermined pattern or signature associated with a known type of malware. The heuristic engine 530 may provide the packet of the suspicious traffic to one or more processes 510 embodied as analysis engine 540. In an embodiment, the analysis engine 540 may be configured to perform static analysis of the object of the packet to, e.g., identify software profile information associated with an operating system instance for execution in a full VM (virtualizing all kernel resources).


The analysis engine 540 may also be configured to analyze other content of the packet (e.g., destination address of a network header) to determine its destination (i.e., the endpoint). To that end, the analysis engine 540 may be configured to cooperate with a module, e.g., endpoint (EP) logic 560, to communicate with the endpoint 200E, e.g., to identify and/or acquire information (including the software profile) associated with execution of the malware on the endpoint. Illustratively, communication with the endpoint may be effected by, e.g., forwarding one or more IPC messages to a network protocol stack (not shown) of the operating system kernel 230. The network protocol stack may then format the messages as one or more packets for transmission over the network to the endpoint. The analysis engine 540 may then provide the software profile information to another process embodied as scheduler 550, which may coordinate with the hypervisor, e.g., VMM 1, to spawn a VM, e.g., VM 1, to replay the traffic.


When replaying the traffic, the analysis engine 540 may employ the EP logic 560 to invoke appropriate instrumentation logic 360A of VM 1 to enable communication with the endpoint to perform dynamic analysis and/or correlation of the suspicious object. In an embodiment, correlation (as described herein) may be performed by one or more user mode processes embodied as a correlation engine 570. The instrumentation logic 360A may be configured to monitor different types of objects, such as payloads of network (web) and email packets, although alternatively, there could be separate web-based and email-based MDS appliances, each of which may be deployed the same way and configured to perform that same work. The MDS appliance 200M may include a module that communicates with a similar module on the endpoint to perform the requested instrumentation. For example in the case of email objects, the application may be an email reader that analyzes email traffic captured by the appliance (and endpoint).


During instrumentation (monitoring) in VM 1, the object may manifest behaviors that are captured by the microvisor and VMM 1. That is, the object may execute within the software profile of VM 1 and its monitored operation (behaviors) observed. The microvisor 300 and VMM 1 may record any resulting activity as, e.g., an event within a database of another user mode process embodied as an event logger 590. In addition, the activity of the object (including the event) may be provided to the correlation engine 570 and to yet another user mode process embodied as a classifier 580 for classification and/or validation of the object as, e.g., malware. Illustratively, correlation engine 570 may be configured to correlate observed behaviors (e.g., results of dynamic analysis) with known malware and/or benign objects (embodied as defined rules) and generate an output (e.g., a level of risk or a numerical score associated with an object) that is provided to the classifier. The classifier 580 may be configured to classify the observed behaviors (expected and unexpected/anomalous) and capability violations of the object relative to those of known malware and benign content to render a decision of malware, i.e., validate the monitored operation of the object as malicious activity, based on the risk level or score exceeding a probability threshold.


Operationally, the MDS appliance may intercept (i.e., receive) and store communication traffic flowing over the network that is destined to the endpoints. The appliance may analyze the traffic and communicate with the endpoints over the network using a messaging protocol that encapsulates an object of interest (e.g., a file of a network packet). Illustratively, the MDS appliance may deploy the network protocol stack, e.g., of the operating system kernel 230 configured to employ a protocol to communicate with the endpoints. For example, the EP logic 560 may notify an endpoint to replay the object using a network message having a MAC address (layer 2 connectivity) and/or IP address of the endpoint (layer 3 connectivity).


Code Injection for Remediation


The embodiments described herein provide a technique for injecting code into a suspicious process containing malware executing on a node to enable remediation at the node. Illustratively, the technique may inject code into the suspicious process (i.e., inject instructions into memory within an address space of process) during instrumentation of the malware in a micro-VM to monitor malicious behavior and to enable remediation of that behavior at a node embodied as an endpoint. According to the technique, code may be injected into the suspicious process during instrumentation in the micro-VM of the endpoint to restore states of kernel resources (e.g., memory) that may be infected and altered by behavior (actions) of the malware. Notably, restoration of kernel resource states may occur by (1) an act of injecting the code itself (e.g., overwriting malware in memory) and (2) execution of the injected code (e.g., repairing damage done by malware). In one embodiment, execution of the suspicious process and malware on the endpoint may be terminated after monitoring of the malware behavior, while in another embodiment, an operating system image (binary) containing the suspicious process may not be changed. In either embodiment, the code is illustratively injected to provide dynamic, in-process vulnerability patching that enables remediation of the malware behavior at the endpoint.



FIG. 6 is a block diagram of endpoint remediation using code injection that may be advantageously used with one or more embodiments described herein. Assume there has been an infection that manifests as changes to a kernel resource 630 (e.g., memory) by an exploit (i.e., vulnerability) to enable malware 610a to execute in process 620a in micro-VM A. Code may be injected (i.e., injected code 640a) to restore the memory (i.e., resource 630) to its state prior to the infection. Assume further that original code 625 of, e.g., process 620b stored at certain pages of memory is altered by malware 610b. During instrumentation of the process 620b in micro-VM B, the behavior of the malware 610b may be monitored as it attempts to change the original code stored in the memory pages. In response, the technique described herein may inject code 640b to reverse the changes made to the original code 625 by the malware 610b and to restore the state of that code. That is, the malicious changes to the memory pages may be overwritten (or alternatively removed and replaced) with the original code (i.e., the injected code 640b) to provide non-fixed (i.e., dynamic) patching of the process vulnerability. Thus, the process 620b altered by the malware need not be terminated; rather, the process 620b may be dynamically repaired at run-time. As such, the original code persistent on storage devices 216 need not be patched, despite the known exploit and/or malicious content (i.e., detected vulnerability) so as to, e.g., meet any requirements to run a specific version of the original code (e.g., embodied as application 525). Notably, restoration of the original code 625 may be accomplished by executing the injected code 640b at run-time to repair (rather than simply overwrite) the memory pages that store that original code.


In an embodiment, a file 660 containing the specific version of software (e.g., version of the application 525) may be executed at the endpoint; yet it may be undesirable (e.g., to meet a compliance requirement) to permanently change the file such that the software's instruction sequence or “logic” is altered. That is, the file may be an executable binary of an operating system that is deemed not subjectable to fixed (i.e., static) patching on the storage device 216. The executed binary (e.g., process 620b) may be instrumented at micro-VM B of the endpoint to uncover the malicious content and, further, to monitor its malicious behavior. According to the technique, the microvisor and VMM 0 do not stop (“kill”) the malicious process 620b, but rather allow it to run in the micro-VM B while reversing any changes to the memory pages having the original code 625 or other kernel resource that the malware 610b may attempt. Essentially, the technique provides a dynamic patch while the process (malware) is running, e.g., in memory, without rendering any fixed or static changes to the executable file (binary) on the storage device. Notably, the patch may include code injected along-side the existing software instructions of the process (e.g., within an address space of the process) that is executed to repair damage by the malware. Illustratively, the dynamic patch may operate in a manner such that every time the malware attempts to alter (i.e., modify) the content of the kernel resource, such as a memory location, the microvisor and VMM 0 may remove (i.e., reverse) the modification and restore the state of that location, e.g., to its (prior) unaltered state. The microvisor and VMM 0 may direct operation of the dynamic patch either by directly restoring the altered kernel resource or executing the injected code (to effect restoration of the kernel resource), or combinations thereof.


In an embodiment, the technique may restore the malicious alterations (i.e., modifications) to an original resource state 632a by, e.g., capturing the state of the kernel resource execution context of the process (thread) before the process (thread) executes (i.e., original resource 632a) on the CPU and then reverting that context to the original captured state after being changed to an altered resource state 632b once execution of the thread begins. As a result, the microvisor and the VMM 0 may need to be aware of the occurrence of the malware in the process 620c so that the state of the kernel resource may be captured prior to the occurrence. Accordingly, once the malicious behavior of the malware is detected and the unaltered (i.e., original) state of the kernel resource 632a of the process is captured, dynamic (i.e., run-time) reversion to that unaltered state may be made by the microvisor and VMM 0 to thereby thwart the attempted malicious modification to the resource. Notably, the captured original state may require maintenance to enable reversion to that state after the occurrence.


Illustratively, knowledge of the exploit (and the malware) based on its malicious behavior may be known a priori (i.e., the exploit vulnerability and the resource altering behavior of the malware may be detected and recorded previously) so as to anticipate when the exploit occurs (and when the malware makes its illicit modifications). Notably, the a priori knowledge (i.e., identification of the malware and corresponding remediation) may be from another source, such as a cloud service 680 (i.e., an internet-based distribution service) or a database of the endpoint. That is, identification of the malware and the associated remediation (e.g., code injection to restore state of the affected process) may be obtained illustratively as a dynamic patch available from cloud service 680, the endpoint database, or a local server on the private network 130, wherein the patch may be available from an author (i.e., vendor) of the binary (i.e., application 525). As a result, the process need not be constantly instrumented (monitored) to uncover the occurrence. The technique (i.e., dynamic patching of the kernel resource) may be applied on subsequent executions of the binary file (i.e., invocations of the process 620b having the software instructions from the file 660) without instrumenting those subsequent executions. Accordingly, application of the dynamic patch need not have knowledge of the patch and specific kernel resources that may be remediated by applying that patch. The technique may merely inject the dynamic patch which performs appropriate remediation. In an embodiment, dynamic patches using injected code 640d to the instructions (original code 625) of the process 620d may be made as a preventative measure to avoid the exploit from occurring entirely, such that the malware 610d cannot execute. Illustratively, the dynamic patch may be in the form of a dynamic link library (DLL) injected into the process by 1) loading the DLL into the memory 220; 2) mapping one or more memory pages (e.g., code pages) having the dynamic patch into the address space of the process; and 3) executing the instructions of the dynamic patch to affect remediation.


In another embodiment, the original logic of the software instructions (i.e., flow of execution) of the process may be maintained, even though the malicious code (malware) remains in the process. That is, the malicious code (instructions) of the process may not be altered (e.g., overwritten); rather the original (i.e., non-malicious) flow of execution of the code (i.e., original process logic) may be maintained by dynamically altering the kernel resource so as to bypass execution of the malicious code. For example, assume the kernel resource is a process (call) stack and an exploit of the process executes (e.g., in a micro-VM) to cause a buffer overflow of the stack. Illustratively, the exploit may change a return address (for a function call) with an address of the malicious code (malware). As noted, the microvisor assumes control over the execution point of the process while it is running in the micro-VM. When the process is scheduled to execute on the CPU (by the scheduler), the microvisor and VMM 0 may divert execution to, e.g., the injected code without breaking the process logic. By injecting a correct return address on the stack, execution of the malware may be obviated by providing a dynamic patch that restores the stack to its correct state (i.e., the original non-malicious flow of execution) without breaking the logic (life cycle) of the process and without stopping or restarting the process (i.e., so as to allow the process to continue running).


In an embodiment, the restore state utilized by the microvisor and VMM 0 may be provided by the MDS appliance, which may have the a priori knowledge of the exploit vulnerability and the resource altering behavior of the malware. Although exploit and malware detection may be performed on a process at a micro-VM of the endpoint to render a determination that the process may contain an exploit/malware, the endpoint may report the determination to the MDS appliance for validation and/or more extensive analysis. As noted, the instrumentation of the micro-VM is light-weight in order to, inter alia, preserve (i.e., maintain) the user experience at the endpoint. Accordingly, the instrumentation performed by the micro-VM is limited such that there is no extensive CPU processing, i.e., efficient instrumentation that limits CPU processing to preserve the user experience. Instead, any extensive CPU processing is performed at the MDS appliance using, e.g., a run-time environment (software profile) of the endpoint. As a result of such extensive processing associated with the analysis, the MDS appliance may specify actions that VMM 0 and the microvisor should perform in order to address the occurrence of the detected exploit or malware at the endpoint. That is, the MDS appliance may detect the exploit and, based on the vulnerability, gather (i.e., record) the resource altering behavior of the malware. As such, the MDS appliance may illustratively instruct (e.g., via message 670 having injected code 640) the microvisor and VMM 0 as to when (e.g., relative to beginning execution of the process) and how to restore the state of the altered kernel resource with the original kernel resource (e.g., code content and/or a referenced address of the run-time environment) so as to avoid the exploit or repair damage from the malware according to the technique described herein.


While there have been shown and described illustrative embodiments for injecting code into a suspicious process containing malware executing on a node to enable remediation of that malware at the node, it is to be understood that various other adaptations and modifications may be made within the spirit and scope of the embodiments herein. For example, embodiments have been shown and described herein with relation the endpoint injecting code for remediation by the microvisor and VMM 0. However, the embodiments in their broader sense are not so limited, and may, in fact, provide a warning that may be displayed to an end user of the endpoint indicating detection of malware and/or remediation. The warning may instruct the end user to be aware (and be patient) while remediation is applied.


In addition, although the embodiments have been shown and described herein with relation to the microvisor and VMM 0 cooperating (at the endpoint) to inject code for remediation of malware, the embodiments may alternatively include a micro-kernel without protection domains (e.g., in lieu of the microvisor) operating at the highest CPU (hardware) privilege level and providing one or more interception points that pass control from the suspicious object executed in the VM N to the micro-kernel and/or hypervisor. In another alternative embodiment, the micro-kernel (without protection domains), VMM 0 and/or one or more hypervisors may be combined into a virtualization layer operating at the highest CPU privilege level that provide the one or more interception points. That is, the virtualization layer may underlie the operating system kernel (and/or guest operating system) such that the virtualization layer is configured to inject the code for remediation of malware at the endpoint.


The foregoing description has been directed to specific embodiments. It will be apparent, however, that other variations and modifications may be made to the described embodiments, with the attainment of some or all of their advantages. For instance, it is expressly contemplated that the components and/or elements described herein can be implemented as software encoded on a tangible (non-transitory) computer-readable medium (e.g., disks, electronic memory, and/or CDs) having program instructions executing on a computer, hardware, firmware, or a combination thereof. Moreover, the embodiments or aspects thereof can be implemented in hardware, firmware, software, or a combination thereof. In the foregoing description, for example, in certain situations, terms such as “engine,” “component” and “logic” are representative of hardware, firmware and/or software that is configured to perform one or more functions. As hardware, engine (or component/logic) may include circuitry having data processing or storage functionality. Examples of such circuitry may include, but is not limited or restricted to a microprocessor, one or more processor cores, a programmable gate array, a microcontroller, an application specific integrated circuit, semiconductor memory, or combinatorial logic. Accordingly this description is to be taken only by way of example and not to otherwise limit the scope of the embodiments herein. Therefore, it is the object of the appended claims to cover all such variations and modifications as come within the true spirit and scope of the embodiments herein.

Claims
  • 1. A method comprising: receiving an object at an endpoint on a network,determining, by a virtual machine monitor, at least whether the object is suspicious as including possible malware configured to attempt a modification of one or more kernel resources;instantiating, by the virtual machine monitor, a virtual machine as a container including an operating system process executing contents of the object, the operating system process to access one or more kernel resources;monitoring one or more operations of the operating system process included in the virtual machine as the operating system process accesses the one or more kernel resources of the endpoint; andinjecting code into a portion of memory associated with an address space of the operating system process during instrumentation of the virtual machine, the injected code being configured to remediate the modification of the one or more kernel resources accessed by the operating system process by restoring an original state of the one or more kernel resources without terminating the operating system process.
  • 2. The method of claim 1 wherein the injected code executes in the portion of the memory associated with the address space of the operating system process to effect the remediation of the one or more kernel resources.
  • 3. The method of claim 1 wherein the injecting of the code comprises: overwriting the object in the portion of the memory, and wherein the one or more kernel resources include locations in the portions of the memory storing the object.
  • 4. The method of claim 1 further comprising: capturing the original state of the one or more kernel resources prior to the operating system process accessing the one or more kernel resources; andexecuting the injected code to restore the modification of the one or more kernel resources to the original state.
  • 5. The method of claim 1 wherein a message having the injected code is received via the network at the endpoint, the message instructing the endpoint to restore the one or more kernel resources.
  • 6. The method of claim 1 wherein the modification to the one or more kernel resources is prevented by the injected code, thereby thwarting the attempted modification of the one or more kernel resources by the object.
  • 7. The method of claim 1 wherein the operating system process includes instructions for a version of an application having known malware in the object, the application stored in a file unpatched to prevent the modification of the one or more kernel resources.
  • 8. The method of claim 1 wherein a virtual machine monitor injects the code into the operating system process in response to a capability violation of a protection domain associated with the operating system process.
  • 9. The method of claim 1 wherein an original flow of execution of the operating system process is restored without altering the logic of the software instructions of the operating system process.
  • 10. The method of claim 1 wherein the instantiating of the virtual machine as the container comprises creating an instance from another virtual machine that is substantially similar to the VM, but includes different instrumentation logic.
  • 11. The method of claim 10 wherein the injecting of the code comprises: overwriting the object in the portion of memory, and wherein the one or more kernel resources include locations in the portions of the memory storing the object.
  • 12. The method of claim 1, wherein the determining that the operating system process is suspicious includes conducting a static analysis on the object, the static analysis includes one or more non-behavioral analyses of the object in order to detect, without execution of the object, anomalous characteristics associated with the object.
  • 13. A method to remediate malware, included as part of an object, that is infecting an endpoint, the method comprising: determining, by a virtual machine monitor, at least whether the object is suspicious as possibly including malware configured to attempt a modification of one or more kernel resources;instantiating, by the virtual machine monitor, a virtual machine to process an operating system process configured to execute contents of an object that include possible malware, the operating system process having instructions for a version of an application vulnerable to the malware;monitoring one or more operations of the operating system process included in the virtual machine as the operating system process accesses one or more kernel resources; andinjecting code into a portion of memory associated with an address space of the operating system process during instrumentation of the virtual machine, the injected code being configured to remediate the modification of at least one of the one or more kernel resources accessed by the operating system process by at least restoring an original state of the at least one of the one or more kernel resources without terminating the operating system process.
  • 14. The method of claim 13 wherein the injected code executes in the portion of the memory associated with the address space of the operating system process to effect the remediation of the at least one of the one or more kernel resources.
  • 15. The method of claim 13 further comprising: capturing the original state of the one or more kernel resources prior to the operating system process accessing the one or more kernel resources; andexecuting the injected code to restore the modification of the at least one of the one or more kernel resources to the original state.
  • 16. The method of claim 13 wherein a message having the injected code is received via a network at the endpoint, the message instructing the endpoint to restore the modification of the at least one kernel resource of the one or more kernel resources.
  • 17. The method of claim 13 wherein the modification to the at least one of the one or more kernel resources is prevented by the injected code, thereby thwarting the modification of the at least one of the one or more kernel resources by the object.
  • 18. The method of claim 13 wherein the operating system process includes instructions for the version of the application vulnerable to the known malware, the application being stored in a file unpatched from preventing the attempted modification of the one or more kernel resources.
  • 19. The method of claim 13 wherein the virtual machine monitor injects the code into the operating system process in response to a capability violation of a protection domain associated with the operating system process.
  • 20. The method of claim 13 wherein an original flow of execution of the operating system process is restored without terminating the operating system process.
  • 21. The method of claim 13, wherein the determining that the operating system process is suspicious includes conducting a static analysis on the object, the static analysis includes one or more non-behavioral analyses of the object in order to detect, without execution of the object, anomalous characteristics associated with the object.
  • 22. A system comprising: a network interface connected to a network;a memory coupled to the network interface and configured to store an object, a module, a virtual machine monitor and a virtual machine; anda central processing unit (CPU) coupled to the memory and adapted to execute the module, virtual machine monitor and virtual machine, wherein the module and virtual machine monitor are configured to: determine, by the virtual machine monitor, at least whether the object is suspicious as including possible malware configured to attempt a modification of one or more kernel resources,instantiate, by the virtual machine monitor, the virtual machine as a container to include an operating system process executing contents of the object, the operating system process to access one or more kernel resources,monitor one or more operations of the operating system process included in the virtual machine as the operating system process accesses one or more kernel resources, andinject code into a portion of the memory associated with an address space of the operating system process during instrumentation of the virtual machine, the injected code being configured to remediate the modification of the one or more kernel resources accessed by the operating system process by restoring an original state of the one or more kernel resources without terminating the operating system process.
  • 23. The system of claim 22 wherein the injected code executes in the portion of the memory associated with the address space of the operating system process to effect the remediation of the one or more kernel resources.
  • 24. The system of claim 22 wherein the injected code overwrites the object in the portion of the memory, and wherein the one or more kernel resources include locations in the portion of the memory storing the object.
  • 25. The system of claim 22 wherein the module and the virtual machine monitor are further configured to: capture the original state of the one or more kernel resources prior to the operating system process accessing the one or more kernel resources; andexecute the injected code to restore the modification of the one or more kernel resources to the original state.
  • 26. The system of claim 22 wherein a message having the injected code is received via the network at the system from a cloud service, the message instructing the system to restore the one or more kernel resources.
  • 27. The system of claim 22 wherein the modification to the one or more kernel resources is prevented by the injected code, thereby thwarting the modification of the one or more kernel resources by the object.
  • 28. The system of claim 22 wherein the operating system process includes instructions for a version of an application having known malware in the object, the application stored in a file unpatched to prevent attempted modification of the one or more kernel resources by the malware.
  • 29. The system of claim 22 wherein the virtual machine monitor injects the code into the operating system process in response to a capability violation of a protection domain associated with the operating system process.
  • 30. The system of claim 22 wherein an original flow of execution of the operating system process is restored without altering the logic of the software instructions of the operating system process.
  • 31. The system of claim 26 wherein the message includes instructions relative to a beginning of execution of the operating process to inject the code.
  • 32. The system of claim 22, wherein the CPU determining that the operating system process is suspicious by at least conducting a static analysis on the object, the static analysis includes one or more non-behavioral analyses of the object in order to detect, without execution of the object, anomalous characteristics associated with the object.
RELATED APPLICATION

The present application claims priority from commonly owned Provisional Patent Application No. 62/141,099, entitled CODE INJECTION TECHNIQUE FOR REMEDIATION AT AN ENDPOINT OF A NETWORK, filed on Mar. 31, 2015, the contents of which are incorporated herein by reference.

US Referenced Citations (756)
Number Name Date Kind
4292580 Ott et al. Sep 1981 A
5175732 Hendel et al. Dec 1992 A
5319776 Hile et al. Jun 1994 A
5440723 Arnold et al. Aug 1995 A
5490249 Miller Feb 1996 A
5657473 Killean et al. Aug 1997 A
5802277 Cowlard Sep 1998 A
5842002 Schnurer et al. Nov 1998 A
5960170 Chen et al. Sep 1999 A
5978917 Chi Nov 1999 A
5983348 Ji Nov 1999 A
6088803 Tso et al. Jul 2000 A
6092194 Touboul Jul 2000 A
6094677 Capek et al. Jul 2000 A
6108799 Boulay et al. Aug 2000 A
6154844 Touboul et al. Nov 2000 A
6269330 Cidon et al. Jul 2001 B1
6272641 Ji Aug 2001 B1
6279113 Vaidya Aug 2001 B1
6298445 Shostack et al. Oct 2001 B1
6357008 Nachenberg Mar 2002 B1
6424627 Sorhaug et al. Jul 2002 B1
6442696 Wray et al. Aug 2002 B1
6484315 Ziese Nov 2002 B1
6487666 Shanklin et al. Nov 2002 B1
6493756 O'Brien et al. Dec 2002 B1
6550012 Villa et al. Apr 2003 B1
6775657 Baker Aug 2004 B1
6831893 Ben Nun et al. Dec 2004 B1
6832367 Choi et al. Dec 2004 B1
6895550 Kanchirayappa et al. May 2005 B2
6898632 Gordy et al. May 2005 B2
6907396 Muttik et al. Jun 2005 B1
6941348 Petry et al. Sep 2005 B2
6971097 Wallman Nov 2005 B1
6981279 Arnold et al. Dec 2005 B1
7007107 Ivchenko et al. Feb 2006 B1
7028179 Anderson et al. Apr 2006 B2
7043757 Hoefelmeyer et al. May 2006 B2
7058822 Edery et al. Jun 2006 B2
7069316 Gryaznov Jun 2006 B1
7080407 Zhao et al. Jul 2006 B1
7080408 Pak et al. Jul 2006 B1
7093002 Wolff et al. Aug 2006 B2
7093239 van der Made Aug 2006 B1
7096498 Judge Aug 2006 B2
7100201 Izatt Aug 2006 B2
7107617 Hursey et al. Sep 2006 B2
7159149 Spiegel et al. Jan 2007 B2
7213260 Judge May 2007 B2
7231667 Jordan Jun 2007 B2
7240364 Branscomb et al. Jul 2007 B1
7240368 Roesch et al. Jul 2007 B1
7243371 Kasper et al. Jul 2007 B1
7249175 Donaldson Jul 2007 B1
7287278 Liang Oct 2007 B2
7308716 Danford et al. Dec 2007 B2
7328453 Merkle, Jr. et al. Feb 2008 B2
7346486 Ivancic et al. Mar 2008 B2
7356736 Natvig Apr 2008 B2
7386888 Liang et al. Jun 2008 B2
7392542 Bucher Jun 2008 B2
7418729 Szor Aug 2008 B2
7428300 Drew et al. Sep 2008 B1
7441272 Durham et al. Oct 2008 B2
7448084 Apap et al. Nov 2008 B1
7458098 Judge et al. Nov 2008 B2
7464404 Carpenter et al. Dec 2008 B2
7464407 Nakae et al. Dec 2008 B2
7467408 O'Toole, Jr. Dec 2008 B1
7478428 Thomlinson Jan 2009 B1
7480773 Reed Jan 2009 B1
7487543 Arnold et al. Feb 2009 B2
7496960 Chen et al. Feb 2009 B1
7496961 Zimmer et al. Feb 2009 B2
7519990 Xie Apr 2009 B1
7523493 Liang et al. Apr 2009 B2
7530104 Thrower et al. May 2009 B1
7540025 Tzadikario May 2009 B2
7546638 Anderson et al. Jun 2009 B2
7565550 Liang et al. Jul 2009 B2
7568233 Szor et al. Jul 2009 B1
7584455 Ball Sep 2009 B2
7603715 Costa et al. Oct 2009 B2
7607171 Marsden et al. Oct 2009 B1
7639714 Stolfo et al. Dec 2009 B2
7644441 Schmid et al. Jan 2010 B2
7657419 van der Made Feb 2010 B2
7676841 Sobchuk et al. Mar 2010 B2
7698548 Shelest et al. Apr 2010 B2
7707633 Danford et al. Apr 2010 B2
7712136 Sprosts et al. May 2010 B2
7730011 Deninger et al. Jun 2010 B1
7739740 Nachenberg et al. Jun 2010 B1
7779463 Stolfo et al. Aug 2010 B2
7784097 Stolfo et al. Aug 2010 B1
7832008 Kraemer Nov 2010 B1
7836502 Zhao et al. Nov 2010 B1
7849506 Dansey et al. Dec 2010 B1
7854007 Sprosts et al. Dec 2010 B2
7869073 Oshima Jan 2011 B2
7877803 Enstone et al. Jan 2011 B2
7904959 Sidiroglou et al. Mar 2011 B2
7908660 Bahl Mar 2011 B2
7930738 Petersen Apr 2011 B1
7937387 Frazier et al. May 2011 B2
7937761 Bennett May 2011 B1
7949849 Lowe et al. May 2011 B2
7996556 Raghavan et al. Aug 2011 B2
7996836 McCorkendale et al. Aug 2011 B1
7996904 Chiueh et al. Aug 2011 B1
7996905 Arnold et al. Aug 2011 B2
8006305 Aziz Aug 2011 B2
8010667 Zhang et al. Aug 2011 B2
8020206 Hubbard et al. Sep 2011 B2
8028338 Schneider et al. Sep 2011 B1
8042184 Batenin Oct 2011 B1
8045094 Teragawa Oct 2011 B2
8045458 Alperovitch et al. Oct 2011 B2
8069484 McMillan et al. Nov 2011 B2
8087086 Lai et al. Dec 2011 B1
8171553 Aziz et al. May 2012 B2
8176049 Deninger et al. May 2012 B2
8176480 Spertus May 2012 B1
8201246 Wu et al. Jun 2012 B1
8204984 Aziz et al. Jun 2012 B1
8214905 Doukhvalov et al. Jul 2012 B1
8220055 Kennedy Jul 2012 B1
8225288 Miller et al. Jul 2012 B2
8225317 Chiueh Jul 2012 B1
8225373 Kraemer Jul 2012 B2
8233882 Rogel Jul 2012 B2
8234640 Fitzgerald et al. Jul 2012 B1
8234709 Viljoen et al. Jul 2012 B2
8239944 Nachenberg et al. Aug 2012 B1
8239947 Glick Aug 2012 B1
8260914 Ranjan Sep 2012 B1
8266091 Gubin et al. Sep 2012 B1
8271978 Bennett et al. Sep 2012 B2
8286251 Eker et al. Oct 2012 B2
8291499 Aziz et al. Oct 2012 B2
8307435 Mann et al. Nov 2012 B1
8307443 Wang et al. Nov 2012 B2
8312545 Tuvell et al. Nov 2012 B2
8321936 Green et al. Nov 2012 B1
8321941 Tuvell et al. Nov 2012 B2
8332571 Edwards, Sr. Dec 2012 B1
8365286 Poston Jan 2013 B2
8365297 Parshin et al. Jan 2013 B1
8370938 Daswani et al. Feb 2013 B1
8370939 Zaitsev et al. Feb 2013 B2
8375369 Mensch et al. Feb 2013 B2
8375444 Aziz et al. Feb 2013 B2
8381299 Stolfo et al. Feb 2013 B2
8402529 Green et al. Mar 2013 B1
8464340 Ahn et al. Jun 2013 B2
8479174 Chiriac Jul 2013 B2
8479276 Vaystikh et al. Jul 2013 B1
8479286 Dalcher et al. Jul 2013 B2
8479291 Bodke Jul 2013 B1
8479292 Li et al. Jul 2013 B1
8510827 Leake et al. Aug 2013 B1
8510828 Guo et al. Aug 2013 B1
8510842 Amit et al. Aug 2013 B2
8516478 Edwards et al. Aug 2013 B1
8516590 Ranadive et al. Aug 2013 B1
8516593 Aziz Aug 2013 B2
8522348 Chen et al. Aug 2013 B2
8528086 Aziz Sep 2013 B1
8533824 Hutton et al. Sep 2013 B2
8539582 Aziz et al. Sep 2013 B1
8549638 Aziz Oct 2013 B2
8555391 Demir et al. Oct 2013 B1
8561177 Aziz et al. Oct 2013 B1
8566476 Shifter et al. Oct 2013 B2
8566946 Aziz et al. Oct 2013 B1
8584094 Dadhia et al. Nov 2013 B2
8584234 Sobel et al. Nov 2013 B1
8584239 Aziz et al. Nov 2013 B2
8595834 Xie et al. Nov 2013 B2
8612995 Yun Dec 2013 B1
8627476 Satish et al. Jan 2014 B1
8635696 Aziz Jan 2014 B1
8682054 Kue et al. Mar 2014 B2
8682812 Ranjan Mar 2014 B1
8689333 Aziz Apr 2014 B2
8695060 Wade et al. Apr 2014 B2
8695096 Zhang Apr 2014 B1
8713631 Pavlyushchik Apr 2014 B1
8713681 Silberman et al. Apr 2014 B2
8726392 McCorkendale et al. May 2014 B1
8739280 Chess et al. May 2014 B2
8775715 Tsirkin et al. Jul 2014 B2
8776229 Aziz Jul 2014 B1
8782792 Bodke Jul 2014 B1
8789172 Stolfo et al. Jul 2014 B2
8789178 Kejriwal et al. Jul 2014 B2
8793278 Frazier et al. Jul 2014 B2
8793787 Ismael et al. Jul 2014 B2
8805947 Kuzkin et al. Aug 2014 B1
8806647 Daswani et al. Aug 2014 B1
8832352 Tsirkin et al. Sep 2014 B2
8832829 Manni et al. Sep 2014 B2
8839245 Khajuria et al. Sep 2014 B1
8850570 Ramzan Sep 2014 B1
8850571 Staniford et al. Sep 2014 B2
8881234 Narasimhan et al. Nov 2014 B2
8881271 Butler, II Nov 2014 B2
8881282 Aziz et al. Nov 2014 B1
8898788 Aziz et al. Nov 2014 B1
8910155 Sobel Dec 2014 B1
8935779 Manni et al. Jan 2015 B2
8949257 Shifter et al. Feb 2015 B2
8984638 Aziz et al. Mar 2015 B1
8990939 Staniford et al. Mar 2015 B2
8990944 Singh et al. Mar 2015 B1
8997219 Staniford et al. Mar 2015 B2
9009822 Ismael et al. Apr 2015 B1
9009823 Ismael et al. Apr 2015 B1
9027135 Aziz May 2015 B1
9071638 Aziz et al. Jun 2015 B1
9104867 Thioux et al. Aug 2015 B1
9106630 Frazier et al. Aug 2015 B2
9106694 Aziz et al. Aug 2015 B2
9118715 Staniford et al. Aug 2015 B2
9159035 Ismael et al. Oct 2015 B1
9171160 Vincent et al. Oct 2015 B2
9176843 Ismael et al. Nov 2015 B1
9189627 Islam Nov 2015 B1
9195829 Goradia et al. Nov 2015 B1
9197664 Aziz et al. Nov 2015 B1
9223962 Kashyap Dec 2015 B1
9223972 Vincent et al. Dec 2015 B1
9225740 Ismael et al. Dec 2015 B1
9241010 Bennett et al. Jan 2016 B1
9251343 Vincent et al. Feb 2016 B1
9262635 Paithane et al. Feb 2016 B2
9268936 Butler Feb 2016 B2
9275229 LeMasters Mar 2016 B2
9282109 Aziz et al. Mar 2016 B1
9292686 Ismael et al. Mar 2016 B2
9294501 Mesdaq et al. Mar 2016 B2
9300686 Pidathala et al. Mar 2016 B2
9306960 Aziz Apr 2016 B1
9306974 Aziz et al. Apr 2016 B1
9311479 Manni et al. Apr 2016 B1
9355247 Thioux et al. May 2016 B1
9356944 Aziz May 2016 B1
9363280 Rivlin et al. Jun 2016 B1
9367681 Ismael et al. Jun 2016 B1
9398028 Karandikar et al. Jul 2016 B1
9411979 Agarwal Aug 2016 B2
9413781 Cunningham et al. Aug 2016 B2
9426071 Caldejon et al. Aug 2016 B1
9430646 Mushtaq et al. Aug 2016 B1
9432389 Khalid et al. Aug 2016 B1
9438613 Paithane et al. Sep 2016 B1
9438622 Staniford et al. Sep 2016 B1
9438623 Thioux et al. Sep 2016 B1
9459901 Jung et al. Oct 2016 B2
9467460 Otvagin et al. Oct 2016 B1
9483644 Paithane et al. Nov 2016 B1
9489516 Lu Nov 2016 B1
9495180 Ismael Nov 2016 B2
9497213 Thompson et al. Nov 2016 B2
9507935 Ismael et al. Nov 2016 B2
9516057 Aziz Dec 2016 B2
9519782 Aziz et al. Dec 2016 B2
9536091 Paithane et al. Jan 2017 B2
9537972 Edwards et al. Jan 2017 B1
9560059 Islam Jan 2017 B1
9565202 Kindlund et al. Feb 2017 B1
9591015 Amin et al. Mar 2017 B1
9591020 Aziz Mar 2017 B1
9594904 Jain et al. Mar 2017 B1
9594905 Ismael et al. Mar 2017 B1
9594912 Thioux et al. Mar 2017 B1
9609007 Rivlin et al. Mar 2017 B1
9626509 Khalid et al. Apr 2017 B1
9628498 Aziz et al. Apr 2017 B1
9628507 Haq et al. Apr 2017 B2
9633134 Ross Apr 2017 B2
9635039 Islam et al. Apr 2017 B1
9641546 Manni et al. May 2017 B1
9654485 Neumann May 2017 B1
9661009 Karandikar et al. May 2017 B1
9661018 Aziz May 2017 B1
9674298 Edwards et al. Jun 2017 B1
9680862 Ismael et al. Jun 2017 B2
9690606 Ha et al. Jun 2017 B1
9690933 Singh et al. Jun 2017 B1
9690935 Shifter et al. Jun 2017 B2
9690936 Malik et al. Jun 2017 B1
9736179 Ismael Aug 2017 B2
9740857 Ismael et al. Aug 2017 B2
9747446 Pidathala et al. Aug 2017 B1
9756074 Aziz et al. Sep 2017 B2
9773112 Rathor et al. Sep 2017 B1
9781144 Otvagin et al. Oct 2017 B1
9787700 Amin et al. Oct 2017 B1
9787706 Otvagin et al. Oct 2017 B1
9792196 Ismael et al. Oct 2017 B1
9824209 Ismael et al. Nov 2017 B1
9824211 Wilson Nov 2017 B2
9824216 Khalid et al. Nov 2017 B1
9825976 Gomez et al. Nov 2017 B1
9825989 Mehra et al. Nov 2017 B1
9838408 Karandikar et al. Dec 2017 B1
9838411 Aziz Dec 2017 B1
9838416 Aziz Dec 2017 B1
9838417 Khalid et al. Dec 2017 B1
9846776 Paithane et al. Dec 2017 B1
9876701 Caldejon et al. Jan 2018 B1
9888016 Amin et al. Feb 2018 B1
9888019 Pidathala et al. Feb 2018 B1
9910988 Vincent et al. Mar 2018 B1
9912644 Cunningham Mar 2018 B2
9912681 Ismael et al. Mar 2018 B1
9912684 Aziz et al. Mar 2018 B1
9912691 Mesdaq et al. Mar 2018 B2
9912698 Thioux et al. Mar 2018 B1
9916440 Paithane et al. Mar 2018 B1
9921978 Chan et al. Mar 2018 B1
9934376 Ismael Apr 2018 B1
9934381 Kindlund et al. Apr 2018 B1
9946568 Ismael et al. Apr 2018 B1
9954890 Staniford et al. Apr 2018 B1
9973531 Thioux May 2018 B1
10002252 Ismael et al. Jun 2018 B2
10019338 Goradia et al. Jul 2018 B1
10019573 Silberman et al. Jul 2018 B2
10025691 Ismael et al. Jul 2018 B1
10025927 Khalid et al. Jul 2018 B1
10027689 Rathor et al. Jul 2018 B1
10027690 Aziz et al. Jul 2018 B2
10027696 Rivlin et al. Jul 2018 B1
10033747 Paithane et al. Jul 2018 B1
10033748 Cunningham et al. Jul 2018 B1
10033753 Islam et al. Jul 2018 B1
10033759 Kabra et al. Jul 2018 B1
10050998 Singh Aug 2018 B1
10068091 Aziz et al. Sep 2018 B1
10075455 Zafar et al. Sep 2018 B2
10083302 Paithane et al. Sep 2018 B1
10084813 Eyada Sep 2018 B2
10089461 Ha et al. Oct 2018 B1
10097573 Aziz Oct 2018 B1
10104102 Neumann Oct 2018 B1
10108446 Steinberg et al. Oct 2018 B1
10121000 Rivlin et al. Nov 2018 B1
10122746 Manni et al. Nov 2018 B1
10133863 Bu et al. Nov 2018 B2
10133866 Kumar et al. Nov 2018 B1
10146810 Shiffer et al. Dec 2018 B2
10148693 Singh et al. Dec 2018 B2
10165000 Aziz et al. Dec 2018 B1
10169585 Pilipenko et al. Jan 2019 B1
10176321 Abbasi et al. Jan 2019 B2
10181029 Ismael et al. Jan 2019 B1
10191861 Steinberg et al. Jan 2019 B1
10192052 Singh et al. Jan 2019 B1
10198574 Thioux et al. Feb 2019 B1
10200384 Mushtaq et al. Feb 2019 B1
10210329 Malik et al. Feb 2019 B1
10216927 Steinberg Feb 2019 B1
10218740 Mesdaq et al. Feb 2019 B1
10242185 Goradia Mar 2019 B1
20010005889 Albrecht Jun 2001 A1
20010047326 Broadbent et al. Nov 2001 A1
20020018903 Kokubo et al. Feb 2002 A1
20020038430 Edwards et al. Mar 2002 A1
20020091819 Melchione et al. Jul 2002 A1
20020095607 Lin-Hendel Jul 2002 A1
20020116627 Tarbotton et al. Aug 2002 A1
20020144156 Copeland Oct 2002 A1
20020162015 Tang Oct 2002 A1
20020166063 Lachman et al. Nov 2002 A1
20020169952 DiSanto et al. Nov 2002 A1
20020184528 Shevenell et al. Dec 2002 A1
20020188887 Largman et al. Dec 2002 A1
20020194490 Halperin et al. Dec 2002 A1
20030021728 Sharpe et al. Jan 2003 A1
20030074578 Ford et al. Apr 2003 A1
20030084318 Schertz May 2003 A1
20030101381 Mateev et al. May 2003 A1
20030115483 Liang Jun 2003 A1
20030120856 Neiger et al. Jun 2003 A1
20030188190 Aaron et al. Oct 2003 A1
20030191957 Hypponen et al. Oct 2003 A1
20030200460 Morota et al. Oct 2003 A1
20030212902 van der Made Nov 2003 A1
20030229801 Kouznetsov et al. Dec 2003 A1
20030237000 Denton et al. Dec 2003 A1
20040003323 Bennett et al. Jan 2004 A1
20040006473 Mills et al. Jan 2004 A1
20040015712 Szor Jan 2004 A1
20040019832 Arnold et al. Jan 2004 A1
20040047356 Bauer Mar 2004 A1
20040083408 Spiegel et al. Apr 2004 A1
20040088581 Brawn et al. May 2004 A1
20040093513 Cantrell et al. May 2004 A1
20040111531 Staniford et al. Jun 2004 A1
20040117478 Triulzi et al. Jun 2004 A1
20040117624 Brandt et al. Jun 2004 A1
20040128355 Chao et al. Jul 2004 A1
20040165588 Pandya Aug 2004 A1
20040236963 Danford et al. Nov 2004 A1
20040243349 Greifeneder et al. Dec 2004 A1
20040249911 Alkhatib et al. Dec 2004 A1
20040255161 Cavanaugh Dec 2004 A1
20040268147 Wiederin et al. Dec 2004 A1
20050005159 Oliphant Jan 2005 A1
20050021740 Bar et al. Jan 2005 A1
20050033960 Vialen et al. Feb 2005 A1
20050033989 Poletto et al. Feb 2005 A1
20050050148 Mohammadioun et al. Mar 2005 A1
20050086523 Zimmer et al. Apr 2005 A1
20050091513 Mitomo et al. Apr 2005 A1
20050091533 Omote et al. Apr 2005 A1
20050091652 Ross et al. Apr 2005 A1
20050108562 Khazan et al. May 2005 A1
20050114663 Cornell et al. May 2005 A1
20050125195 Brendel Jun 2005 A1
20050149726 Joshi et al. Jul 2005 A1
20050157662 Bingham et al. Jul 2005 A1
20050183143 Anderholm et al. Aug 2005 A1
20050201297 Peikari Sep 2005 A1
20050210533 Copeland et al. Sep 2005 A1
20050216759 Rothman et al. Sep 2005 A1
20050229250 Ring Oct 2005 A1
20050238005 Chen et al. Oct 2005 A1
20050240781 Gassoway Oct 2005 A1
20050262562 Gassoway Nov 2005 A1
20050265331 Stolfo Dec 2005 A1
20050283839 Cowburn Dec 2005 A1
20060010495 Cohen et al. Jan 2006 A1
20060015416 Hoffman et al. Jan 2006 A1
20060015715 Anderson Jan 2006 A1
20060015747 Van de Ven Jan 2006 A1
20060021029 Brickell et al. Jan 2006 A1
20060021054 Costa et al. Jan 2006 A1
20060031476 Mathes et al. Feb 2006 A1
20060047665 Neil Mar 2006 A1
20060070130 Costea et al. Mar 2006 A1
20060075496 Carpenter et al. Apr 2006 A1
20060095968 Portolani et al. May 2006 A1
20060101516 Sudaharan et al. May 2006 A1
20060101517 Banzhof et al. May 2006 A1
20060117385 Mester et al. Jun 2006 A1
20060123477 Raghavan et al. Jun 2006 A1
20060130060 Anderson et al. Jun 2006 A1
20060143709 Brooks et al. Jun 2006 A1
20060150249 Gassen et al. Jul 2006 A1
20060161983 Cothrell et al. Jul 2006 A1
20060161987 Levy-Yurista Jul 2006 A1
20060161989 Reshef et al. Jul 2006 A1
20060164199 Glide et al. Jul 2006 A1
20060173992 Weber et al. Aug 2006 A1
20060179147 Tran et al. Aug 2006 A1
20060184632 Marino et al. Aug 2006 A1
20060191010 Benjamin Aug 2006 A1
20060221956 Narayan et al. Oct 2006 A1
20060236393 Kramer et al. Oct 2006 A1
20060242709 Seinfeld et al. Oct 2006 A1
20060248519 Jaeger et al. Nov 2006 A1
20060248582 Panjwani et al. Nov 2006 A1
20060251104 Koga Nov 2006 A1
20060288417 Bookbinder et al. Dec 2006 A1
20070006288 Mayfield et al. Jan 2007 A1
20070006313 Porras et al. Jan 2007 A1
20070011174 Takaragi et al. Jan 2007 A1
20070016951 Piccard et al. Jan 2007 A1
20070019286 Kikuchi Jan 2007 A1
20070033645 Jones Feb 2007 A1
20070038943 FitzGerald et al. Feb 2007 A1
20070064689 Shin et al. Mar 2007 A1
20070074169 Chess et al. Mar 2007 A1
20070094730 Bhikkaji et al. Apr 2007 A1
20070101435 Konanka et al. May 2007 A1
20070128855 Cho et al. Jun 2007 A1
20070142030 Sinha et al. Jun 2007 A1
20070143827 Nicodemus et al. Jun 2007 A1
20070156895 Vuong Jul 2007 A1
20070157180 Tillmann et al. Jul 2007 A1
20070157306 Elrod et al. Jul 2007 A1
20070168988 Eisner et al. Jul 2007 A1
20070171824 Ruello et al. Jul 2007 A1
20070174915 Gribble et al. Jul 2007 A1
20070192500 Lum Aug 2007 A1
20070192858 Lum Aug 2007 A1
20070198275 Malden et al. Aug 2007 A1
20070208822 Wang et al. Sep 2007 A1
20070220607 Sprosts et al. Sep 2007 A1
20070240218 Tuvell et al. Oct 2007 A1
20070240219 Tuvell et al. Oct 2007 A1
20070240220 Tuvell et al. Oct 2007 A1
20070240222 Tuvell et al. Oct 2007 A1
20070250930 Aziz et al. Oct 2007 A1
20070256132 Oliphant Nov 2007 A2
20070271446 Nakamura Nov 2007 A1
20080005782 Aziz Jan 2008 A1
20080018122 Zierler et al. Jan 2008 A1
20080028124 Tago Jan 2008 A1
20080028463 Dagon Jan 2008 A1
20080040710 Chiriac Feb 2008 A1
20080046781 Childs et al. Feb 2008 A1
20080066179 Liu Mar 2008 A1
20080072326 Danford et al. Mar 2008 A1
20080077793 Tan et al. Mar 2008 A1
20080080518 Hoeflin et al. Apr 2008 A1
20080086720 Lekel Apr 2008 A1
20080098476 Syversen Apr 2008 A1
20080120722 Sima et al. May 2008 A1
20080134178 Fitzgerald et al. Jun 2008 A1
20080134334 Kim et al. Jun 2008 A1
20080141376 Clausen et al. Jun 2008 A1
20080184016 Erlingsson Jul 2008 A1
20080184367 McMillan et al. Jul 2008 A1
20080184373 Traut et al. Jul 2008 A1
20080189787 Arnold et al. Aug 2008 A1
20080201778 Guo et al. Aug 2008 A1
20080209557 Herley et al. Aug 2008 A1
20080215742 Goldszmidt et al. Sep 2008 A1
20080222729 Chen et al. Sep 2008 A1
20080244206 Heo et al. Oct 2008 A1
20080263665 Ma et al. Oct 2008 A1
20080295172 Bohacek Nov 2008 A1
20080301810 Lehane et al. Dec 2008 A1
20080307524 Singh et al. Dec 2008 A1
20080313738 Enderby Dec 2008 A1
20080320594 Jiang Dec 2008 A1
20090003317 Kasralikar et al. Jan 2009 A1
20090007100 Field et al. Jan 2009 A1
20090013408 Schipka Jan 2009 A1
20090031423 Liu et al. Jan 2009 A1
20090036111 Danford et al. Feb 2009 A1
20090037835 Goldman Feb 2009 A1
20090044024 Oberheide et al. Feb 2009 A1
20090044274 Budko et al. Feb 2009 A1
20090064332 Porras et al. Mar 2009 A1
20090077666 Chen et al. Mar 2009 A1
20090083369 Marmor Mar 2009 A1
20090083855 Apap et al. Mar 2009 A1
20090089879 Wang et al. Apr 2009 A1
20090094697 Provos et al. Apr 2009 A1
20090113425 Ports et al. Apr 2009 A1
20090125976 Wassermann et al. May 2009 A1
20090126015 Monastyrsky et al. May 2009 A1
20090126016 Sobko et al. May 2009 A1
20090133125 Choi et al. May 2009 A1
20090144823 Lamastra et al. Jun 2009 A1
20090158430 Borders Jun 2009 A1
20090172815 Gu et al. Jul 2009 A1
20090187992 Poston Jul 2009 A1
20090193293 Stolfo et al. Jul 2009 A1
20090198651 Shifter et al. Aug 2009 A1
20090198670 Shifter et al. Aug 2009 A1
20090198689 Frazier et al. Aug 2009 A1
20090199274 Frazier et al. Aug 2009 A1
20090199296 Xie et al. Aug 2009 A1
20090228233 Anderson et al. Sep 2009 A1
20090241187 Troyansky Sep 2009 A1
20090241190 Todd et al. Sep 2009 A1
20090265692 Godefroid et al. Oct 2009 A1
20090271867 Zhang Oct 2009 A1
20090300415 Zhang et al. Dec 2009 A1
20090300761 Park et al. Dec 2009 A1
20090328185 Berg et al. Dec 2009 A1
20090328221 Blumfield et al. Dec 2009 A1
20100005146 Drako et al. Jan 2010 A1
20100011205 McKenna Jan 2010 A1
20100017546 Poo et al. Jan 2010 A1
20100023810 Stolfo et al. Jan 2010 A1
20100030996 Butler, II Feb 2010 A1
20100031353 Thomas et al. Feb 2010 A1
20100037314 Perdisci et al. Feb 2010 A1
20100043073 Kuwamura Feb 2010 A1
20100054278 Stolfo et al. Mar 2010 A1
20100058474 Hicks Mar 2010 A1
20100064044 Nonoyama Mar 2010 A1
20100077481 Polyakov et al. Mar 2010 A1
20100083376 Pereira et al. Apr 2010 A1
20100107245 Jakubowski Apr 2010 A1
20100107252 Mertoguno Apr 2010 A1
20100115621 Staniford et al. May 2010 A1
20100132038 Zaitsev May 2010 A1
20100154056 Smith et al. Jun 2010 A1
20100180344 Malyshev et al. Jul 2010 A1
20100192223 Ismael et al. Jul 2010 A1
20100220863 Dupaquis et al. Sep 2010 A1
20100235831 Dittmer Sep 2010 A1
20100251104 Massand Sep 2010 A1
20100281102 Chinta et al. Nov 2010 A1
20100281541 Stolfo et al. Nov 2010 A1
20100281542 Stolfo et al. Nov 2010 A1
20100287260 Peterson et al. Nov 2010 A1
20100299754 Amit et al. Nov 2010 A1
20100306173 Frank Dec 2010 A1
20110004737 Greenebaum Jan 2011 A1
20110004935 Moffie et al. Jan 2011 A1
20110025504 Lyon et al. Feb 2011 A1
20110041179 St Hlberg Feb 2011 A1
20110047542 Dang et al. Feb 2011 A1
20110047594 Mahaffey et al. Feb 2011 A1
20110047620 Mahaffey et al. Feb 2011 A1
20110055907 Narasimhan et al. Mar 2011 A1
20110078794 Manni et al. Mar 2011 A1
20110093951 Aziz Apr 2011 A1
20110099620 Stavrou et al. Apr 2011 A1
20110099633 Aziz Apr 2011 A1
20110099635 Silberman et al. Apr 2011 A1
20110113231 Kaminsky May 2011 A1
20110145918 Jung et al. Jun 2011 A1
20110145920 Mahaffey et al. Jun 2011 A1
20110145934 Abramovici et al. Jun 2011 A1
20110153909 Dong Jun 2011 A1
20110167493 Song et al. Jul 2011 A1
20110167494 Bowen et al. Jul 2011 A1
20110173213 Frazier et al. Jul 2011 A1
20110173460 Ito et al. Jul 2011 A1
20110219449 St. Neitzel et al. Sep 2011 A1
20110219450 McDougal et al. Sep 2011 A1
20110225624 Sawhney et al. Sep 2011 A1
20110225655 Niemela et al. Sep 2011 A1
20110247072 Staniford et al. Oct 2011 A1
20110265182 Peinado et al. Oct 2011 A1
20110289582 Kejriwal et al. Nov 2011 A1
20110296412 Banga et al. Dec 2011 A1
20110302587 Nishikawa et al. Dec 2011 A1
20110307954 Melnik et al. Dec 2011 A1
20110307955 Kaplan et al. Dec 2011 A1
20110307956 Yermakov et al. Dec 2011 A1
20110314546 Aziz et al. Dec 2011 A1
20120023593 Puder et al. Jan 2012 A1
20120047580 Smith et al. Feb 2012 A1
20120054869 Yen et al. Mar 2012 A1
20120066698 Yanoo Mar 2012 A1
20120079594 Jeong Mar 2012 A1
20120079596 Thomas Mar 2012 A1
20120084859 Radinsky et al. Apr 2012 A1
20120096553 Srivastava et al. Apr 2012 A1
20120110667 Zubrilin et al. May 2012 A1
20120117652 Manni et al. May 2012 A1
20120121154 Xue et al. May 2012 A1
20120124426 Maybee et al. May 2012 A1
20120174186 Aziz et al. Jul 2012 A1
20120174196 Bhogavilli et al. Jul 2012 A1
20120174218 McCoy et al. Jul 2012 A1
20120198279 Schroeder Aug 2012 A1
20120210423 Friedrichs et al. Aug 2012 A1
20120222121 Staniford et al. Aug 2012 A1
20120233612 Beckett Sep 2012 A1
20120254995 Sallam Oct 2012 A1
20120255002 Sallam Oct 2012 A1
20120255015 Sahita et al. Oct 2012 A1
20120255016 Sallam Oct 2012 A1
20120255017 Sallam Oct 2012 A1
20120255021 Sallam Oct 2012 A1
20120260342 Dube et al. Oct 2012 A1
20120266244 Green et al. Oct 2012 A1
20120278886 Luna Nov 2012 A1
20120297489 Dequevy Nov 2012 A1
20120311708 Agarwal et al. Dec 2012 A1
20120330801 McDougal et al. Dec 2012 A1
20120331553 Aziz et al. Dec 2012 A1
20130014259 Gribble et al. Jan 2013 A1
20130031374 Thom et al. Jan 2013 A1
20130036472 Aziz Feb 2013 A1
20130047257 Aziz Feb 2013 A1
20130055256 Banga et al. Feb 2013 A1
20130061012 Turner et al. Mar 2013 A1
20130074185 McDougal et al. Mar 2013 A1
20130086684 Mohler Apr 2013 A1
20130097699 Balupari et al. Apr 2013 A1
20130097706 Titonis et al. Apr 2013 A1
20130111587 Goel et al. May 2013 A1
20130117852 Stute May 2013 A1
20130117855 Kim et al. May 2013 A1
20130139264 Brinkley et al. May 2013 A1
20130145471 Richard et al. Jun 2013 A1
20130160125 Likhachev et al. Jun 2013 A1
20130160127 Jeong et al. Jun 2013 A1
20130160130 Mendelev et al. Jun 2013 A1
20130160131 Madou et al. Jun 2013 A1
20130167236 Sick Jun 2013 A1
20130191924 Tedesco et al. Jun 2013 A1
20130174214 Duncan Jul 2013 A1
20130185789 Hagiwara et al. Jul 2013 A1
20130185795 Winn et al. Jul 2013 A1
20130185798 Saunders et al. Jul 2013 A1
20130191915 Antonakakis et al. Jul 2013 A1
20130196649 Paddon et al. Aug 2013 A1
20130227691 Aziz et al. Aug 2013 A1
20130246370 Bartram et al. Sep 2013 A1
20130247186 LeMasters Sep 2013 A1
20130263260 Mahaffey et al. Oct 2013 A1
20130291109 Staniford et al. Oct 2013 A1
20130298243 Kumar et al. Nov 2013 A1
20130312099 Edwards Nov 2013 A1
20130318038 Shiffer et al. Nov 2013 A1
20130318073 Shiffer et al. Nov 2013 A1
20130325791 Shiffer et al. Dec 2013 A1
20130325792 Shiffer et al. Dec 2013 A1
20130325871 Shiffer et al. Dec 2013 A1
20130325872 Shiffer et al. Dec 2013 A1
20130333033 Khesin Dec 2013 A1
20130346966 Natu et al. Dec 2013 A1
20140032875 Butler Jan 2014 A1
20140053260 Gupta et al. Feb 2014 A1
20140053261 Gupta et al. Feb 2014 A1
20140130158 Wang et al. May 2014 A1
20140137180 Lukacs et al. May 2014 A1
20140169762 Ryu Jun 2014 A1
20140179360 Jackson et al. Jun 2014 A1
20140181131 Ross Jun 2014 A1
20140189687 Jung Jul 2014 A1
20140189866 Shifter et al. Jul 2014 A1
20140189882 Jung et al. Jul 2014 A1
20140237600 Silberman et al. Aug 2014 A1
20140280245 Wilson Sep 2014 A1
20140283037 Sikorski et al. Sep 2014 A1
20140283063 Thompson et al. Sep 2014 A1
20140328204 Klotsche et al. Nov 2014 A1
20140337836 Ismael Nov 2014 A1
20140344926 Cunningham et al. Nov 2014 A1
20140351935 Shao et al. Nov 2014 A1
20140380473 Bu et al. Dec 2014 A1
20140380474 Paithane et al. Dec 2014 A1
20150007312 Pidathala et al. Jan 2015 A1
20150096022 Vincent et al. Apr 2015 A1
20150096023 Mesdaq et al. Apr 2015 A1
20150096024 Haq et al. Apr 2015 A1
20150096025 Ismael Apr 2015 A1
20150180886 Staniford et al. Jun 2015 A1
20150186645 Aziz et al. Jul 2015 A1
20150199513 Ismael et al. Jul 2015 A1
20150199531 Ismael et al. Jul 2015 A1
20150199532 Ismael et al. Jul 2015 A1
20150220735 Paithane et al. Aug 2015 A1
20150372980 Eyada Dec 2015 A1
20160004869 Ismael Jan 2016 A1
20160006756 Ismael Jan 2016 A1
20160044000 Cunningham Feb 2016 A1
20160127393 Aziz et al. May 2016 A1
20160191547 Zafar et al. Jun 2016 A1
20160191550 Ismael et al. Jun 2016 A1
20160205115 Kulkarni Jul 2016 A1
20160261612 Mesdaq et al. Sep 2016 A1
20160285914 Singh et al. Sep 2016 A1
20160301703 Aziz Oct 2016 A1
20160335110 Paithane et al. Nov 2016 A1
20170083703 Abbasi et al. Mar 2017 A1
20180013770 Ismael Jan 2018 A1
20180048660 Paithane et al. Feb 2018 A1
20180121316 Ismael et al. May 2018 A1
20180288077 Siddiqui et al. Oct 2018 A1
Foreign Referenced Citations (16)
Number Date Country
2439806 Jan 2008 GB
2490431 Oct 2012 GB
0206928 Jan 2002 WO
0223805 Mar 2002 WO
2007117636 Oct 2007 WO
2008041950 Apr 2008 WO
2011084431 Jul 2011 WO
2011112348 Sep 2011 WO
2012075336 Jun 2012 WO
2012145066 Oct 2012 WO
WO2012135192 Oct 2012 WO
WO2012154664 Nov 2012 WO
WO-2012177464 Dec 2012 WO
2013067505 May 2013 WO
WO-2014004747 Jan 2014 WO
WO-2013091221 Jun 2015 WO
Non-Patent Literature Citations (83)
Entry
Amiri Sani, Ardalan, et al. “I/O paravirtualization at the device file boundary,” ACM SIGPLAN Notices 49.4 (2014), pp. 319-332.
“Bromium vSentry—Defeat the Unknown Attack,” Oct. 10, 2013, 11 pages.
Bromium Corp, “Live Attack Visualization and Analysis, What does a Malware attack look like?” http://www.bromium.com/sites/default/files/Bromium%20LAVA%20WP_2.pdf on Dec 1, 2013, 11 pages.
Chen, Peter M., and Brian D. Noble. “When virtual is better than real [operating system relocation to virtual machines].” Hot Topics in Operating Systems, 2001. Proceedings of the Eighth Workshop on. IEEE, 2001.
Gao, Debin, Michael K. Reiter, and Dawn Xiaodong Song. “On Gray-Box Program Tracking for Anomaly Detection.” USENIX security symposium. 2004.
Garfinkel, Tal, and Mendel Rosenblum. “A Virtual Machine Introspection Based Architecture for Intrusion Detection.” NDSS. 2003.
Heiser, Gernot, and Ben Leslie. “The OKL4 Microvisor: Convergence point of microkernels and hypervisors.” Proceedings of the first ACM asia-pacific workshop on Workshop on systems. ACM, 2010.
Hofmeyr, Steven A., Stephanie Forrest, and Anil Somayaji. “Intrusion detection using sequences of system calls.” Journal of computer security 6.3 (1998): 151-180.
Huang, Yih, et al. “Efficiently tracking application interactions using lightweight virtualization.” Proceedings of the 1st ACM workshop on Virtual machine security. ACM, 2008.
Iqbal; Asif, Nayeema Sadeque, and Rafika Ida Mutia. “An overview of microkernel; hypervisor and microvisor virtualization approaches for embedded systems.” Report, Department of Electrical and Information Technology, Lund University, Sweden 2110 (2009), 15 Pages.
Iqbal, et al.,—“An Overview of Microkernel, Hypervisor and Microvisor Virtualization Approaches for Embedded Systems,” Department of Electrical and Information Technology, Lund University, Sweden, Aug. 26, 2013, 15 pages.
Jiang, Xuxian, Xinyuan Wang, and Dongyan Xu. “Stealthy malware detection through vmm-based out-of-the-box semantic view reconstruction.” Proceedings of the 14th ACM conference on Computer and communications security. ACM, 2007.
Jones, Stephen T., Andrea C. Arpaci-Dusseau, and Remzi H. Arpaci-Dusseau. “Antfarm: Tracking Processes in a Virtual Machine Environment.” USENIX Annual Technical Conference, General Track. 2006.
Kapravelos, Alexandros, et al. “Revolver: An Automated Approach to the Detection of Evasive Web-based Malware.” USENIX Security Symposium. 2013.
King, Samuel. T., and Peter M. Chen, “SubVirt Implementing malware with virtual machines.” Security and Privacy, 2006 IEEE Symposium on. IEEE, 2006, 14 Pages.
Kosoresow, Andrew P., and Steven A. Hofmeyr. “Intrusion detection via system call traces.” IEEE software 14.5 (1997): 35-42.
Laureano, Marcos, Carlos Maziero, and Edgard Jamhour. “Intrusion detection in virtual machine environments.” Euromicro Conference, 2004. Proceedings. 30th. IEEE, 2004.
Levin, Thomas E., Cynthia E. Irvine, and Thuy D. Nguyen. Least privilege in separation kernels. Naval Postgraduate School Monterey CA Dept of Computer Science, 2006.
Nguyen, Anh M., et al. “Mavmm: Lightweight and purpose built vmm for malware analysis.” Computer Security Applications Conference, 2009. ACSAC'09. Annual. IEEE, 2009.
PCT Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration, International Searching Authority, International Application No. PCT/US2014/071847, dated Mar. 26, 2015, 16 pages.
PCT Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration, International Searching Authority, International Application No. PCT/US2014/071879, dated /Apr. 28, 2015, 12 pages.
PCT Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration, International Searching Authority, International Application No. PCT/US2014/071923, dated Mar. 26, 2015, 13 pages.
Steinberg, Udo, and Bernhard Kauer. “NOVA: a microhypervisor-based secure virtuaiization architecture.” Proceedings of the 5th European conference on Computer systems, ACM, 2010, 14 Pages.
Stumpf, Frederic, et al. “An approach to a trustworthy system architecture using virtualization.” Autonomic and trusted computing. Springer Berlin Heidelberg, 2007. 191-202.
Sun, et al., “SecureSwitch: BIOS-Assisted Isolation and Switch between Trusted and Untrusted Commodity OSes,” Center for Secure Information Systems, George Mason University, Feb. 26, 2013, 15 pages.
Wojtczuk, Rafal. “Subverting the Xen hypervisor.” Black Hat USA 2008 (2008), 9 Pages.
Yan, Lok Kwong, et al. “Transparent and Extensible Malware Analysis by Combining Hardware Virtualization and Software Emulation.” Internet Society, 2010. Downloaded from https://www.internetsociety.org/sites/default/files/05_1.pdf.
“Mining Specification of Malicious Behavior”—Jha et al, UCSB, Sep. 2007 https://www.cs.ucsb.edu/about.chris/research/doc/esec07.sub.--mining.pdf-.
“Network Security: NetDetector—Network Intrusion Forensic System (NIFS) Whitepaper”, (“NetDetector Whitepaper”), (2003).
“When Virtual is Better Than Real”, IEEEXplore Digital Library, available at, http://ieeexplore.ieee.org/xpl/articleDetails.isp?reload=true&amumbe- r=990073, (Dec. 7, 2013).
Abdullah, et al., Visualizing Network Data for Intrusion Detection, 2005 IEEE Workshop on Information Assurance and Security, pp. 100-108.
Adetoye, Adedayo , et al., “Network Intrusion Detection & Response System”, (“Adetoye”), (Sep. 2003).
Apostolopoulos, George; hassapis, Constantinos; “V-eM: A cluster of Virtual Machines for Robust, Detailed, and High-Performance Network Emulation”, 14th IEEE International Symposium on Modeling, Analysis, and Simulation of Computer and Telecommunication Systems, Sep. 11-14, 2006, pp. 117-126.
Aura, Tuomas, “Scanning electronic documents for personally identifiable information”, Proceedings of the 5th ACM workshop on Privacy in electronic society. ACM, 2006.
Baecher, “The Nepenthes Platform: An Efficient Approach to collect Malware”, Springer-verlag Berlin Heidelberg, (2006), pp. 165-184.
Bayer, et al., “Dynamic Analysis of Malicious Code”, J Comput Virol, Springer-Verlag, France., (2006), pp. 67-77.
Boubalos, Chris , “extracting syslog data out of raw pcap dumps, seclists.org, Honeypots mailing list archives”, available at http://seclists.org/honeypots/2003/q2/319 (“Boubalos”), (Jun. 5, 2003).
Chaudet, C. , et al., “Optimal Positioning of Active and Passive Monitoring Devices”, International Conference on Emerging Networking Experiments and Technologies, Proceedings of the 2005 ACM Conference on Emerging Network Experiment and Technology, CoNEXT '05, Toulousse, France, (Oct. 2005), pp. 71-82.
Cisco “Intrusion Prevention for the Cisco ASA 5500-x Series” Data Sheet (2012).
Cohen, M.I. , “PyFlag—An advanced network forensic framework”, Digital investigation 5, Elsevier, (2008), pp. S112-S120.
Costa, M. , et al., “Vigilante: End-to-End Containment of Internet Worms”, SOSP '05, Association for Computing Machinery, Inc., Brighton U.K., (Oct. 23-26, 2005).
Didier Stevens, “Malicious PDF Documents Explained”, Security & Privacy, IEEE, IEEE Service Center, Los Alamitos, CA, US, vol. 9, No. 1, Jan. 1, 2011, pp. 80-82, XP011329453, ISSN: 1540-7993, DOI: 10.1109/MSP.2011.14.
Distler, “Malware Analysis: An Introduction”, SANS Institute InfoSec Reading Room, SANS Institute, (2007).
Dunlap, George W. , et al., “ReVirt: Enabling Intrusion Analysis through Virtual-Machine Logging and Replay”, Proceeding of the 5th Symposium on Operating Systems Design and Implementation, USENIX Association, “Dunlap”), (Dec. 9, 2002).
FireEye Malware Analysis & Exchange Network, Malware Protection System, FireEye Inc., 2010.
FireEye Malware Analysis, Modern Malware Forensics, FireEye Inc., 2010.
FireEye v.6.0 Security Target, pp. 1-35, Version 1.1, FireEye Inc., May 2011.
Goel, et al., Reconstructing System State for Intrusion Analysis, Apr. 2008 SIGOPS Operating Systems Review, vol. 42 Issue 3, pp. 21-28.
Gregg Keizer: “Microsoft's HoneyMonkeys Show Patching Windows Works”, Aug. 8, 2005, XP055143386, Retrieved from the Internet: URL:http://www.informationweek.com/microsofts-honeymonkeys-show-patching-windows-works/d/d-id/1035069? [retrieved on Jun. 1, 2016].
Heng Yin et al, Panorama: Capturing System-Wide Information Flow for Malware Detection and Analysis, Research Showcase @ CMU, Carnegie Mellon University, 2007.
Hiroshi Shinotsuka, Malware Authors Using New Techniques to Evade Automated Threat Analysis Systems, Oct. 26, 2012, http://www.symantec.com/connect/blogs/, pp. 1-4.
Idika et al., A-Survey-of-Malware-Detection-Techniques, Feb. 2, 2007, Department of Computer Science, Purdue University.
Isohara, Takamasa, Keisuke Takemori, and Ayumu Kubota. “Kernel-based behavior analysis for android malware detection.” Computational intelligence and Security (CIS), 2011 Seventh International Conference on. IEEE, 2011.
Kaeo, Merike , “Designing Network Security”, (“Kaeo”), (Nov. 2003).
Kevin A Roundy et al: “Hybrid Analysis and Control of Malware”, Sep. 15, 2010, Recent Advances in Intrusion Detection, Springer Berlin Heidelberg, Berlin, Heidelberg, pp. 317-338, XP019150454 ISBN:978-3-642-15511-6.
Khaled Salah et al: “Using Cloud Computing to Implement a Security Overlay Network”, Security & Privacy, IEEE, IEEE Service Center, Los Alamitos, CA, US, vol. 11, No. 1, Jan. 1, 2013 (Jan. 1, 2013).
Kim, H. , et al., “Autograph: Toward Automated, Distributed Worm Signature Detection”, Proceedings of the 13th Usenix Security Symposium (Security 2004), San Diego, (Aug. 2004), pp. 271-286.
King, Samuel T., et al., “Operating System Support for Virtual Machines”, (“King”), (2003).
Kreibich, C. , et al., “Honeycomb-Creating Intrusion Detection Signatures Using Honeypots”, 2nd Workshop on Hot Topics in Networks (HotNets-11), Boston, USA, (2003).
Kristoff, J. , “Botnets, Detection and Mitigation: DNS-Based Techniques”, NU Security Day, (2005), 23 pages.
Lastline Labs, The Threat of Evasive Malware, Feb. 25, 2013, Lastline Labs, pp. 1-8.
Li et al., A VMM-Based System Call Interposition Framework for Program Monitoring, Dec. 2010, IEEE 16th International Conference on Parallel and Distributed Systems, pp. 706-711.
Lindorfer, Martina, Clemens Kolbitsch, and Paolo Milani Comparetti. “Detecting environment-sensitive malware.” Recent Advances in Intrusion Detection. Springer Berlin Heidelberg, 2011.
Marchette, David J., “Computer Intrusion Detection and Network Monitoring: A Statistical Viewpoint”, (“Marchette”), (2001).
Moore, D. , et al., “Internet Quarantine: Requirements for Containing Self-Propagating Code”, INFOCOM, vol. 3, (Mar. 30-Apr. 3, 2003), pp. 1901-1910.
Morales, Jose A., et al., ““Analyzing and exploiting network behaviors of malware.””, Security and Privacy in Communication Networks. Springer Berlin Heidelberg, 2010. 20-34.
Mori, Detecting Unknown Computer Viruses, 2004, Springer-Verlag Berlin Heidelberg.
Natvig, Kurt , “SANDBOXII: Internet”, Virus Bulletin Conference, (“Natvig”), (Sep. 2002).
NetBIOS Working Group. Protocol Standard for a NetBIOS Service on a TCP/UDP transport: Concepts and Methods. STD 19, RFC 1001, Mar. 1987.
Newsome, J. , et al., “Dynamic Taint Analysis for Automatic Detection, Analysis, and Signature Generation of Exploits on Commodity Software”, In Proceedings of the 12th Annual Network and Distributed System Security, Symposium (NDSS '05), (Feb. 2005).
Nojiri, D. , et al., “Cooperation Response Strategies for Large Scale Attack Mitigation”, DARPA Information Survivability Conference and Exposition, vol. 1, (Apr. 22-24, 2003), pp. 293-302.
Oberheide et al., CloudAV.sub.—N-Version Antivirus in the Network Cloud, 17th USENIX Security Symposium USENIX Security '08 Jul. 28-Aug. 1, 2008 San Jose, CA.
Reiner Sailer, Enriquillo Valdez, Trent Jaeger, Roonald Perez, Leendert van Doorn, John Linwood Griffin, Stefan Berger., sHype: Secure Hypervisor Appraoch to Trusted Virtualized Systems (Feb. 2, 2005) (“Sailer”).
Silicon Defense, “Worm Containment in the Internal Network”, (Mar. 2003), pp. 1-25.
Singh, S. , et al., “Automated Worm Fingerprinting”, Proceedings of the ACM/USENIX Symposium on Operating System Design and Implementation, San Francisco, California, (Dec. 2004).
Thomas H. Ptacek, and Timothy N. Newsham , “Insertion, Evasion, and Denial of Service: Eluding Network Intrusion Detection”, Secure Networks, (“Ptacek”), (Jan. 1998).
Venezia, Paul , “NetDetector Captures Intrusions”, InfoWorld Issue 27, (“Venezia”), (Jul. 14, 2003).
Vladimir Getov: “Security as a Service in Smart Clouds—Opportunities and Concerns”, Computer Software and Applications Conference (COMPSAC), 2012 IEEE 36th Annual, IEEE, Jul. 16, 2012 (Jul. 16, 2012).
Wahid et al., Characterising the Evolution in Scanning Activity of Suspicious Hosts, Oct. 2009, Third International Conference on Network and System Security, pp. 344-350.
Whyte, et al., “DNS-Based Detection of Scanning Works in an Enterprise Network”, Proceedings of the 12th Annual Network and Distributed System Security Symposium, (Feb. 2005), 15 pages.
Williamson, Matthew M., “Throttling Viruses: Restricting Propagation to Defeat Malicious Mobile Code”, ACSAC Conference, Las Vegas, NV, USA, (Dec. 2002), pp. 1-9.
Yuhei Kawakoya et al: “Memory behavior-based automatic malware unpacking in stealth debugging environment”, Malicious and Unwanted Software (Malware), 2010 5th International Conference on, IEEE, Piscataway, NJ, USA, Oct. 19, 2010, pp. 39-46, XP031833827, ISBN:978-1-4244-8-9353-1.
Zang et al., The Effects of Threading, Infection Time, and Multiple-Attacker Collaboration on Malware Propagation, Sep. 2009, IEEE 28th International Symposium on Reliable Distributed Systems, pp. 73-82.
Provisional Applications (1)
Number Date Country
62141099 Mar 2015 US