Opportunistic block transmission with time constraints
First Claim
Patent Images
1. A system comprising:
- a virtual execution environment;
a block granularity caching engine;
a cache;
wherein, in operation;
a process associated with a stream-enabled application is executed in the virtual execution environment;
the virtual execution environment intercepts a request for a resource from the process executing in the virtual execution environment;
the virtual execution environment identifies one or more blocks that are associated with the resource;
the virtual execution environment makes a block request for a requested block associated with the resource;
the block granularity caching engine receives predictively streamed blocks as the predictively streamed blocks are transmitted to the system, the predictively streamed blocks being included as part of an output buffer that includes only requested blocks and the predictively streamed blocks, the output buffer having a size limit based on a data window size that is within an interactivity threshold time throughput, the interactivity threshold being a predetermined time period, a number of the predictively streamed blocks being included in the output buffer based in part on the size limit;
the block granularity caching engine intercepts the block request from the virtual execution environment;
the block granularity caching engine checks the cache for blocks to satisfy the block request;
the block granularity caching engine associates at least one of the predictively streamed blocks with the requested block associated with the resource;
the block granularity caching engine provides the at least one predictively streamed block to the virtual execution environment if the at least one predictively streamed block is found in the cache;
the virtual execution environment satisfies the resource request of the process using the at least one predictively streamed block.
3 Assignments
0 Petitions
Accused Products
Abstract
A technique for determining a data window size allows a set of predicted blocks to be transmitted along with requested blocks. A stream enabled application executing in a virtual execution environment may use the blocks when needed.
318 Citations
8 Claims
-
1. A system comprising:
-
a virtual execution environment; a block granularity caching engine; a cache; wherein, in operation; a process associated with a stream-enabled application is executed in the virtual execution environment; the virtual execution environment intercepts a request for a resource from the process executing in the virtual execution environment; the virtual execution environment identifies one or more blocks that are associated with the resource; the virtual execution environment makes a block request for a requested block associated with the resource; the block granularity caching engine receives predictively streamed blocks as the predictively streamed blocks are transmitted to the system, the predictively streamed blocks being included as part of an output buffer that includes only requested blocks and the predictively streamed blocks, the output buffer having a size limit based on a data window size that is within an interactivity threshold time throughput, the interactivity threshold being a predetermined time period, a number of the predictively streamed blocks being included in the output buffer based in part on the size limit; the block granularity caching engine intercepts the block request from the virtual execution environment; the block granularity caching engine checks the cache for blocks to satisfy the block request; the block granularity caching engine associates at least one of the predictively streamed blocks with the requested block associated with the resource; the block granularity caching engine provides the at least one predictively streamed block to the virtual execution environment if the at least one predictively streamed block is found in the cache; the virtual execution environment satisfies the resource request of the process using the at least one predictively streamed block. - View Dependent Claims (2, 3)
-
-
4. A method, comprising:
-
executing a process associated with a stream-enabled application in a virtual execution environment; intercepting a request for a resource from the process executing in the virtual environment; identifying one or more blocks that are associated with the resource; making a block request for a requested block associated with the resource; receiving predictively streamed blocks as the predictively streamed blocks are transmitted, the predictively streamed blocks being included as part of an output buffer that includes only requested blocks and the predictively streamed blocks, the output buffer having a size limit based on a data window size that is within an interactivity threshold time throughput, the interactivity threshold being a predetermined time period, a number of the predictively streamed blocks being included in the output buffer based in part on the size limit; intercepting the block request associated with the resource; checking a cache for blocks to satisfy the block request; associating at least one of the predictively streamed blocks with the requested block associated with the resource; providing the at least one predictively streamed block to the virtual execution environment if the at least one predictively streamed block is found in the cache; satisfying the resource request of the process using the at least one predictively streamed block. - View Dependent Claims (5, 6, 7)
-
-
8. A computer program product embodied on a non-transitory computer readable medium, the computer program product comprising a processor configured to execute instructions implementing a method comprising:
-
executing a process associated with a stream-enabled application in a virtual execution environment; intercepting a request for a resource from the process executing in the virtual environment; identifying one or more blocks that are associated with the resource; making a block request for a requested block associated with the resource; receiving predictively streamed blocks as the predictively streamed blocks are transmitted, the predictively streamed blocks being included as part of an output buffer that includes only requested blocks and the predictively streamed blocks, the output buffer having a size limit based on a data window size that is within an interactivity threshold time throughput, the interactivity threshold being a predetermined time period, a number of the predictively streamed blocks being included in the output buffer based in part on the size limit; intercepting the block request associated with the resource; checking a cache for blocks to satisfy the block request; associating at least one of the predictively streamed blocks with the requested block associated with the resource; providing the at least one predictively streamed block to the virtual execution environment if the at least one predictively streamed block is found in the cache; satisfying the resource request of the process using the at least one predictively streamed block.
-
Specification