Application-directed memory de-duplication
First Claim
1. In a computing system comprised of an application executing on top of a virtualization control layer, wherein the virtualization control layer maps portions of a virtual memory to portions of a physical memory, an apparatus for managing memory comprising:
- a memory; and
a processor coupled to the memory and configured to;
identify, by the application, a range of the virtual memory whose probability of being replicated in the virtual memory exceeds a given threshold;
obtain, by the application, at least one memory address corresponding to the range of virtual memory;
pass, from the application to the virtualization control layer, an identifier for the range of virtual memory and the memory address corresponding to the range of virtual memory, wherein the identifier is useable by the virtualization control layer to identify similar ranges within the virtual memory; and
provide an application programming interface configured to allow the identifier and the range of virtual memory to be passed down from the application to a guest operating system, and from the guest operating system to the virtualization control layer at runtime;
wherein the application executes on the guest operating system, and the guest operating system executes on the virtualization control layer; and
wherein the processor is further configured to use at the virtualization control layer, based at least in part upon the identifier, delta encoding to reduce redundant information in the physical memory.
5 Assignments
0 Petitions
Accused Products
Abstract
In a computing system including an application executing on top of a virtualization control layer, wherein the virtualization control layer maps portions of a virtual memory to portions of a physical memory, an apparatus for managing memory configured to: identify, by the application, a range of virtual memory whose probability of being replicated in the virtual memory exceeds a given threshold; obtain, by the application, at least one memory address corresponding to the range of virtual memory; and pass, from the application to the virtualization control layer, an identifier for the range of virtual memory and the memory address corresponding to the range of virtual memory, wherein the identifier is useable by the virtualization control layer to identify similar ranges within the virtual memory.
-
Citations
18 Claims
-
1. In a computing system comprised of an application executing on top of a virtualization control layer, wherein the virtualization control layer maps portions of a virtual memory to portions of a physical memory, an apparatus for managing memory comprising:
-
a memory; and a processor coupled to the memory and configured to; identify, by the application, a range of the virtual memory whose probability of being replicated in the virtual memory exceeds a given threshold; obtain, by the application, at least one memory address corresponding to the range of virtual memory; pass, from the application to the virtualization control layer, an identifier for the range of virtual memory and the memory address corresponding to the range of virtual memory, wherein the identifier is useable by the virtualization control layer to identify similar ranges within the virtual memory; and provide an application programming interface configured to allow the identifier and the range of virtual memory to be passed down from the application to a guest operating system, and from the guest operating system to the virtualization control layer at runtime; wherein the application executes on the guest operating system, and the guest operating system executes on the virtualization control layer; and wherein the processor is further configured to use at the virtualization control layer, based at least in part upon the identifier, delta encoding to reduce redundant information in the physical memory. - View Dependent Claims (2, 3, 4, 11, 12, 13, 14, 15, 16, 17, 18)
-
-
5. A computer program product comprising a non-transitory processor-readable storage medium having encoded therein executable code of one or more software programs, wherein the one or more software programs when executed by the at least one processor implement the steps of:
-
identifying, by the application, a range of the virtual memory whose probability of being replicated in the virtual memory exceeds a given threshold; obtaining, by the application, at least one memory address corresponding to the range of virtual memory; passing, from the application to the virtualization control layer, an identifier for the range of virtual memory and the memory address corresponding to the range of virtual memory, wherein the identifier is useable by the virtualization control layer to identify similar ranges within the virtual memory; and providing an application programming interface configured to allow the identifier and the range of virtual memory to be passed down from the application to a guest operating system, and from the guest operating system to the virtualization control layer at runtime; wherein the application executes on the guest operating system, and the guest operating system executes on the virtualization control layer; and wherein the one or more software programs when executed by the at least one processor implement at the virtualization control layer, based at least in part upon the identifier, delta encoding to reduce redundant information in the physical memory.
-
-
6. In a computing system comprised of an application executing on top of a virtualization control layer, wherein the virtualization control layer maps portions of a virtual memory to portions of a physical memory, an apparatus for managing memory comprising:
-
a memory; and a processor coupled to the memory and configured to; receive, at the virtualization control layer from the application, an identifier for a range of virtual memory whose probability of being replicated in the virtual memory exceeds a given threshold and at least one memory address corresponding to the range of virtual memory; and use, by the virtualization control layer, the identifier to identify similar ranges within the virtual memory; and provide an application application programming interface configured to allow the identifier and the range of virtual memory to be passed down from the application to a guest operating system, and from the guest operating m to the virtualization control layer at runtime; wherein the application executes on the guest operating system, and the guest operating system executes on the virtualization control layer; and wherein the processor is further configured to use at the virtualization control layer, based at least in part upon the identifier, delta encoding to reduce redundant information in the physical memory. - View Dependent Claims (7, 8, 9)
-
-
10. A computer program product comprising a non-transitory processor-readable storage medium having encoded therein executable code of one or more software programs, wherein the one or more software programs when executed by the at least one processor implement the steps of:
-
receiving, at the virtualization control layer from the application, an identifier for a range of virtual memory whose probability of being replicated in the virtual memory exceeds a given threshold and at least one memory address corresponding to the range of virtual memory; using, by the virtualization control layer, the identifier to identify similar ranges within the virtual memory; and providing an application programming interface configured to allow the identifier and the range of virtual memory to be passed down from the application to a guest operating system, and from the guest operating system to the virtualization control layer at runtime; and wherein the application executes on the guest operating system, and the guest operating system executes on the virtualization control layer; and wherein the one or more software programs when executed by the at least one processor implement at the virtualization control layer, based at least in part upon the identifier, delta encoding to reduce redundant information in the physical memory.
-
Specification