A method includes, with a hypervisor, receiving a first request from a guest to write a first piece of data to a first memory location within a kernel code page. The method further includes determining that the first request triggers a violation based on a kernel protection mechanism, and in response to determining that the first request triggers the violation, determining that the first piece of data includes a breakpoint. The method further includes, in response to determining that the first piece of data includes the breakpoint, copying a second piece of data currently stored at the first memory location to a second memory location within non-guest writeable memory and overwriting the first memory location with the first piece of data.
|
17. A non-transitory machine-readable medium having stored thereon machine-readable instructions executable to cause a machine to perform operations comprising:
receiving a first request from a guest to write a first piece of data to a first memory location within an executable guest memory page;
determining that the first request triggers a violation of a kernel protection mechanism;
in response to determining that the first request triggers the violation, determining that the first piece of data includes a breakpoint;
in response to determining that the first piece of data includes a breakpoint, copying a second piece of data currently stored at the first memory location to a second memory location within non-guest writable memory;
overwriting the first memory location with the first piece of data;
overwriting a remainder of the first memory location with no-operation (NOP) instructions; and
receiving a second request from the guest to write a third piece of data to the first memory location.
14. A system comprising:
a processor; and
a memory comprising machine readable instructions that when executed by the processor cause the system to:
execute a hypervisor to support at least one guest;
with the hypervisor, receive a first request from the at least one guest, the first request being to write a first piece of data to a first memory location within an executable guest memory page;
with the hypervisor, in response to detecting an Extended page table (EPT) violation resulting from the first request, determine that the first piece of data comprises a breakpoint;
with the hypervisor, in response to determining that the first piece of data comprises the breakpoint, copy a second piece of data currently stored at the first memory location to a second memory location within hypervisor memory;
with the hypervisor, overwrite the first memory location with the first piece of data; and
with the hypervisor, overwrite a remainder of the first memory location with no-operation (NOP) instructions.
1. A method comprising:
with a hypervisor, receiving a first request from a guest to write a first piece of data to a first memory location within an executable guest memory page;
with the hypervisor, determining that the first request triggers a violation based on a kernel protection mechanism;
with the hypervisor, in response to determining that the first request triggers the violation, determining that the first piece of data includes a breakpoint;
with the hypervisor, in response to determining that the first piece of data includes the breakpoint, copying a second piece of data currently stored at the first memory location to a second memory location within non-guest writeable memory;
with the hypervisor, overwriting the first memory location with the first piece of data; and
before the kernel protection mechanism is activated, receiving from the guest a request for breakpoint insertion support, wherein the request for breakpoint insertion support identifies a range of memory addresses within the executable guest memory page for which breakpoint insertion support is requested.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
12. The method of
13. The method of
15. The system of
16. The system of
in response to the determining that the third piece of data matches the second piece of data, overwriting the third piece of data at the first memory location; and
incrementing an instruction register.
18. The non-transitory machine-readable medium of
19. The non-transitory machine-readable medium of
20. The non-transitory machine-readable medium of
|
The present disclosure generally relates to computer program debugging, and more particularly to systems and methods that allow for breakpoint insertion into a protected kernel page.
Conventional tracing technology allows users to analyze the operation of computer programs. For example, users may want to read data values at various execution times to identify a state of a computer program, write data values to particular memory locations, identify functions that are called, insert breakpoints to halt operation at particular code locations, and otherwise analyze the operation of a computer program. Tracing is useful for many activities, such as debugging. Debugging is a conventional activity that is performed using tracing technology to locate bugs/issues in computer programs and repair those bugs/issues.
Tracing technology allows tracing to be performed at the kernel level. For example, breakpoint instructions and function calls may be added and removed at various locations in kernel memory to allow analysis of the operation of the kernel. Users may, for example, identify events that are triggered in the kernel at various execution times, and otherwise trace the operation of the kernel.
Other conventional technologies that are used at the kernel level include kernel protection mechanisms. Kernel protection mechanisms allow enforcement of kernel protection measures that prevent the kernel from being modified. These mechanisms are useful for thwarting at least some malware and/or otherwise helping to safeguard the integrity of the kernel.
One issue that has arisen is that these kernel protection mechanisms are not compatible with tracing technology. That is, by preventing the kernel from being modified, the kernel protection mechanisms do not allow the kernel tracing features to be implemented in the kernel. For example, the tracing technology may be unable to insert and/or remove tracing mechanisms such as breakpoints and/or other tracing function calls into the kernel. Accordingly, while the kernel protection mechanisms may be helpful in some ways, they may also counter useful features that allow users to perform beneficial activities such as debugging.
According to one example, a method includes, with a hypervisor, receiving a first request from a guest to write a first piece of data to a first memory location within a executable guest memory page. The method further includes determining that the first request triggers a violation based on a kernel protection mechanism, and in response to determining that the first request triggers the violation, determining that the first piece of data includes a breakpoint. The method further includes, in response to determining that the first piece of data includes the breakpoint, copying a second piece of data currently stored at the first memory location to a second memory location within non-guest writeable memory and overwriting the first memory location with the first piece of data.
A system includes a processor and a memory comprising machine readable instructions that when executed by the processor cause the system to: execute a hypervisor to support at least one guest, receive a first request from the at least one guest, the first request being to write a first piece of data to a first memory location within a executable guest memory page, in response to detecting an Extended Page Table (EPT) violation resulting from the first request, determine that the first piece of data comprises a breakpoint, in response to determining that the first piece of data comprises the breakpoint, copy a second piece of data currently stored at the first memory location, to a second memory location within hypervisor memory, with the hypervisor, overwrite the first memory location with the first piece of data, and overwrite a remainder of the first memory location with no-operation (NOP) instructions.
A non-transitory machine-readable medium having stored thereon machine-readable instructions executable to cause a machine to perform operations that include receiving a first request from a guest to write a first piece of data to a first memory location within a executable guest memory page, determining that the first request triggers a violation of a kernel protection mechanism, in response to determining that the first request triggers the violation, determining that the first piece of data includes a breakpoint, in response to determining that the first piece of data includes a breakpoint, copying a second piece of data currently stored at the first memory location to a second memory location within non-guest writable memory, overwriting the first memory location with the first piece of data, overwriting a remainder of the first memory location with no-operation (NOP) instructions, and receiving a second request from the guest to write a third piece of data to the first memory location.
In the figures, elements having the same designations have the same or similar functions.
In the following description, specific details are set forth describing some embodiments consistent with the present disclosure. It will be apparent, however, to one skilled in the art that some embodiments may be practiced without some or all of these specific details. The specific embodiments disclosed herein are meant to be illustrative but not limiting. One skilled in the art may realize other elements that, although not specifically described here, are within the scope and the spirit of this disclosure. In addition, to avoid unnecessary repetition, one or more features shown and described in association with one embodiment may be incorporated into other embodiments unless specifically described otherwise or if the one or more features would make an embodiment non-functional.
As described above, while kernel protection mechanisms may be helpful in some ways, they may also counter useful features that allow users to perform beneficial activities such as debugging. It is desirable to have a system that provides protection for the kernel but also allows for breakpoint insertions into the kernel code to allow for debugging and other operations. According to principles described herein, a guest may request support for breakpoint insertion from the hypervisor before the kernel protection mechanism is activated (e.g., at boot-up of the guest). When support for breakpoint insertion into kernel code pages is enabled, the hypervisor will handle requests to write data to the protected kernel code page as follows.
According to one example, the hypervisor detects that the guest is attempting to write data to a memory location within an executable guest memory page, such as a kernel code page. Conventionally, such an action is disallowed by the kernel protection mechanism. But, with breakpoint insertion support enabled as described herein, the hypervisor determines if the data to be written to the memory location within the kernel code page is a breakpoint instruction. If the data is not a breakpoint instruction, then the request is denied. But, if the data is in fact a breakpoint instruction, then the hypervisor first copies the data currently stored at the memory location within the kernel code page to a memory location within non-guest memory (e.g., hypervisor memory). Then, the breakpoint instruction is inserted at the memory location in the kernel code page.
To remove the breakpoint instruction, the guest attempts to write the original instruction back to the memory location within the kernel code page. Again, this conventionally causes the kernel protection mechanism to deny such an attempt. But, with breakpoint insertion support enabled, the hypervisor determines whether the data attempting to be written matches the originals instruction as stored in the non-guest memory. If the data matches, then the original instruction is written back to the memory location within the kernel code page. If, however, the data does not match, then the attempt to write data is denied.
Using principles described herein, breakpoint insertion is allowed while the protections provided by the kernel protection mechanism remain in place. Thus, the kernel protection mechanism can still perform its desired function by protecting the guest against inadvertent or malicious request overwrite portions of the kernel code pages. A developer may perform debugging operations related to the kernel to improve the functionality of the kernel and other applications. The following will describe the breakpoint insertion support in more detail.
The hypervisor 106 allows for multiple virtual machines 110, and thus multiple guests 112, to run on the same physical host machine 102. Additionally, the host machine 102 may run the multiple guests 112 concurrently and in isolation from other programs on the host machine 102. One guest 112 may run different type of operating system than another guest 112 being run on the same host machine 102. Additionally, the operating system associated with a guest 112 running on a virtual machine 110 may be different from the host operating system running on the host machine 102.
A guest 112 may include anything executed on a virtual machine 110. For example, a guest 112 may include an operating system, applications running on that operating system, data storage associated with the applications and operating system, drivers, etc. In one example, a guest 112 may be packaged as a large set of data that is loaded into host memory 105. The hypervisor 106 then interacts with that large set of data to execute instructions on one of the virtual machines 110.
The host memory 105 refers to the working memory of the host machine 102. Working memory is typically Random Access Memory (RAM) and is designed for speed. Working memory is often a volatile form of memory, meaning that it loses its data when power is no longer supplied. The host machine 102 may, however, have other forms of memory available such as solid state drives, Network-Attached Storage (NAS) drives, Redundant Array of Independent Disks (RAID) drives, and other non-volatile storage devices. The various types of memory may store information in the form of software and data. The host memory 105 may designate various blocks of memory for use by the hypervisor 106 or for use by the guests 112 using the virtual machines 110. These blocks of memory may be ranges of physical memory addresses or virtual memory addresses. The memory designated for the guests may be referred to as guest memory 107. The memory designated for the hypervisor may be referred to as hypervisor memory 109. The guest memory may be divided into different regions or modules, each module associated with a different virtual machine.
In the example illustrated in
The hypervisor 106 can map a virtual resource or state (e.g., registers, memory, or files) to real resources in the underlying host machine 102. For example, the hypervisor 106 may present a guest memory to guest 112. The hypervisor 106 may map the memory locations of guest memory to physical memory locations of memory 105.
To facilitate multiple virtual machines 110 simultaneously, hardware resources are shared among the hypervisor 106 and one or more guests 112. The physical processors 104 of the host machines enter and exit the context of different virtual processors 108 and the hypervisor 106. A virtual machine exit marks the point at which a context switch occurs between the virtual processor 108 currently running and the hypervisor 106, which takes over control for a particular reason. During the context switch, the processor 104 may save a snapshot of the state of the virtual processor that was running at the time of exit. The virtual machine exit is handled by the hypervisor 106, which decides the appropriate action to take and then transfers control back to the virtual processor 108 via a virtual machine entry. A virtual machine entry marks the point at which a context switch occurs between the hypervisor 106 and a virtual processor 108, which takes over control.
In the present example, a kernel 114 is associated with a guest 112 and runs on the virtual machine 110 provided by the hypervisor 106. As used herein, the term “kernel” may refer to any privileged software component of an operating system. The kernel 114 provides core computing functionality to the virtual machine 110. For example, kernel 114 is structured to manage important tasks, such as allocating guest memory 107, sending and receiving I/O, managing a file system provided to the guest 112, handling interrupts, scheduling and running processes to execute instructions of computing tasks, and/or provide other fundamental computing features.
In some examples, each guest 112 is structured to include a kernel 114. In some cases, the kernel 114 may be a stand-alone kernel. However, in some examples, the virtual machine 110 is structured with the kernel 114 as well as a guest 112 that is built on top of the kernel 114 and relies upon the kernel 114 for allocating portions of the guest memory 107 to the guest 112 (and its applications) and executing instructions of the guest 112 (and its applications). The guest 112 may also be referred to as a guest operating system. Examples of guest operating systems include, for example, LINUX, UNIX, DOS, OS/2, IOS, ANDROID, WINDOWS, and so forth. These guests all include, at their core, a kernel (such as kernel 114) that handles allocation of memory and runs processes to execute instructions. The guest 112 may include features such as user interfaces (such as a desktop and/or command line interface), file systems, server applications, database management systems, tracing tools (including debugging applications), programming applications, and various other user applications that may be pre installed on the guest 112 or added after installation of the guest 112.
The guest 112 running on a virtual machine 110 may include a same or a different operating system as a host operating system running on the host machine 102. For example, the guest 112 may provide an operating system that is accessed locally on the host machine 102 as a default operating environment of the host machine 102. In other examples, the host machine 102 is structured with an operating system that is separate from the guest 112, and the guest 112 is provided in addition to the host machine's operating system. Accordingly, the host machine 102 may run multiple operating systems concurrently and in isolation from other operating systems. Moreover, the guest operating systems of the host machine 102 and virtual machines 110 may be homogenous or heterogeneous. That is, the guest operating systems may all be one type (e.g., LINUX) or may be different types (e.g., guest 112 may be RED HAT ENTERPRISE LINUX, and a virtual machine of the virtual machine(s) may include a guest that is another type of operating system).
The hypervisor 106 provides a portion of guest memory 107 that is allocated to the kernel 114, guest 112, and/or other applications running on the virtual machine 110. In the present example, the guest memory 107 is structured as a virtualized portion of the host memory 105. The guest memory 107 may include one or more guest memory pages that are mapped to memory pages of the host memory 105 via one or more mappings, such as page tables. The mapping(s) may be provided by the hypervisor 106. As an example, page tables may include Extended Page Tables (EPT). Accordingly, the hypervisor 106 is structured with access to the guest memory 107 to virtualize the host memory 105 and provide the guest memory 107 to the virtual machine 110. The guest memory 107, once allocated to the virtual machine 110 by the hypervisor 106, may have portions allocated by the kernel 114 to the kernel 114 itself, the guest 112, and/or other applications run on the virtual machine 110 by the kernel 114.
In the present example, the kernel 114 is structured to operate in a protected kernel environment, which may prevent at least some modifications to the kernel 114. For example, the kernel 114 may be structured to include a kernel protection mechanism such as KERNEL GUARD TECHNOLOGY (KGT), which renders the memory pages and/or page table entries corresponding to the kernel 114 immutable in the virtual environment provided by the virtual machine 110. That is, the kernel 114, guest 112, and/or other applications running on the virtual machine 110 may be prevented from modifying the memory pages and/or page table entries that correspond to the kernel 114, Accordingly, without breakpoint insertion support as described herein, the guest 112 is prevented from inserting, and/or removing instructions into the kernel 114 to perform tracing activities (including debugging) once the kernel protection mechanism is activated.
In the present example, the kernel protection feature prevents modification of the kernel by the kernel itself and/or any tasks that are managed by the kernel. For example, the kernel, operating system running on top of the kernel, and/or other applications that are assigned tasks managed by the kernel are prevented from writing to the kernel. In some examples, kernel protection feature prevents writes from being executed that modify (1) memory pages that are allocated to the kernel and/or (2) page mappings (such as page table entries) that correspond to the memory pages that are allocated to the kernel.
In some examples, the kernel protection feature may protect the kernel from modification by parsing each instruction that is provided to the kernel for execution, and skipping execution of instructions that would write to memory pages allocated to the kernel, and/or page table entries corresponding to the memory pages. Accordingly, because the kernel, guest, and/or other applications run by the guest rely upon the kernel to manage tasks for executing instructions, the kernel is able to determine whether the instructions are write instructions and whether the destinations of the write instructions correspond to the kernel. Thus, the kernel may provide a protected kernel environment that renders the kernel's memory pages (and its page mappings) immutable to itself and/or other programs managed by the kernel.
In the present example, the hypervisor 106 is structured with access to the guest memory 107, including page table entries and memory pages allocated to the kernel 114. The hypervisor 106 maintains this access even while the protected kernel environment is implemented. The hypervisor 106 is structured to communicate with the kernel 114, such as via hypercalls, system calls, shared memory, and/or interrupts, such that information may be passed between the hypervisor 106 and the kernel 114.
At action 402, the hypervisor (e.g., 106,
At action 404, the hypervisor determines whether the request of action 402 triggers a page table violation. Specifically, if the first memory location is not within a protected page, then the method 400 proceeds to action 406 at which the request is executed as normal. If, however, the first memory location is within a protected page (e.g., a kernel code page), then a page table violation is triggered. For example, the violation may trigger an error handler at the hypervisor, which executes instructions to respond to the error. For example, the kernel may trigger an interrupt that is received by the hypervisor and processed at the error handler. Accordingly, the hypervisor detects the attempted modification to the kernel. The method 400 then proceeds to action 408.
At action 408 it is determined with a breakpoint insertion support has been enabled. In one example, breakpoint insertion support may be enabled upon boot-up of the guest before the kernel protection mechanism is activated. For example, as the guest is booting up, it may request breakpoint insertion support from the hypervisor. In some examples, the guest may define a range of memory addresses within the kernel code pages for which the guest desires breakpoint insertion support. In such a case, the hypervisor will also determine whether the first portion of memory from the request of action 402 is within such a range of memory addresses. If breakpoint insertion support is not enabled, or if the first portion of memory is outside a range of memory addresses that has been approved for breakpoint insertion support, then the request is denied at action 424. If, however, breakpoint support is enabled and the first portion of memory is within the approved range of memory addresses, then the method 400 proceeds to action 410. In some cases, the hypervisor may not know whether a particular page is a kernel page. Thus, the hypervisor can make decisions based on the range of memory addresses provided by the guest.
At action 410, the hypervisor determines whether the first piece of data is a breakpoint. Determining whether the first piece of data is a breakpoint may be done in a variety of manners. In one example, the hypervisor compares the first piece of data to a predetermined value. That predetermined value may correspond to a breakpoint instruction. In some examples, the hypervisor compares the first piece of data to a value received along with the request for breakpoint insertion support. In other words, when the guest requests breakpoint insertion support at start-up, the guest may provide a set of values that correspond to breakpoints that the guest may wish to use. If the hypervisor determines that the first piece of data matches such values, then it is determined that the first piece of data is a breakpoint. If, however, the first piece of data does not match such values, then it is determined that the first piece of data is not a breakpoint.
If it is determined, at action 410, that the first piece of data is a breakpoint, then the method 400 proceeds to action 412. At action 412, the hypervisor determines whether a breakpoint is already present at the first memory location. If a breakpoint is already present, then the hypervisor simply ignores the request at action 414. If, however, there is no breakpoint present, then the method 400 proceeds to action 416.
At action 416, the hypervisor copies the original instruction (e.g., 206-2,
At action 418, after the original instruction has been copied to the second memory location, the hypervisor overwrites the first memory location with the first piece of data of the request. In other words, the hypervisor overwrites the first memory location with the breakpoint. In some examples, the breakpoint instruction may be smaller than the original instruction stored at the first memory location. In such a case, the hypervisor may fill the remaining space with NOP instructions action 420. Then, the method 400 proceeds as the instruction register is incremented at action 430.
If it is determined, at action 410, that the first piece of data is not a breakpoint, then the method 400 proceeds to action 422. At action 422 it is determined whether the request is a breakpoint reversion. A breakpoint reversion is a request to replace the breakpoint instruction with the original instruction that was stored at the first memory location before breakpoint was inserted there. The hypervisor may determine whether the request is a breakpoint reversion by comparing the first piece of data to data stored at a second memory location in non-guest writable memory. In one example, the comparison may be done by comparing a first byte of the first piece of data with a first byte of the data stored at the second memory location. If, during a previous iteration of method 400, the first piece of data was a breakpoint, the original instruction would have been copied to the second memory location as in action 416. Thus, during a subsequent iteration of method 400 for the first piece of data is a breakpoint reversion (e.g., 302,
If the hypervisor determines that the request is not a breakpoint reversion, then the method proceeds to action 424 and the request is denied. In some examples, the denied request may be logged as well. If, however, the hypervisor determines that the request is a breakpoint reversion, then at action 428, the hypervisor overwrites the breakpoint stored at the first memory location with the original instruction associated with the request. This may include overwriting the NOP instructions as well. Then, the method 400 proceeds as the instruction register is incremented at action 430.
The computer system 500 may be used to implement one or more embodiments of the present disclosure. For example, with respect to
Computer system 500 includes processing device (processor) 502, main memory 504 (e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM), double data rate (DDR SDRAM), or DRAM (RDRAM), and so forth), static memory 506 (e.g., flash memory, static random access memory (SRAM), and so forth), and data storage device 518, which communicate with each other via bus 530.
Processor 502 represents one or more general-purpose processing devices such as a microprocessor, central processing unit, or the like. More particularly, processor 502 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, or a processor implementing other instruction sets or processors implementing a combination of instruction sets. Processor 502 may also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. Processor 502 is configured to execute instructions for performing the operations and steps discussed herein.
Computer system 500 may further include network interface device 508 that is structured to transmit data to and from the network 520.
Computer system 500 also may include video display unit 510 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)), alphanumeric input device 512 (e.g., a keyboard), cursor control device 514 (e.g., a mouse), and signal generation device 516 (e.g., a speaker).
Data storage device 518 may include a computer-readable storage medium on which is stored one or more sets of instructions (e.g., software) embodying any one or more of the methodologies or functions described herein. The instructions may also reside, completely or at least partially, within main memory 504 and/or within processor 502 during execution thereof by computer system 500, main memory 504 and processor 502 also constituting computer-readable storage media. The instructions may further be transmitted or received over network 520 via network interface device 508.
The network 520 may include any combination of public and/or private networks. The network 520 may include one or more network devices and transport media that are communicatively coupled via transport media. For example, network devices may include routers, hubs, switches, and so forth. Transport media may include, for example, Ethernet cable, Fibre Channel Cable, wireless signals, and so forth.
While data storage device 518 is shown in an example to be a single medium, the term “data storage device” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions.
The term “computer-readable storage medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present disclosure. The term “computer-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories, optical media, and magnetic media.
In the foregoing description, numerous details are set forth. It will be apparent, however, to one of ordinary skill in the art having the benefit of this disclosure, that the present disclosure may be practiced without these specific details. In some instances, well-known structures and devices are shown in block diagram form, rather than in detail, in order to avoid obscuring the present disclosure.
Some portions of the detailed description have been presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It has proven convenient at times, for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like.
It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussion, it is appreciated that throughout the description, discussions utilizing terms such as “determining,” “measuring,” “generating,” “setting,” “performing,” “transmitting,” “comparing,” “matching,” “ordering,” and the like, refer to the actions and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (e.g., electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Certain examples of the present disclosure also relate to an apparatus for performing the operations herein. This apparatus may be constructed for the intended purposes, or it may comprise a general-purpose computer selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a computer readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, or any type of media suitable for storing electronic instructions.
Although illustrative embodiments have been shown and described, a wide range of modification, change and substitution is contemplated in the foregoing disclosure and in some instances, some features of the embodiments may be employed without a corresponding use of other features. One of ordinary skill in the art would recognize many variations, alternatives, and modifications. Thus, the scope of the invention should be limited only by the following claims, and it is appropriate that the claims be construed broadly and in a manner consistent with the scope of the embodiments disclosed herein.
Bonzini, Paolo, Tsirkin, Michael
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
6964035, | Jul 03 2001 | VALTRUS INNOVATIONS LIMITED | Debugging an operating system kernel with debugger support in a network interface card |
7000225, | Dec 07 2000 | International Business Machines Corporation | Method for inserting global breakpoints |
7571482, | Jun 28 2005 | Microsoft Technology Licensing, LLC | Automated rootkit detector |
7581220, | Nov 22 2005 | CA, INC | System and method for modifying user memory from an arbitrary kernel state |
7584383, | Aug 04 2006 | Oracle America, Inc | Method and system for kernel-level diagnostics using a hardware watchpoint facility |
7823131, | Jun 29 2001 | Siemens Industry Software Inc | Debugger for a hardware-implemented operating system |
7996836, | Dec 29 2006 | NORTONLIFELOCK INC | Using a hypervisor to provide computer security |
8024568, | Jan 28 2005 | Citrix Systems, Inc | Method and system for verification of an endpoint security scan |
8108641, | Jun 19 2006 | Texas Instruments Incorporated | Methods, apparatus, and systems for secure demand paging and other paging operations for processor devices |
8239838, | May 11 2006 | Samsung Electronics Co., Ltd. | Kernel-aware debugging system, medium, and method |
8464254, | Dec 31 2009 | Veritas Technologies LLC | Tracking storage operations of virtual machines |
8661417, | Mar 26 2009 | International Business Machines Corporation | Debugging program function |
8677321, | Jun 13 2011 | Red Hat, Inc.; Red Hat, Inc | User-space probe based debugging |
8713371, | Jan 28 2011 | ARM Limited | Controlling generation of debug exceptions |
8789189, | Jun 24 2010 | GOSECURE, INC | System and method for sampling forensic data of unauthorized activities using executability states |
8812804, | Jun 19 2006 | Texas Instruments Incorporated | Methods, apparatus, and systems for secure demand paging and other paging operations for processor devices |
8990520, | Mar 30 2012 | EMC IP HOLDING COMPANY LLC | Global memory as non-volatile random access memory for guest operating systems |
9311248, | May 07 2012 | Raytheon Company | Methods and apparatuses for monitoring activities of virtual machines |
9767003, | Jan 10 2014 | International Business Machines Corporation | Conditional component breakpoint setting system and method |
20060053492, | |||
20110185417, | |||
20130132690, | |||
20130297849, | |||
20130318398, | |||
20140189687, | |||
20150033038, | |||
20150046908, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Feb 25 2016 | RED HAT ISRAEL LTD | (assignment on the face of the patent) | / | |||
Feb 25 2016 | BONZINI, PAOLO | RED HAT ISRAEL | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037929 | /0439 | |
Feb 25 2016 | TSIRKIN, MICHAEL | RED HAT ISRAEL | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037929 | /0439 | |
Feb 25 2016 | BONZINI, PAOLO | RED HAT ISRAEL LTD | CORRECTIVE ASSIGNMENT TO CORRECT THE ASSIGNEE NAME PREVIOUSLY RECORDED ON REEL 037929 FRAME 0439 ASSIGNOR S HEREBY CONFIRMS THE RED HAT ISRAEL TO RED HAT ISRAEL LTD | 042525 | /0510 | |
Feb 25 2016 | TSIRKIN, MICHAEL | RED HAT ISRAEL LTD | CORRECTIVE ASSIGNMENT TO CORRECT THE ASSIGNEE NAME PREVIOUSLY RECORDED ON REEL 037929 FRAME 0439 ASSIGNOR S HEREBY CONFIRMS THE RED HAT ISRAEL TO RED HAT ISRAEL LTD | 042525 | /0510 |
Date | Maintenance Fee Events |
Nov 30 2021 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Date | Maintenance Schedule |
Jun 12 2021 | 4 years fee payment window open |
Dec 12 2021 | 6 months grace period start (w surcharge) |
Jun 12 2022 | patent expiry (for year 4) |
Jun 12 2024 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jun 12 2025 | 8 years fee payment window open |
Dec 12 2025 | 6 months grace period start (w surcharge) |
Jun 12 2026 | patent expiry (for year 8) |
Jun 12 2028 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jun 12 2029 | 12 years fee payment window open |
Dec 12 2029 | 6 months grace period start (w surcharge) |
Jun 12 2030 | patent expiry (for year 12) |
Jun 12 2032 | 2 years to revive unintentionally abandoned end. (for year 12) |