Field of the Invention
The present invention is directed generally to methods and systems for constructing an application file from a plurality of files each storing less than the entire application file.
Description of the Related Art
A virtual application is a virtual machine image pre-configured with all of the files, registry data, settings, components, runtimes, and other dependencies required for a specific application to execute immediately and without installation on a host computing device. The virtual application is partially isolated from other applications implemented on a host computing device and partially isolated from an underlying host operating system installed and executing on the host computing device. The virtual application is encapsulated from the host operating system by a virtual runtime environment, which includes a virtual operating system, that receives operations performed by the virtualized application and redirects them to one or more virtualized locations (e.g., a virtual filesystem, virtual registry, and the like).
Thus, the virtual application may be conceptualized as including two components: a virtualization runtime and a virtual application configuration. The virtualization runtime implements the virtual runtime environment, which implements various operating system application programming interfaces (“APIs”) in such a way that allows the executing virtual application to access and interact with items that may not be present on the host computer. The virtual application configuration includes data necessary to implement the virtual application within the virtualization runtime.
The virtual application is stored in and implemented by one or more data files and/or executable files. Depending upon the implementation details, the one or more data files and/or executable files storing and implementing the virtual application may include blocks of data corresponding to each application file of a natively installed version of the application. Herein, these blocks of data will be referred to as “virtual application files.” The one or more data files and/or executable files storing and implementing the virtual application also include configuration information.
The data files and/or executable files are configured to execute within a virtual runtime environment that is provided at least in part by the virtual operating system. When the virtual application is executed within the virtual runtime engine, the configuration information is used to configure the virtual operating system to execute the virtual application. For example, the configuration information may contain information related to the virtual application files, virtual registry entries, environment variables, services, and the like. The virtual operating system is configured to communicate with the host operating system as required to execute the virtual application on the host computing device.
To download and execute a virtual application, a user must either use a specialized streaming protocol or download the entire virtualized application file before executing the application. Therefore, a need exists for a method and system configured to download and execute a virtualized application file without first downloading the entire file or using a specialized streaming protocol. The virtual application can be executed using less than the entire virtualized application file provided the executing virtual application does not request access to a portion of the file that has not been downloaded. Therefore, a need exists for a method or system that determines in which order the virtual application will request access to portions of the virtualized application file. A need also exists for systems and methods for managing the download and execution of a virtual application by a virtual runtime engine. The present application provides these and other advantages as will be apparent from the following detailed description and accompanying figures.
A diagram of hardware and an operating environment in conjunction with which implementations of the server computing device 7, the model building server 8, the client computing device 9, the computing device 11, and the network 10 may be practiced is provided in
As explained above, a virtualized application file 140 is transferred to the client computing device 9 from the server computing device 7. The virtualized application file 140 is illustrated in dashed lines to indicate that the virtualized application file 140 is stored in the cache 139 during and after the download. However, before the download begins, the virtualized application file 140 is not stored in the cache 139. As will be explained below, the virtualized application file 140 may be an executable file or a file configured to execute within a virtualized environment provided by a virtual machine (or virtual runtime engine).
The system memory 22A stores one or more files implementing one or more virtual machines (or virtual runtime engines). By way of a non-limiting example, the system memory 22A may include a plurality of virtual machine executable files 137 that when executed, each implement a different virtual machine. For example, each of the virtual machine executable files 137 may implement a different version of the same virtual machine. The virtual machine executable files 137 may be executed individually. When executed, a virtual machine executable file implements a virtualized environment. Execution of a virtual machine executable file may be initiated by the Sandbox Manager 134 using a command including a parameter (e.g., a file path) identifying a virtualized application file to execute. In response to receiving the parameter, the virtual machine executable file executes the identified virtualized application file inside the virtualized environment implemented by the virtual machine executable file.
The Sandbox Manager 134 and the virtual runtime engine 131 may both have read/write access to a block of shared memory 133 that may be used to send settings and state information between the Sandbox Manager 134 and the virtual runtime engine 131.
The virtualized application file 140 includes a version identifier that may be used by the Sandbox Manager 134 to select which of the virtual machine executable files 137 is configured to execute the virtualized application file 140.
In the embodiment illustrated, the system memory 22B stores web server components 142 configured to implement a web server. The web server components 142 may be configured to provide a web page having one or more links to virtualized application files using standard Hypertext Transfer Protocol (“HTTP”) protocol. By way of non-limiting examples, the web server components 142 may include Internet Information Services (“IIS”) provided by Microsoft Corporation, Apache, and the like. While illustrated as being outside the filesystem 126B, those of ordinary skill in the art appreciate that the virtualized application file 140 and the web server components 142 may be conceptualized as being within the filesystem 126B.
The virtualized application file 140 may include components necessary to implement a virtual runtime environment including a virtual operating system 120 configured to execute in the operating system 35A (see
The virtual operating system 120 includes a virtual filesystem 150, a virtual registry 152, and a virtual process environment and threading subsystems component 154. The virtual application 110 interacts with the virtual filesystem 150, virtual registry 152, and virtual process environment and threading subsystems component 154, instead of interacting directly with the host filesystem 126A, the host registry 128A, and the process environment and threading subsystems component 130A of the host operating system 35A illustrated in
The virtual application 110 executes inside a virtual runtime environment provided at least in part by the virtual operating system 120. Some virtual applications require one or more additional runtime environments to execute. For example, to execute a Flash application, the Flash runtime engine must also be installed. Therefore, to virtualize a Flash application, both the Flash application and Flash runtime engine must be included in the virtualized application file 140 and configured to execute in the portions of the virtual runtime environment provided by the virtual operating system 120. Collectively, all runtime components necessary to execute the virtual application 110 will be referred to as a virtual runtime engine. However, those of ordinary skill in the art appreciate that the virtual runtime engine may include only the virtual operating system 120 and components of other additional runtime engines (e.g., the Flash runtime engine) required to execute the virtual application 110 may be loaded separately by the virtual operating system 120. When executed, the virtual runtime engine generates, at least in part, the virtual runtime environment in which the virtual application 110 executes.
Referring to
The virtualized application file 140 includes virtualized application files 123A-123C corresponding to application files 111A-111C of a natively installed version of the same application. The virtualized application files 123A-123C are stored as blocks of data inside a configuration data block 121. During execution, the virtualized application files 123A-123C are accessed via the virtual filesystem 150. The virtualized application files 123A-123C include one or more startup executables. The virtualized application file 140 identifies one or more startup executables that are executed when the virtual application 110 is first executed. The startup executables may be identified in the configuration data block 121.
When the virtualized application file 140 is executed, the configuration data block 121 is used to configure the virtual operating system 120 to execute the virtual application. For example, the configuration data block 121 may contain configuration information related to the files in the virtual filesystem 150 (e.g., the virtualized application files 123A-123C), entries in the virtual registry 152, environment variables, services, and the like. The configuration data block 121 may also include basic application metadata and settings such as the application name, application version, and sandbox location. Further, the configuration data block 121 may provide isolation information to the virtual operating system 120. This information indicates which virtualized application files 123A-123C, virtual registry keys, virtual registry values, environment variables, and services are to be isolated from the host operating system 35A.
The configuration data block 121 may also include one or more virtual layers. Each virtual layer may identify files, registry entries, environment variables, and services. As the virtual layers are read, the corresponding files, registry entries, environment variables, and services are added to appropriate runtime data-structures. If the virtualized application file 140 is configured to execute on more than one host operating system, the configuration data block 121 may include a virtual layer for each operating system. In such an embodiment, each virtual layer includes information necessary to configure the virtual runtime environment to execute on a particular operating system. Further, the configuration data block 121 may include a virtual layer that includes configuration information common to the other virtual layers (e.g., a “default” virtual layer).
To execute the virtual application 110, an initialization process is first performed. During this process, the virtual operation system 120 is launched and configured by the configuration data block 121. A component of the virtual runtime engine 131 referred to as a “reader” (not shown) reads data stored in the configuration data block 121 and uses that data to configure the virtual runtime environment. For example, the reader reads the virtual layer for the host operating system 35A and any other applicable virtual layers and uses the information read to configure the virtual operation system 120 (and in some implementations, other components of the virtual runtime environment) to execute the virtual application 110 on the host operating system 35A. The virtual filesystem 150 may be configured to mirror a host filesystem configured to execute a natively installed version of the application. Similarly, the virtual registry 152 may be configured to mirror a host registry configured to execute a natively installed version of the application.
After the initialization process has completed, the appropriate startup executable(s) is/are launched inside the virtual operating system 120. The virtual operating system 120 intercepts calls to the host operating system 35A (see
The virtualized application file 140 is read-only and when executed, cannot be modified by the virtual application 110 or components of the virtual runtime engine 131 (see
U.S. patent application Ser. No. 12/188,155, filed on Aug. 7, 2008, U.S. patent application Ser. No. 12/188,161 filed on Aug. 7, 2008, and U.S. patent application Ser. No. 12/685,576 filed on Jan. 11, 2010, all of which are incorporated herein by reference in their entireties, disclose systems that may be used to create and configure the virtualized application file 140. As described in greater detail in U.S. patent application Ser. Nos. 12/188,155, 12/188,161, and 12/685,576, the virtualized application file 140 may be created by a virtual application executable constructor or authoring tool 170 using an application template that includes copies of files, such as a configuration file 202, application files 111A-111C, and the like, used to configure the virtualized application file 140. However, the template is not a requirement. Instead, to build the virtualized application file 140, the authoring tool 170 needs only the configuration file 202 and copies of any applications files 111A-111C necessary for a natively installed version of the application to execute. The applications files 111A-111C, and the configuration file 202 are referred to collectively as an application configuration 171.
The authoring tool 170 combines the application configuration 171 and the components of the virtual runtime engine (e.g., the virtual operating system 120) into the executable virtualized application file 140. Sometimes multiple virtual applications share a common set of virtual machine configuration settings or virtual runtime engine components. By way of a non-limiting example, multiple Flash applications may be configured to be executed by the same Flash runtime engine. Further, system administrators may want to share a common set of configuration options (e.g., browser bookmarks, application settings, etc.) across a department or enterprise. These settings may be stored in a file, referred to as an xlayer file 300, and incorporated into one or more virtual application files at runtime by the virtual runtime engine 131. Depending upon the implementation details, the authoring tool 170 may be used to create the xlayer file 300.
The xlayer file 300 cannot be executed directly from the host operating system 35A and instead requires the virtual runtime environment supplied at least in part by the virtual operating system 120. Like the configuration data block 121, the xlayer file 300 may be read by the reader of the virtual runtime engine at runtime. The information stored within the xlayer file 300 may be made available to a virtual application (e.g., the virtual application 110) via the virtual filesystem 150 and virtual registry 152 of the virtual operating system 120 at runtime. By way of a non-limiting example, the configuration data block 121 may specify a location on the host filesystem 126A whereat the virtual runtime engine 131 is configured to look for xlayer files. If an xlayer file is located in the specified location, the xlayer file 300 may be read automatically by the reader of the virtual runtime environment. Alternatively, the virtual runtime engine 131 may be configured to look for xlayer files in a particular location each time the virtual application 110 is executed.
The xlayer file 300 may be shared between users and used to supply virtual machine settings to multiple virtual applications. The xlayer file 300 may include all virtual registry and virtual filesystem information associated with a particular software component (e.g., a virtual runtime engine component), allowing the component to be fully installed in the virtual runtime environment. The xlayer file 300 may include all of the application data required to implement the virtual application 110 when executed by the virtual runtime engine 131. The xlayer file 300 may be implemented as a binary file. The data in the xlayer file 300 may be organized in one or more virtual layers substantially similar to the virtual layers of the configuration data block 121 described above.
As is apparent to those of ordinary skill in the art, the number of files and registry keys needed to implement a virtual application (such as the virtual application 110) and/or a component encoded in the xlayer file 300 can be very large. For example, it is not uncommon for the number of files and registry keys needed to implement a virtual application to total in the tens of thousands. Therefore, the performance characteristics of the configuration data block 121 and the xlayer file 300 can affect the performance of the virtual application 110 significantly. In other words, the performance characteristics of the configuration data block 121 and/or the xlayer file 300 can increase or decrease the startup time for the virtual application 110.
Further, the size of the xlayer file 300 may affect an amount of time required to access data stored by the xlayer file 300, which may affect the performance of the virtual application 110. The size of the xlayer file 300 also affects an amount of time required to download (or otherwise communicate) the xlayer file 300 between computing devices (e.g., the computing devices 7 and 9 illustrated in
As is apparent to those of ordinary skill in the art, the configuration data block 121 and the xlayer file 300 store similar data and therefore, can be formatted in accordance with a common format. U.S. patent application Ser. No. 12/697,029, filed on Mar. 31, 2010, entitled Method and System for Improving Startup Performance and Interoperability of a Virtual Application, which is incorporated herein by reference in its entirety, describes a file format that may be used to configure the configuration data block 121 portion of the executable virtualized application file 140 and/or the xlayer file 300.
Referring to
Applications often store large amounts of data in a single file stored on a hard disk. For example, the virtual application 110 may be executed using one or more xlayer files (e.g., the xlayer file 300). Unlike streaming media where a file is used in a linear fashion, some applications (e.g., the virtual application 110) require random access to chunks of data, referred to herein as “pages.” Thus, the pages required by the end user (or the application) are retrieved from a file in a non-sequential fashion. In other words, the pages are accessed in non-predetermined sequences that may include some randomness and may be difficult to predict. Depending upon the implementation details, pages may have a predetermined size (e.g., 4 kilobytes, 10 kilobytes, etc.). Alternatively, pages may have non-uniform sizes.
If during execution, an application suddenly requires access to a page that has not yet been downloaded, a delay must be introduced to download the page. Alternatively, execution of the application may end. To avoid this problem, when the xlayer file 300 is hosted on a web server (e.g., a web server implemented by the web server components 142 of the server computing device 7 illustrated in
If there is a predictable pattern in the order in which the pages are requested by the application, the pages can be ordered and encoded into files that model this pattern. In this manner, the most commonly accessed pages or page sequences may be downloaded first. This improves access time and transmission efficiency. Depending upon the implementation details, this ordering and encoding allows the pages to be distributed using standard Hypertext Transfer Protocol (“HTTP”), which is a conventional download technology, and does not require the use of specialized streaming protocols. By way of additional non-limiting examples, the pages to be distributed using other conventional download protocols, including File Transfer Protocol (“FTP”), Server Message Block Protocol (“SMB”), and the like.
For example, pages stored in a large single xlayer file (e.g., the xlayer file 300) can be reordered and divided into a plurality of smaller files (referred to herein as “xsequence files”) encoded using a predetermined file format (referred to herein as “xsequence file format,” which is described in detail below). The xsequence file format is configured to store permutations of at least a portion of the pages stored in a larger file (e.g., the xlayer file 300) and enables streaming distribution of the larger xlayer file. As mentioned above, the smaller xsequence files may be streamed over the Internet using conventional download methods thereby transferring the data of the xlayer file between different computing devices. Thus, the virtual application 110 may be launched by the client computing device 9 from the web without first downloading the entire xlayer file 300. This may greatly decrease startup latency. The remaining portions of the xlayer file may be downloaded subsequently while the user interacts with the executing virtual application 110.
For ease of illustration, the file from which one or more xsequence files are created will be referred to as an “original file.” While the original file may be an xlayer file (e.g., the xlayer file 300) having one or more of the file format(s) described in U.S. patent application Ser. No. 12/697,029, it is apparent to those of ordinary skill in the art that the original file may have a format other than the file format(s) described in U.S. patent application Ser. No. 12/697,029. For example, the original file may be an alternate encoding of a virtual machine or virtual application, a data file, an xml file, and the like. For ease of illustration, the original file is described below as implementing the virtual application 110. However, as is apparent to those of ordinary skill in the art, the original file may implement other applications, including applications requiring installation on the client computing device 9 (see
Profiling generally refers to a method of analyzing an application (e.g., the virtual application 110) to determine usage statistics. A profile or transcript of the application contains information about a single execution of the application such as the order of the page access, and the time spent in each transition between pages. The transcript may be stored in a transcript file 125 (see
An application (e.g., the virtual application 110) may implement one or more processes that are selectively executed as the application executes. As the virtual application 110 executes, it implements one or more such processes that each access the original file (e.g., the xlayer file 300) to obtain information about the virtual application 110. This information includes, but is not limited to, virtual environment settings, virtual filesystem information, virtual registry information, and the like. This information resides in various locations within the original file (e.g., the xlayer file 300). Threads and processes spawned by the virtual application 110 as it executes may be treated as separate instances and merged together in the same transcript file in a manner similar to that used to merge multiple transcript files together (discussed below).
A profiling process 700 described below may be used to determine an order in which blocks of data (pages) stored in a file are accessed by an executing application. For ease of illustration, the profiling process 700 will be described as being performed with the virtual application 110. However, as is apparent to those of ordinary skill in the art, the profiling process 700 may be performed with other types of applications, including applications requiring installation on the client computing device 9 (see
The profiling process 700 profiles usage of the virtual application 110 to generate transcript files (such as the transcript file 125 illustrated in
As mentioned above, the Sandbox Manager 134 (see
The information stored in the transcript files (generated by the profiling process 700) is then used to divide the original file into pages that are loaded onto the server computing device 7 for download to the client computing device 9. The server computing device 7 streams the xsequence files to the client computing device 9 through the Client Application 132 and the Sandbox Manager 134 that together download and execute the pages.
The profiling process 700 described herein may be used to perform accurate and low-overhead profiling of a virtual application's access to an underlying xlayer file. Depending upon the implementation details, the profiling process 700 may include the use of per-thread data structures and named-pipes to communicate to the directing process 129 that by the executing virtual application 110 has requested access to raw block level data (stored in the original file, e.g., the xlayer file 300). The term “per-thread data structure” refers to a data structure corresponding to a single thread. Thus, a separate per-thread data structure may be created for each thread used by an application (e.g., the virtual application 110). A ThreadDiscriminate value is sent to the Sandbox Manager 134 by the virtual runtime engine 131 when a thread is created. The ThreadDiscriminate value is an entry point discriminator for the thread accessing the xlayer file. An example method of generating the ThreadDiscriminate value is described below.
The profiling process 700 is performed using a PseudoPid value and a PseudoTid value. The PseudoPid value and the PseudoTid value are determined by the virtual runtime engine 131.
The PseudoPid value is a unique process identifier of the application process accessing the original file (e.g., the xlayer file 300). Because operating system allocated process identifiers (“Pid” values) can be recycled and reused, a unique identifier (the PseudoPid value) is generated for each process. The PseudoPid value may be generated by performing a hash function using the operating system allocated Pid value and the current system time as input parameters. For example, the following pseudo code may be used to generate the PseudoPid value:
PseudoPid=Hash(GetCurrentProcessId( ),GetSystemTime( )).
The hash function performed may be a 32-bit “good” hash function. Those of ordinary skill in the art are familiar with good hash functions. Therefore, such functions will not be described herein.
Furthermore, because operating system allocated thread identifiers (“Tid” values) can be recycled and reused, a unique identifier (the PseudoTid value) is generated for each thread. The PseudoTid value may be generated by performing a hash function using the operating system allocated Tid value and the current system time as input parameters. For example, the following pseudo code may be used to generate the PseudoTid value:
PseudoTid=Hash(GetCurrentThreadId( ),GetSystemTime( ))
The hash function performed may be a 32-bit “good” hash function.
Thus, there may be three different scopes for the profiling process 700: Session, Process, and Thread. Session scope includes the profiling context of a single execution of the virtual application 110. As is apparent to those of ordinary skill in the art, during execution, the virtual application 110 may include multiple processes and multiple threads.
Process scope refers to the lifetime of a single process instance (given a unique PseudoPid value, described below) within a session. If two or more virtualized application files are launched more than once, a separate process for each launched file (each having a different PseudoPid value) and a separate process contexts for each launched file are created (or recorded) within a transcript. If the same virtualized application file is launched more than once, execution statistics recorded for each process can be aggregated using the name of the virtualized application file (or other identifier) to identify execution statistics associated with the same virtualized application file.
Thread scope refers to the lifetime of a single thread instance (given a unique PseudoTid value, described below) within a process (and therefore session). Different threads may be identified in the transcript using the ThreadDiscriminate value (described below). If a thread with the same ThreadDiscriminate value is launched more than once, execution statistics recorded for the thread (having that ThreadDiscriminate value) can be aggregated using the ThreadDiscriminate value (or other identifier) to identify execution statistics associated with the same thread or similar threads. As is apparent to those of ordinary skill in the art, because the ThreadDiscriminate value stores an identifier (e.g., a file name) of an entry point module (e.g., a Dynamic Link Library “dll” file, an executable file, and the like) and a relative offset within the module whereat execution of the thread began, different threads may have the same ThreadDiscriminate value.
Each time the virtual application 110 accesses the original file, access information (including one or more execution statistics) is recorded. For example, each time the virtual application 110 accesses the original file (e.g., the xlayer file 300), the Sandbox Manager 134 may record a PseudoTid value, an xlayerId value, an AccessOffset value, an AccessBytes value, a TickCount value, and flags. This access is associated with the PseudoPid value of the process that created the thread.
The xlayerId value is an identifier of the xlayer file 300. The xlayerId value may be a hash (e.g., a “good” hash) of the path of the xlayer file 300. The AccessOffset value is an offset in bytes of the portion of the xlayer file 300 accessed. The AccessBytes value is a size in bytes of the portion of the xlayer file 300 accessed. The TickCount value is a current Operating System (“OS”) tick count at the time the xlayer file 300 is accessed. The flags may include a Blocked value implemented as Boolean field. The Blocked value indicates whether the virtual runtime engine 131 and/or the virtual application 110 is/are blocked from further execution of the page for which access is requested.
During performance of the profiling process 700, data is recorded for each process over its lifetime. Thus, each process is tracked over the duration of its lifetime. Optionally, shutdown notifications may not be tracked.
During performance of the profiling process 700, data is recorded for each thread over its lifetime. Thus, each thread is tracked over the duration of its lifetime. Optionally, thread-shutdown notifications may not be tracked.
When the profiling process 700 is performed, it may be useful to aggregate statistics collected for the same application code path. A thread discriminate (the ThreadDiscriminate value) is used to identify a code path by its starting point. The ThreadDiscriminate value may be obtained by performing a hash function using the name of the entry point module (e.g., a file name) and the entry point relative offset within the module as input parameters. Optionally, the name of the entry point module may include the file path. The hash function performed may be a 32-bit “good” hash function. For example, if the entry point for the thread was in a file named “myapplogic.dll,” and at an offset of 0x10025, the hash function is performed on the bytes of the string “myapplogic.dll” using the offset (0x10025) as a seed value. The ThreadDiscriminate value for any xlayer access from this thread is set to the resulting value generated by the hash function. For example, the following pseudo code may be used to generate the ThreadDiscriminate value:
The ThreadDiscriminate value may be stored in a per-thread data structure. The following is a non-limiting example of such a structure:
By way of a non-limiting example, the ThreadDiscriminate value may be stored in a per-thread data structure (e.g., the structure “CVmTlsData”) using dynamic thread-local-storage mechanisms via Win32 ::TlsGetValue and ::TlsSetValue APIs. As is apparent to those of ordinary skill in the art, thread-local-storage mechanisms refer to storing data in a thread-local-storage location that is accessible only by a thread associated with the thread-local-storage location. The ThreadDiscriminate value and/or the PseudoTid value for a particular thread may be stored in the thread-local-storage location associated with the particular thread. The thread may look up the ThreadDiscriminate value and/or the PseudoTid stored in the thread-local-storage location and provide such information to the virtual runtime engine 131, which may in turn, communicate the information to the directing process 129.
The structure may be initialized at thread creation time. By way of a non-limiting example, hooking the CreateThread system call may be used to initialize the structure at thread creation time. In other words, an instance of the structure “CVmTlsData” may be created in response to each detection of the CreateThread system call by the hook on the CreateThread system call. Hooking the CreateThread system call is a technique known to those of ordinary skill in the art and will not be described in detail.
When an application thread is created, a PseudoTid value and ThreadDiscriminate value are determined as described above. Then, memory for the structure “CVmTlsData” is allocated, and the structure “CVmTlsData” is saved in thread-local-storage. By way of a non-limiting example, the structure may be saved in thread-local-storage via the Win32 ::TlsSetValue API. By way of another non-limiting example, the following pseudo code may be used to create a per-thread data structure, which in this example, is the structure “CVmTlsData.”
After the PseudoTid value and the ThreadDiscriminate value are stored in the per-thread data structure (e.g., the structure “CVmTlsData”), each access to the original file (e.g., the xlayer file 300) during execution of the virtual application 110 is recorded by the Sandbox Manager 134 in a transcript file 125 (see
Named pipe communication may be used to provide communication between the virtual runtime engine 131 and the directing process 129 (implemented by the Sandbox Manager 134). Thus, the directing process 129 may “listen” to the virtual runtime engine 131 over at least one named pipe connection 127 illustrated in
In first block 710, the virtual runtime engine 131 receives an instruction from the Sandbox Manager 134 to execute the virtual application 110 in profiling mode. As will be described in more detail below, the virtual runtime engine 131 may also receive information (e.g., the SessionId value, and the path to the xlayer file) from the Sandbox Manager 134.
Then, in block 715, the virtual runtime engine 131 begins execution of the virtual application 110 in profiling mode.
In block 717, the virtual runtime engine 131 connects to the named pipe of the Sandbox Manager 134 to form the named pipe connection 127.
In block 718, the virtual runtime engine 131 constructs a message containing the SessionId value received from the Sandbox Manager 134 in block 710 and optionally other information (e.g., the Pid value, the PseudoPid value, a ProcessName value, and a Process Name Length value). This message signals the start of a new process. The virtual application 110 is associated with a process that may launch one or more additional processes. Thus, the first message received by the Sandbox Manager 134 signals the start of the virtual application 110. The Pid value in the first message is associated with the virtual application 110 itself. By way of a non-limiting example, the Pid value may be obtained using a function named “::GetCurrentProcessId( ).” As mentioned above, the PseudoPid value may be obtained using a hash function. By way of a non-limiting example, the ProcessName value may be obtained using a function named “GetStartupExecutableName( ).” The ProcessName value is a file name of the entry point executable file of the process. For example, the ProcessName value may be the filename of the original file (e.g., the xlayer file 300). However, this is not always the case. The ProcessName value may not be the filename of the original file (e.g., the xlayer file 300). The ProcessName Value may be used to merge statistics across processes having the same name.
The following structure named “SProcessConnectMessage” may be used to construct the message containing the new process information.
In the above pseudo code, the Name variable stores the ProcessName value. The message constructed in block 718 may inform listeners (e.g., the directing process 129) that a new process is starting. The message may be sent by the virtual runtime engine 131 to the Sandbox Manager 134 once for each PseudoPid value.
Then, in block 719, the virtual runtime engine 131 sends the message constructed in block 718 to the directing process 129 implemented by the Sandbox Manager 134. At this point, communication between the Sandbox Manager 134 and the virtual runtime engine 131 has been properly initialized, and messages including statistics may be sent from the virtual runtime engine 131 to the Sandbox Manager 134 for recordation in a transcript file.
In next block 720, all read operations (e.g., IStream::Read operations) performed by the virtual application 110 with respect to the original file (e.g., the xlayer file 300) are monitored. This may be achieved by abstracting access to the original file through the standard IStream interface, which is used to read data from the original file. The IStream interface is configured to read from and write data to stream objects. Those of ordinary skill in the art are familiar with reading data from a file (such as the xlayer file 300) and this process will not be described in detail.
In decision block 725, the virtual runtime engine 131 determines whether a read operation is being performed on the original file (e.g., the xlayer file 300) or execution of the virtual application 110 has terminated. The decision in decision block 725 is “ACCESS” when a read operation has been detected by the virtual runtime engine 131. The decision in decision block 725 is “TERMINATED” when the virtual runtime engine 131 detects execution of the virtual application 110 has terminated.
A method of detecting when execution of the virtual application 110 has terminated is described below. When the decision in decision block 725 is “TERMINATED,” the method 700 terminates.
When the decision in decision block 725 is “ACCESS,” in decision block 755, the virtual runtime engine 131 determines whether this is the first time the thread associated with the PseudoTid has accessed the xlayer file. The data stored in the per-thread data structures (e.g., the structures “CVmTlsData” described above) may be used to determine whether this is the first time the thread associated with the PseudoTid value has accessed the original file. The decision in decision block 755 is “YES” when this is the first time the thread associated with the PseudoTid value has accessed the xlayer file. Otherwise, the decision in decision block 755 is “NO” when this is not the first time the thread associated with the PseudoTid value has accessed the xlayer file.
When the decision in decision block 755 is “NO,” the virtual runtime engine 131 advances to block 730.
When the decision in decision block 755 is “YES,” in block 740, the virtual runtime engine 131 stores the new thread information (e.g., the PseudoTid value, and the ThreadDiscriminate value). In block 740, both of the PseudoTid value and the ThreadDiscriminate value may be stored in the per-thread data structure (e.g., the structure “CVmTlsData”). By way of a non-limiting example, these values may be obtained via the Win32 ::TlsGetValue API.
Then, in block 760, the virtual runtime engine 131 constructs a message containing the new thread information (e.g., the PseudoTid value and the ThreadDiscriminate value). The message constructed in block 760 is sent by the virtual runtime engine 131 to the Sandbox Manager 134 once for each PseudoTid value. The following structure named “SThreadStartedMessage” may be used to construct the message containing the new thread information.
The variable named “Discriminate” in the above pseudo code stores a ThreadDiscriminate value that is sent when a new thread is created. The ThreadDiscriminate value is an entry point discriminator for the thread accessing the original file (e.g., the xlayer file 300).
In block 765, the virtual runtime engine 131 sends the message constructed in block 760 to the Sandbox Manager 134. Then, the virtual runtime engine 131 advances to block 730.
In block 730, an offset value indicating where in the original file the read operation started and a length value indicating an amount of the original file read are recorded. The offset may be implemented as a 64-bit value. The PseudoTid value is also recorded. Further, the current process tick count is recorded as the TickCount value.
In next block 750, a message including the information recorded above (e.g., the PseudoTid value, the xlayerId value, the AccessOffset value, the AccessBytes value, the TickCount value, and flags) is constructed. The message also includes an xlayerId value that is an identifier of the original file (e.g., the xlayer file 300). By way of a non-limiting example, the message may be implemented using the following data structure (named “SFeedbackStatsMessage”):
In the data structure named “SFeedbackStatsMessage,” a flags member may store the Blocked value (discussed above).
In summary, the Sandbox Manager 134 sends the SessionId value and the path of the original file to the virtual runtime engine 131. The xlayerId value may be determined by performing a hash function (e.g., a “good” hash function) on the path. When a new process accesses the original file, the virtual runtime engine 131 sends the SessionId value, the Pid value, the PseduoPid value, the ProcessName value, and the Process Name Length value to the Sandbox Manager 134. The Sandbox Manager 134 may use this information to associate processes with the session identified by the SessionId value. Because two different sessions launched under the directing process 129 (see
When a new thread accesses the original file, the virtual runtime engine 131 sends the PseudoTid value and the ThreadDiscriminate value to the Sandbox Manager 134. For each read operation performed by the virtual application 110 on the original file, the virtual runtime engine 131 sends the PseudoTid value, the xlayerId value, the AccessOffset value, the AccessBytes value, the TickCount value, and flags to the Sandbox Manager 134. The Sandbox Manager 134 may use this information to associate each read operation with the original file identified by the xlayerId value and the thread identified by the PseudoTid value. The xlayerId value is used because a single session may include the execution of one or more application file in addition to the original file.
Then, in block 752, the virtual runtime engine 131 sends the message “SFeedbackStatsMessage” to the directing process 129. Then, the virtual runtime engine 131 returns to block 720.
The following pseudo code provides a non-limiting example of an implementation of the blocks 755, 740, 760, 765, 730, 750, and 752 of the profiling process 700 described above.
If the virtual application 110 initiates a child process, the virtual runtime engine 131 will perform block 718 using the same SessionId received in block 710. The named pipe connection 127 created in block 717 is used for child processes.
It may be beneficial if the profiling process 700 has as little affect on the running application as possible. In such implementations, communication mechanisms may be very fast and invisible to the running application itself. Using the named pipe of the Sandbox Manager 134 to provide communication between the virtual runtime engine 131 and the directing process 129 may provide such benefits. Thus, the messages sent in blocks 719, 752, and 765 may be sent over the named pipe connection(s) 127.
On the WINDOWS® platform, named pipes are implemented with multiple instance support. Thus, multiple clients (e.g., virtual runtime engines) can communicate with a single named pipe server (implemented by the Sandbox Manager 134), with each client having an isolated connection to the same named pipe. In other words, each process (even processes started by the process associated with the virtual application) will connect separately to the named pipe server. On the named pipe server (implemented by the Sandbox Manager 134), multiple connections are handled via a unique connection handle for each client (e.g., virtual runtime engine). Thus, each virtual runtime engine running a virtual application can connect to the name pipe of the same Sandbox Manager 134 and send statistics to the single Sandbox Manager.
One named pipe connection per process may be used. In such implementations, access to the named pipe from multiple threads may be serialized within a process via a critical section. This may impact performance of the virtual application 110 slightly. However, the size of the data being sent is small and named pipe communication is inherently fast. Thus, this method may provide satisfactory performance.
In first block 810, the Sandbox Manager 134 obtains information (e.g., command line parameters) to send to the virtual runtime engine 131 along with a command to execute the virtual application 110 in profiling mode. By way of a non-limiting example, the SessionId may have been obtained via a /XExecutionSession command line parameter.
In block 815, the Sandbox Manager 134 sends the information and a command to execute the virtual application 110 in profiling mode to the virtual runtime engine 131. The virtual runtime engine 131 knows it was started by a parent process (the directing process 129 of the Sandbox Manager 134). With that information, the virtual runtime engine 131 initiates the named pipe communication with the Sandbox Manager 134 to send messages (including those with execution statistics) to the directing process 129.
The execute command and the SessionId value are received by the virtual runtime engine 131 in block 710 of the profiling process 700 illustrated in
As discussed above, while the virtual application 110 is executing in profiling mode, the Sandbox Manager 134 may receive messages from the virtual runtime engine 131 and generate events in response to those messages.
In decision block 820, the Sandbox Manager 134 determines whether it has received a message from the virtual runtime engine 131 or execution of the virtual application 110 has terminated. If a message is received, the decision in decision block 820 is “RECEIVED” and the Sandbox Manager 134 advances to decision block 825. Otherwise, if the virtual runtime engine 131 stops executing the virtual application 110 before a message is received, the decision in decision block 820 is “TERMINATED” and the method 800 terminates.
When the virtual runtime engine 131 detects that a process is accessing the original file (e.g., the xlayer file 300) for the first time, the virtual runtime engine 131 sends a message (optionally implemented using a structure name “SProcessConnectMessage”) to the directing process 129. In decision block 825, the Sandbox Manager 134 determines whether the message received in block 820 indicates a process is accessing the original file (e.g., the xlayer file 300) for the first time. The decision in decision block 825 is “YES” when the message received in block 820 indicates a process is accessing the original file (e.g., the xlayer file 300) for the first time. For example, the decision in decision block 825 is “YES” when the message received was constructed in block 718 of the profiling process 700 illustrated in
When the decision in decision block 825 is “YES,” in block 830, the Sandbox Manager 134 generates a ProcessStarted event. In block 835, Sandbox Manager 134 records information included in the message (e.g., the SessionId, PseudoPid, and ProcessName values). This information may be recorded in the transcript file 125 (see
When the decision in decision block 825 is “NO,” in decision block 840, the Sandbox Manager 134 determines whether the message received in block 820 includes statistics to be stored in the transcript file 125 (see
When the decision in decision block 840 is “YES,” in block 845, the Sandbox Manager 134 generates an ExecutionStatistic event. Then, in block 850, the statistics included in the message are stored in the transcript file 125. Then, the Sandbox Manager 134 advances to decision block 870.
When the decision in decision block 840 is “NO,” in decision block 855, the Sandbox Manager 134 determines whether the message received in block 820 indicates a thread is accessing the original file (e.g., the xlayer file 300) for the first time. The decision in decision block 855 is “YES” when the message received in block 820 indicates a thread is accessing the original file for the first time. Otherwise, the decision in decision block 855 is “NO.”
When the decision in decision block 855 is “YES,” in block 860, the Sandbox Manager 134 generates a ThreadStarted event. Then, in block 865, the PseudoTid and ThreadDiscriminate values are stored in memory. This information may be recorded in the transcript file 125 (see
When the decision in decision block 855 is “NO,” the Sandbox Manager 134 advances to decision block 870.
In decision block 870, the Sandbox Manager 134 determines whether the virtual runtime engine 131 has stopped executing the virtual application 110 (and therefore, no additional statistics will be generated for the virtual application 110). The decision in decision block 870 is “NO” when the virtual runtime engine 131 has stopped executing the virtual application 110. Otherwise, the decision in decision block 870 is “YES.”
When the decision in decision block 870 is “NO,” the method 800 terminates.
When the decision in decision block 870 is “YES,” the Sandbox Manager 134 returns to decision block 820.
The information received in the messages constructed in block 750 of the profiling process 700 illustrated in
The Sandbox Manager 134 may include a dictionary accessible by the directing process 129. The directing process 129 may use the dictionary to associate all subsequent messages (e.g., implemented using the structures named “SThreadStartedMessage” and “SFeedbackStatsMessage”) with the correct PseudoPid value. The dictionary may be keyed by a connection handle to a structure storing the PseudoPid value, Pid value, and Process Name value. The following data structure (named “SPipeConnection”) is an example of a data structure that may be used to implement the dictionary:
As described above, the information stored in the class defined by the pseudo code above is received by the Sandbox Manager 134 (from the virtual runtime engine 131) in the message constructed in block 718 of the profiling process 700 illustrated in
The dictionary lookup may be hidden by the implementation of the .NET System.IO.Pipes.NamedPipeServerStream class, which may have been used to perform the named pipe communication. This class uses IO Completion Ports to schedule asynchronous pipe reads from the pipe clients (e.g., the virtual runtime engine 131) in the virtual application processes. An asynchronous named pipe completion routine may be responsible for determining the type of message received, reading the message, and calling back into the listening code of the directing process 129 with the appropriate callbacks. Possible callbacks are: SignalNewProcess (which is called when a new process is started in the virtual application 110); SignalNewThread (which is called when a new thread is started within a virtual application process); and SignalXLayerAccess (which is called when access to the original file has been requested by a particular thread within the virtual application process). How this data provided by these callbacks is handled is described below.
The following pseudo code provides a non-limiting example of a server-side named pipe completion routine. Portions of the routine may be performed in blocks 820, 825, 840, and 855.
As mentioned above, the transcript file 125 generated by the profiling process is used to determine a predictive application access model that is used to determine an order in which to download blocks of data (e.g., portions of the xlayer file 300) to the client computing device 9. When used to stream blocks of data or pages to the client computing device 9, the access model is referred to as a streaming model.
The server computing device 7 provides applications to the client computing device 9 on a “self-serve” basis (i.e., a user operating the client computing device 9 may select any of the applications provided by the server computing device 7 for download at anytime). After the user has selected an application for download and execution, the server computing device 7 downloads or streams the selected application to the client computing device 9. Multiple client computing devices (e.g., the computing devices 9 and 11) may select applications for download at the same time.
Because training and building streaming models is a computationally intensive process and relies on proprietary technologies, it may be preferable to perform this process on a centralized server (e.g., the server computing device 7 or another computing device connected thereto). The access model may be generated using machine learning techniques that require training. The training of streaming models requires information about the program's access patterns under realistic and/or actual use. Thus, generating “transcripts” via profiling is a task best performed manually, by an application publisher or test users.
As described above, the Sandbox Manager 134 may be configured to profile an application downloaded from a web page (e.g., via the plug-in 136). Transcript files generated by the Sandbox Manager 134 may then be uploaded to the server computing device 7 (or another computing device connected thereto), which automatically generates and distributes a streaming model (e.g., the streaming model 122 illustrated in
As mentioned above, the authoring tool 170 allows application developers and publishers to virtualize an application and publish it to the web. The result of this process is one or more executable files or xlayer files (e.g., a file named “application_p.xlayer”) residing on the server computing device 7. As described in U.S. patent application Ser. No. 12/695,107, these files can be downloaded and executed from the web via the plug-in 136 and the Sandbox Manager 134. If the plug-in 136 is executing on a computing device (e.g., the computing device 11) that is also executing the authoring tool 170, optionally, when the layer file is published to the server computing device 7, the xlayer file 300 will also be copied to the local cache 139 (see
An upper portion of
Returning to
The profiling tool 169 may be implemented as a “Profile” link in the online management panel. When the publisher clicks on the “Profile” link, a panel launcher page may be displayed that includes a query string parameter (e.g., “&profile=”) set to a value that indicates the application should be profiled. The page may pass the query string parameter (e.g., “&profile=”) to an iframe that renders the panel launcher page. The panel launcher page renders a javascript call to the xrfw.go( ) method that sets the query string parameter (e.g., “&profile=”) equal to “TRUE.”
In block 1115, the server computing device 7 receives an instruction to download the virtual application 110 to the client computing device 9. For example, this instruction may be received in response to a user clicking on a launch button on the panel launcher page.
In block 1120, the Sandbox Manager 134 downloads and executes the virtual application file 140 in a profile mode. When executing an application in profile mode, the Sandbox Manager 134 instructs the virtual machine (e.g., the virtual runtime engine 131) to provide execution statistics (e.g., via messages implemented using the structure named “SFeedbackStatsMessage”).
In block 1125, the Sandbox Manager 134 receives messages from the virtual runtime engine 131 and handles events generated by the virtual runtime engine 131 executing the application as the application is running. The method 800 (described above) may be performed in blocks 1120 and 1125.
By way of non-limiting examples, the events may include a ProcessStarted event, a ThreadStarted event, an ExecutionStatistic event, and an ApplicationEnded event. A ProcessStarted event may be identified by the Sandbox Manager 134 when the directing process 129 receives a message from the virtual runtime engine 131 indicating a process has requested access to the xlayer file for the first time. As explained above, such a message may be sent by the virtual runtime engine 131 in block 719 of the profiling process 700 illustrated in
An ExecutionStatistic event may be identified by the Sandbox Manager 134 when the directing process 129 receives a message including access statistics. As explained above, such a message may be sent by the virtual runtime engine 131 in block 752 of the profiling process 700 illustrated in
In next block 1130, the Sandbox Manager 134 detects that an ApplicationEnded event has been triggered.
Then, in block 1135, the Sandbox Manager 134 combines the collected execution statistics into a single combined transcript (e.g., the combined transcript “CT” illustrated in
In block 1140, the Sandbox Manager 134 uploads the combined transcript to the server computing device 7. Arrow “A4” in
<AppInternalName>/<AppVersion>_<LayerRevision>/<AppInternalName>_p.xlayer.
In block 1145, the server computing device 7 receives the uploaded combined transcript and associated application identifier.
In block 1150, the server computing device 7 resolves the application identifier to determine which application and version created the transcript. The server computing device 7 includes an application library database 1151 illustrated in
In block 1155, the server computing device 7 saves the combined transcript in a predetermined location on the filesystem. In block 1155, the binary data contained in the transcript may be written to a file on the server computing device 7 using a standard .NET BinaryWriter. Each transcript is named using a unique GUID. Files containing the transcripts may be stored at the following location, relative to the web root:
In block 1160, the server computing device 7 requests a build of a new streaming model for the xlayer file identified in block 1150. Arrow “A5” in
Application publishers can use the profiling tool 169 to request subsequent model builds as needed (e.g., by adding a request to the ModelRequest table illustrated in
In block 1165, the request is processed and a streaming model (e.g., the streaming model 122 illustrated in
Then, in block 1310, the model building server 8 copies all transcript files associated with the xlayer file identified in block 1150 into the same directory in the filesystem of the model building server 8. For example, all files stored in a first directory named
“\\<SpoonServer>\LibraryResources\Layers\Transcripts\<AppInternalName>\<AppVersion>_<LayerRevision>\<AppInternalName>_p.xlayer\” may be copied to a second directory named
“\\<BuildServer>\LibraryResources\Layers\Transcripts\<AppInternalName>\<AppVersion>_<LayerRevision>\<AppInternalName>_p.xlayer\.” Arrow “A6” in
When the copying is finished, in block 1320, the model building server 8 tries to delete the original transcript files (stored in the first directory).
In decision block 1325, the model building server 8 determines whether the transcript files have been successfully deleted. If the attempt to delete a particular transcript file fails, the model building server 8 concludes the transcript is still being written and the decision in decision block 1325 is “NO.” Then, in block 1330, the copy stored in the second directory is deleted. These copy and delete actions may use the standard .NET File class.
In block 1335, the model building server 8 then performs a method 1600 (illustrated in
“\\<BuildServer>\LibraryResources\Layers\<AppInternalName>\<AppVersion>_<LayerRevision>\xstream\0\.”
In block 1340, referring to
Referring to
Returning to
At this point, the streaming models may be distributed to other computing devices connected to the model building server 8 and/or the network 10.
In decision block 1415, for each streaming model identified in block 1410, the querying server computing device determines whether the streaming model is already stored in the filesystem of the querying server computing device. The decision in decision block 1415 is “NO” when the streaming model is already stored in the filesystem of the querying server computing device. Otherwise, the decision in decision block 1415 is “YES” when the streaming model is not already stored in the filesystem of the querying server computing device.
When the decision in decision block 1415 is “YES,” in block 1425, the querying server computing device waits for a period of time and then returns to block 1410. In block 1425, the querying server computing device may wait for a predetermined amount of time, a randomly selected amount of time, or a combination thereof.
When the decision in decision block 1415 is “YES,” in block 1430, the streaming model is copied from a server computing device on which the streaming model is stored to the querying server computing device. Thus, when a record is found in the ServerXFile table 1168 that the querying server computing device does not yet have stored in its filesystem (according to the ServerXFile table), a copy is initiated. In other words, the querying server computing device (e.g., the server computing device 6) may use the ServerXFile table 1168 to locate model files stored on other server computing devices (e.g., the server computing device 7) and copy those files to the local filesystem of the querying server computing device. The files located in this manner may be copied from the third directory to a fourth directory named
“\\<SpoonServer>\LibraryResources\Layers\<AppInternalName>\<AppVersion>_<LayerRevision>\xstream\0\.” In other words, each server computing device is responsible for distributing streaming model files by copying those files onto their own filesystem.
In decision block 1435, for each streaming model copied in block 1430, the querying server computing device determines whether the streaming model was copied to the filesystem of the querying server computing device successfully. The decision in decision block 1435 is “YES” when the streaming model was copied to the filesystem of the querying server computing device successfully. Otherwise, the decision in decision block 1435 is “NO” when the streaming model was not copied to the filesystem of the querying server computing device successfully.
When the decision in decision block 1435 is “NO,” the querying server computing device may return to block 1430 to retry the copy operation.
When the decision in decision block 1435 is “YES” (the copy operation has completed successfully), in block 1440, the querying server computing device (e.g., the server computing device 6) adds a new record to the ServerXFile table 1168, indicating that the streaming model is now stored on that particular server computing device. Thus, after a server computing device (e.g., the server computing device 6) copies streaming models onto its filesystem, the server computing device records this in the database illustrated in
In optional block 1515, the Client Application 132 communicates that the user would like to execute a virtual application to the Sandbox Manager 134.
In block 1520, the Sandbox Manager 134 executing on the client computing device 9 (which may be located somewhere across the world from the server computing device 7) requests the virtual application the user indicated he/she would like to execute in block 1510.
In block 1530, the server computing device that services the request (e.g., the server computing device 7) will query the ServerXFile table 1168 to determine which server computing device(s) is/are storing the streaming model for the application requested in block 1520. For example, in block 1520, the Sandbox Manager 134 may request an application named “App1.xlayer” for which a streaming model named “Model1” was created. In this example, in block 1530, the server computing device 7 may query the ServerXFile table 1168 to determine which server computing device(s) are storing the streaming model named “Model1” associated with the application requested in block 1520.
Then, in block 1535, the server computing device that services the request (e.g., the server computing device 7) selects one of the server computing device(s) storing the streaming model requested in block 1520 from which to download the streaming model. Load balancing techniques or a random selection algorithm may be used to select a server computing device in block 1535. For example, in block 1535, load balancing techniques or a random selection algorithm may be used to select a server computing device (e.g., the “publicserver1” computing device) from which the “Model1” model file may be downloaded to the client computing device 9.
Then, in block 1540, the method 900 (illustrated in
Among other data, each transcript includes information identifying transitions between pages (“page transitions”). To combine the transcripts, in block 1610, the page transitions are broken down and combined. For example, referring to
After the individual transcripts have been combined to form the combined transcript “CT,” in block 1620, the combined transcript “CT” is used to create a directed graph structure “SD.” The directed graph structure “SD” includes states and transitions between states. The states are merely end points (or nodes) for the transitions. Each transition is associated with one or more pages. The directed graph structure “SD” illustrated in
In the directed graph structure “SD,” linear sequences of transitions (i.e., sequences of transitions without any branches) in the combined transcript “CT” are reduced or simplified into a single transition. For example, the linear sequence of transitions that includes the following transitions (P6P4P5), is simplified into the single transition TRANS-1 (or S1S2) that is associated with the pages P6, P4, and P5. The weight of transition TRANS-1 is the same as the weight of each of the transitions (P6P4P5). The transition TRANS-2 (or S2S3) is associated with the pages P5 and P1. The transition TRANS-3 (or S2S4) is associated with the pages P5 and P2. The transition TRANS-4 (or S3S5) is associated with the pages P1 and P3. The transition TRANS-5 (or S4S5) is associated with the pages P2 and P3.
When the states and transitions are created by combining the transitions in the combined transcript “CT,” a timestamp delta valued is calculated for each page. The timestamp delta is the difference between the start time of the transcript (e.g., a time at which execution of the virtual application began) and the timestamp recorded for the page in the transcript. Then, an average timestamp delta value is calculated for the pages associated with each of the transitions between states. This average is recorded for each transition between states as a TickDelta member.
The directed graph structure “SD” describes data access by the application while executing and may be stored in one or more state objects. Referring to
Referring to
The directed graph structure “SD” (stored by the one or more state objects) may include loops or cycles. By way of a non-limiting example, the directed graph structure “SD” may be a directed acyclic graph (“DAG”). However, this is not a requirement. As mentioned above, in the directed graph structure “SD,” the transitions (or “edges”) are labeled with a set of pages or data blocks.
Transition data structures that are too large may be divided into two or more separate transition data structures. For example, transition data structures that have a large value stored in the TickDelta member, or have a large number of pages stored in the page sequence member may be subdivided into two or more separate transition data structures.
In block 1630, the pages identified in the page sequence members of the transition data structures are encoded in one or more xsequence files. The xsequence files each belong to one of three categories: initial execution (or prefetch) xsequence files, sequence xsequence files, and rest xsequence files. For example, the xsequence files 1182 of the streaming model 122 illustrated in
As mentioned above, the virtual application 110 may be streamed from the server computing device 7 without using a special streaming protocol by encoding the xlayer file into smaller xsequence files. In particular embodiments, the virtual application 110 may be streamed from the server computing device 7 using well-known download protocols, such as HTTP, FTP, SMB, and the like. Which category a particular page is encoded into is based upon the directed graph structure “SD” which predicts when the page may be used by a virtual application as it is executing as xsequence files are concurrently being downloaded.
In block 1710, the pages included in the initial execution xsequence file may be identified by determining how close in time (which may be determined using the time stamp for the page) each page is to an origin or first transition data structure listed in the list of transitions in a first state object in the directed graph structure “SD.” Then, only the pages accessed within a predetermined amount of time from the first transition data structure may be selected for inclusion in the initial execution xsequence file(s). Alternatively, a predetermined number of pages accessed within a least amount of time from the first transition data structure may be selected for inclusion in the initial execution xsequence file(s). By way of another non-limiting example, a predetermined percentage of pages including those that were accessed within the least amount of time from the first transition data structure may be selected for inclusion in the initial execution xsequence file(s).
The following pseudo code provides a non-limiting example of a method of encoding the pages in the initial execution xsequence file using the directed graph structure “SD.”
In the pseudo code above, the function named “IsChildOf” determines whether a second state (stored in variable named “s”) is reachable from the first state (stored in a variable named “OriginState”). In other words, the function named “IsChildOf” determines whether a path exists in the directed graph structure “SD” from the first state to the second state. In
In block 1715, the model building server 8 writes the pages identified in block 1710 to the initial execution xsequence file(s).
In block 1720, the model building server 8 identifies pages for inclusion in the sequence xsequence files. For example, in block 1720, the model building server 8 may identify the pages (identified in the page sequence members of the transition data structures) that were not written to the initial execution xsequence file(s) in block 1715.
In decision block 1725, the model building server 8 decides whether to create a sequence xsequence file for each transition data structure that was not used to populate the initial execution xsequence file or to reduce the number of sequence xsequence files created by combining the transition data structures that were not used to populate the initial execution xsequence file. The decision in decision block 1725 is “YES” when the model building server 8 decides to combine the transition data structures that were not used to populate the initial execution xsequence file. Otherwise, the decision in decision block 1725 is “NO” when the model building server 8 decides to create a sequence xsequence file for each transition data structure that was not used to populate the initial execution xsequence file.
When the decision in decision block 1725 is “YES,” in block 1730, the model building server 8 combines at least a portion of the transition data structures that were not used to populate the initial execution xsequence file. For example, in block 1730, the model building server 8 may combine similar transitions into a single transition to be stored in a single sequence xsequence file. By way of another example, a threshold file size may be used to identify sequence xsequence files having a size less than the threshold file size. The sequence xsequence files identified may be combined into one or more larger sequence xsequence files. The following pseudo code provides a non-limiting example of a method of combining transitions into a single transition for storage in a single sequence xsequence file.
Next, in block 1735, the pages identified in block 1720 are stored in sequence xsequence files. As mentioned above, a sequence xsequence file may be created for each transition data structure that was not used to populate the initial execution xsequence file and used to store the pages of the transition data structure for which the sequence xsequence file was created. Optionally, the number of transition data structures that were not used to populate the initial execution xsequence file may be reduced by combining two or more of them before creating the sequence xsequence files.
The sequence xsequence files store the pages that were accessed by the application as it executed. Thus, the sequence xsequence files store all of the pages appearing in all of the transcripts.
In block 1740, the model building server 8 identifies pages for inclusion in the rest xsequence files. In block 1740, the model building server 8 identifies pages that did not appear in every transcript for inclusion in the rest xsequence files. For example, referring to
While a rest xsequence file may store one or more pages also stored in one of the sequence xsequence files, this is not a requirement. Optionally, in decision block 1742, the model building server 8 may decide whether to search the sequence xsequence files for each page and only write pages not found in the sequence xsequence files to the rest xsequence file(s). The decision in decision block 1742 is “YES” when the model building server 8 decides to search the sequence xsequence files for each page. Otherwise, the decision in decision block 1742 is “NO” when the model building server 8 decides not to search the sequence xsequence files for each page.
When the decision in decision block 1742 is “NO,” in block 1744, the model building server 8 writes the pages identified in block 1740 to the rest xsequence file(s). It may be beneficial to include all of the pages that did not appear in every transcript in the rest xsequence file(s) because as the directed graph structure “SD” is traversed, particular transitions may not be visited.
When the decision in decision block 1742 is “YES,” for each page, in block 1745, the model building server 8 searches the sequence xsequence files to determine whether the page has been written to one or more of the sequence xsequence files.
Then, in decision block 1750, the model building server 8 determines whether the page has been written to one or more of the sequence xsequence files. The decision in decision block 1750 is “YES” when the page has been written to one or more of the sequence xsequence files. Otherwise, the decision in decision block 1750 is “NO” when the page has not been written to one or more of the sequence xsequence files.
When the decision in decision block 1750 is “NO,” in block 1755, the model building server 8 writes the page to a rest xsequence file. Then, the model building server 8 advances to decision block 1760.
When the decision in decision block 1750 is “YES,” the page may be omitted from the rest xsequence file and the model building server 8 advances to decision block 1760.
In decision block 1760, the model building server 8 determines whether there are any pages for which the sequence xsequence files have not been searched. The decision in decision block 1760 is “YES” when the model building server 8 has not searched the sequence xsequence files for all of the pages. Otherwise, the decision in decision block 1760 is “NO” when the model building server 8 has searched the sequence xsequence files for all of the pages.
The pages may be ordered within the rest xsequence files based on the frequencies at which the pages appeared in the transcripts. Rest xsequence files may be downloaded when the download pipeline (that is downloading the xsequence files from the server computing device 7 to the client computing device 9) is idle.
The following pseudo code provides a non-limiting example of a method of adding pages to the rest xsequence file.
Then, in block 1770, the model building server 8 creates the streaming model file 1180 (see
Referring to
Then, the method 1700 terminates.
In response to this request, the server computing device 7 streams the streaming model file 1180 and the initial execution xsequence file(s) (e.g., the initial execution xsequence file 1632) to the Sandbox Manager 134 and/or the Client Application 132. Arrow “A10” in
In block 1015, the Sandbox Manager 134 and/or the Client Application 132 receive the model file and the initial execution xsequence file(s).
By way of a non-limiting example, the following code may be used in blocks 1010 and 1015 to pass a URL to the server computing device 7 and download the model file and the initial execution xsequence files.
Then, in block 1020, the Sandbox Manager 134 launches the virtual application 110. Thus, the virtual application 110 begins executing even though less then all of the data stored in the xlayer file 300 has been downloaded.
In decision block 1022, the Sandbox Manager 134 determines whether it has received a notification from the virtual runtime engine 131 that a page has been requested by the virtual application 110 that has not yet been downloaded, or whether there are additional xsequence files to be downloaded for the virtual application 110.
The decision in decision block 1022 is “REQUEST” when the Sandbox Manager 134 determines it has received a notification from the virtual runtime engine 131 that a page has been requested by the virtual application 110 that has not yet been downloaded.
The decision in decision block 1022 is “MORE TO DOWNLOAD” when the Sandbox Manager 134 determines there are additional xsequence files to be downloaded for the virtual application 110 and the Sandbox Manager 134 determines it has not received a notification from the virtual runtime engine 131 that a page has been requested by the virtual application 110 that has not yet been downloaded.
When the decision in decision block 1022 is “REQUEST,” in block 1030, the directing process 129 identifies the xsequence file storing the page for which access has been requested. The directing process 129 may use the model file to look up which xsequence file is storing the page for which access has been requested. Optionally, the directing process 129 may pause execution of the virtual application 110.
In block 1035, the Sandbox Manager 134 and/or the Client Application 132 download the xsequence file indentified in block 1030 while the virtual application 110 is in use. Then, the Sandbox Manager 134 and/or the Client Application 132 advance to decision block 1065.
The Sandbox Manager 134 and/or the Client Application 132 may download additional xsequence files even without receiving a notification from the virtual runtime engine 131 indicating a page stored by the xsequence file has been requested. For example, after the Sandbox Manager 134 and/or the Client Application 132 have downloaded the model file and the initial execution xsequence file(s), the Sandbox Manager 134 and/or the Client Application 132 may download the sequence xsequence files.
When the decision in decision block 1022 is “MORE TO DOWNLOAD,” in decision block 1045, the Sandbox Manager 134 determines whether one or more of the sequence xsequence files have yet to be downloaded. The decision in decision block 1045 is “YES” when one or more of the sequence xsequence files have yet to be downloaded. Otherwise, the decision in decision block 1045 is “NO” when all of the sequence xsequence files have been downloaded.
When the decision in decision block 1045 is “YES,” in block 1050, the Sandbox Manager 134 and/or the Client Application 132 download one of the sequence xsequence files. The directing process 129 may use the model file to determine which sequence xsequence file to download. Because the directing process 129 knows which of the sequence xsequence file was the last one downloaded, the directing process 129 may use the model file to traverse the directed graph structure “SD” and locate the next sequence xsequence file to download. By way of a non-limiting example, the following pseudo code provides an exemplary download loop that may be used to download the sequence xsequence file (referred to in the following pseudo code as “blocks”). The function named “GetNextXferBlock( )” reads the model file to identify the next sequence xsequence file to download.
The above download loop continues looping until all of the sequence xsequence files listed in the model file are written to the shared memory block 133. As mentioned above, in the above pseudo code, the order in which the sequence xsequence files are downloaded is determined by the function named “GetNextXferBlock( ).” The following pseudo code provides an exemplary implementation of the function named “GetNextXferBlock( ).”
As discussed above, the directed graph structure “SD” may include one or more branches. Therefore, when the Sandbox Manager 134 is traversing the directed graph structure “SD” (using the model file) and encounters a branch, the Sandbox Manager 134 must select one of the transitions of the branch. The Sandbox Manager 134 may perform a weighted depth first traversal of the directed graph structure “SD,” which reflects the order(s) in which the pages are most commonly accessed as determined by the profiling process 700 and the modeling process. Alternatively, other types of traversal, such as a breadth first traversal may be used. The weight assigned to a transition to a particular sequence xsequence file (which stores the pages of one or more transition data structures) may be a percentage that the particular transition occurred out of all of the transitions recorded in the transcripts.
Returning to
In decision block 1065, the Sandbox Manager 134 determines whether all of the xsequence files have been downloaded. The decision in decision block 1065 is “YES” when all of the xsequence files have been downloaded. Otherwise, the decision in decision block 1065 is “NO” when all of the xsequence files have not been downloaded.
When the decision in decision block 1065 is “NO,” the Sandbox Manager 134 returns to decision block 1022.
When the decision in decision block 1065 is “YES,” all of the rest xsequence files have been downloaded. Therefore, the application download is complete, and the method 1000 terminates.
The following pseudo code is a non-limiting example of a method of downloading the rest xsequence files and determining when the download is complete.
U.S. patent application Ser. No. 12/695,107 (which is incorporated herein by reference) describes the Sandbox Manager 134, which is a virtual process manager configured to download and execute a virtualized application file from a server computing device to a client computing device. Each of the streaming model file 1180 (see
As mentioned above, the directing process 129 may send one or more special command-line arguments 1170 to the virtual runtime engine 131. For example, settings may be provided to the virtual runtime engine 131 via the special command-line arguments 1170. An exemplary command-line argument may include “/XExecutionSession=<SessionId>.” This SessionId value is used by the directing process 129 and the virtual runtime engine 131 to lookup the shared memory by name.
By way of a non-limiting example, the shared memory block 133 may have a name with the following format:
_xmgr_<managerVersion>_sessioninfo_<sessionId>
In the above format, “managerVersion” is one of the special command-line arguments 1170 (like the SessionId value). By way of a non-limiting example, the SessionId value may be implemented as a 64-bit integer.
Status events are created and used by the directing process 129 to signal changes in the state of the session to the virtual runtime engine 131. By way of a non-limiting example, the session may have the following states, which may be assigned the exemplary values indicated:
The sentinel object 1174, which is a named kernel object, is used to indicate the lifetime of the virtual application. For example, a named mutex may be used. Once the sentinel object 1174 disappears (which may be determined by polling in the directing process 129) all processes of the virtual application 110 have terminated. As is appreciated by those of ordinary skill in the art, some operating systems, such as Microsoft WINDOWS®, are configured to track or count references by other objects to named kernel objects. Thus, when a WINDOWS® process has a reference (or handle) to the sentinel object 1174, the host operating system 35A (see
In addition to the above fixed-sized shared memory structures used to manage execution of the virtual application 110, optionally, another named shared memory block 1176 containing handles to a shared mapping of the xlayer file (e.g., the xlayer file 300) itself may be used, along with a shared memory based bit-array structure 1178 to support dynamic population of the xlayer file (e.g., the xlayer file 300) while the virtual application 110 is running. This is done to support streaming delivery of the virtual application 110 using the streaming model 122.
Starting a Virtual Application
In first block 1210, the directing process 129 allocates the block of shared memory 133 (see
Then, in block 1220, the directing process 129 sets the values of any specific settings or values stored in the shared memory block. For example, the shared memory block may store a SignalEvent value and a State value. The SignalEvent value is set to the handle value of the status event object allocated in block 1215.
Whenever the State value is changed or the xlayer mapping 1176 is updated by the directing process 129 (e.g., when additional xsequence files have been downloaded), the directing process 129 triggers a SignalEvent. In response to detecting the SignalEvent, each thread launched by the execution of the virtual application 110 checks the State value to determine if the state of the virtual application 110 is to be changed (e.g., paused, resumed, or terminated). Any threads waiting for the xlayer mapping 1176 to indicate a particular portion of the downloading virtualized application file is available (or stored in a local copy of the virtualized application file), also check the xlayer mapping 1176 to determine whether the data has been delivered.
The initial value of the State value depends upon in which state the virtual application 110 is to be launched. If the virtual application is to be launched in a “paused” state, the State value is set to a value indicating the application is paused (e.g., the eSessionPaused value). Otherwise, the State value is set to a value indicating the application is executing (e.g., the eSessionRunning value). If at some point, the application is terminated, the State value is set to a value indicating the application has shutdown (e.g., the eSessionShutdown value).
Once the shared memory block 133, status event object(s), and command-line arguments are prepared, in block 1225, the directing process 129 launches the virtual application 110. By way of a non-limiting example, the virtual application 110 may be launched via standard a Win32 CreateProcess function or ShellExecute APIs. The following pseudo code provides a non-limiting example of a method of starting a virtual application.
The first code portion to execute within the virtual application 110 is called “bootstrap” code. The “bootstrap” code includes the virtual runtime engine code that, when executing, sets up the virtual runtime environment, reads the configuration information (e.g., virtual filesystem information, virtual registry settings, and the like), and other initialization tasks. As explained above, the configuration information may be stored in an xlayer file (e.g., the xlayer file 300). When the SessionId value is passed to the “bootstrap” code, the “bootstrap” code uses the SessionId value to determine a name of the shared memory block 133 having the predetermined format specified above, and searches for the shared memory block 133 using that name. The “bootstrap” code may also create the sentinel object 1174. Once found, addition settings can be read as well as the State value. As discussed above, in particular implementations, the State value may be set to the eSessionPaused value, the eSessionRunning value, or the eSessionShutdown value.
Then, the method 1200 terminates.
Pausing and Resuming a Virtual Application
As mentioned previously, once a virtual application has been started in the directed fashion, it is able to detect SignalEvents that provide notification of changes in the state of the session. Depending upon the implementation details, this may be done via the Win32 ::WaitForMultipleObjects APIs, and by associating the SignalEvent value with the handle of the directing process 129. After detecting a SignalEvent, the virtual application 110 can check the State value of the shared memory block 133. If the State value indicates the session has been paused (e.g., the State value is set to the eSessionPaused value), the virtual runtime engine 131 blocks access by the virtual application 110 to the underlying xlayer file (which contains the virtual filesystem and registry among other things). The virtual runtime engine 131 could also explicitly suspend application threads. However, this may not be necessary.
The following pseudo code provides a non-limiting example of a method of pausing a virtual application by setting the value of the State value to the eSessionPaused value and triggering a SignalEvent to indicate a change in the state of the session.
When the State value indicates the session is running (e.g., the State value is set to the eSessionRunning value), access to the xlayer file is restored. In other words, the virtual application 110 resumes. The following pseudo code provides a non-limiting example of a method of resuming a virtual application by setting the value of the State value to the eSessionRunning value and triggering a SignalEvent to indicate a change in the state of the session.
Monitoring a Virtual Application
The directing process 129 has the ability to tell the virtual application to shutdown. However, this shutdown occurs asynchronously. Additionally, the virtual application can shut itself down at any time, or may be shut down due to user control, for example when the user closes the virtual application. As mentioned above, the named sentinel object 1174 is used to determine when the virtual application is completely shutdown. Each process within the virtual application duplicates the handle of the named sentinel object 1174 to the child process during any create-process call. For example, the name of the named sentinel object 1174 may be determined as follows:
_xmgr_<managerVersion>_mtx_sentinel_<sessionId>
Duplicating the handle of the named sentinel object 1174 into each child process ensures that the named sentinel object 1174 remains alive (e.g., has a reference count greater than zero) for the lifetime of the virtual application. The directing process 129 may determine the virtual application is executing by polling for the existence of the named sentinel object 1174 occasionally (e.g., at regular intervals). For example, the directing process 129 may poll for the named sentinel object 1174 once every second via a Win32 timer thread function. In embodiments in which a reference count is available, the polling may simply poll to determine if the reference count is equal to zero meaning no objects have references (or handles) to the named sentinel object 1174.
The following pseudo code provides a non-limiting example of a method of monitoring for virtual application shutdown.
Once shutdown is detected, the directing process 129 may perform custom actions, such as cleaning up resources, marking the end time in usage statistics, recording the termination in a transcript file, etc.
Dynamic Population of XLayer File During Application Execution
To begin execution of a virtual application as soon as possible, one may try to determine which portions of the xlayer file are necessary for initial execution and deliver those portions to the virtual application first. To actually support dynamic population of the underlying xlayer file while it is being executed requires a system and method for doing so.
The directing process 129 is responsible for preparing the data-structures described above and illustrated in
By way of a non-limiting example, the name of the shared memory block 133 may have the following format:
_xmgr_<managerVersion>_mem_xlayerinfo_<xlayerpathhash>. Where “managerVersion” is an argument passed on the command line from the directing process 129. The “xlayerpathhash” may be a hash (e.g., a “good” hash) of the normalized path to the xlayer file being populated.
If the shared memory block 133 has been allocated, the virtual runtime engine 131 concludes the xlayer file is to be dynamically delivered. If the shared memory block 133 has not been allocated, the virtual runtime engine 131 concludes the xlayer file is fully populated.
By way of a non-limiting example, the shared-memory block 133 may be implemented using the following structure:
The following pseudo code provides a non-limiting example of a method of preparing dynamic xlayer population data-structures.
After this data structure is prepared, execution of the application may be started as described above. Note the local copy of the xlayer file need not be fully populated to launch the virtual application. However, once started, the virtual application will begin to demand access to various parts of the local copy of the xlayer file and will wait until these requests are satisfied. By way of a non-limiting example, this access may be requested via an IStream interface abstraction of the xlayer file. The blocking is done by way of a check of the pageMap bit-array 1178. If a requested page is not yet populated, as indicated by this bit-array, the virtual application waits on the SignalEvent, until the PageMap indicates the page has been populated within the local copy of the xlayer file. The following pseudo code provides a non-limiting example of a method by which the virtual application may access the xlayer file and check the PageMap.
Simultaneously, the directing process 129 may populate any portion of the xlayer file. The following pseudo code provides a non-limiting example of a method by which the directing process may populate any portion of the xlayer file.
As the virtual application 110 executes, it sends messages (e.g., messages using the data structure named “SFeedbackStatsMessage”) to the directing process 129 indicating which page of the local copy of the xlayer file is currently being accessed by the executing virtual application 110. The directing process 129 uses these messages to determine where in the streaming model file 1180 the page currently being accessed by the executing virtual application 110 is located. The directing process 129 then begins reading the streaming model file 1180 from that location. This allows the traversal of the directed graph structure stored by the streaming model file 1180 to be modified by the user choices occurring during the execution of the virtual application 110. Thus, the directing process 129 traverse the streaming model file 1180 in a custom manner dictated by the actions of a user. As discussed above, the SFeedbackStatsMessage type message includes the blocked value. The virtual runtime engine 131 may communicate to the directing process 129 that the virtual runtime engine has tried to access a page that has not yet been downloaded (e.g., is not indicated as being included in the local copy of the downloaded xlayer file by the xlayer mapping 1176) by setting the blocked value to “TRUE.”
The signature value 622 is a value used to authenticate the information stored in a file. For example, the signature value 622 may be used to validate a particular xsequence file. By way of a non-limiting example, the signature value 622 of a valid xsequence file may store a predetermined value (e.g., the string “xsequencedfile”). Thus, to validate the xsequence file, the Sandbox Manager 134 may simply confirm the signature value 622 stores the predetermined value. The signature value 622 may be implemented as a 16-byte array. The value stored in the signature value 622 may be generated using any method and the present teachings are not limited to use with a signature value generated using any particular method.
The version stamp 624 may include a major version identifier 636 and a minor version identifier 638. The major version identifier 636 is typically modified when a change is made to the xsequence file format 600 that would make the file incompatible with a previous version of the virtual runtime engine 131. The minor version identifier 638 may be incremented for informational purposes when the xsequence file format 600 is modified such that it requires special handling to enable backwards compatibility. By way of a non-limiting example, each of the major and minor version identifiers 636 and 638 may be implemented as 32-bit integers.
The flags 625 may include a flag that indicates whether the data stored in the xblocks 620 has been compressed. The flags 625 may include a flag that indicates which type of compression was used to compress the data stored in the xblocks 620. By way of a non-limiting example, the flags 625 may be implemented as a 32-bit integer.
The size indicator 626 identifies a location in memory that corresponds to the end of an xsequence file having the xsequence file format 600. The location in memory to which the size indicator 626 refers is identified in
The indicator of size of the original file 628 indicates the size of the original file (e.g., the xlayer file 300). By way of a non-limiting example, the indicator of size of the original file 628 may be implemented as a 64-bit integer.
The indicator of size of the xblocks 630 indicates the size of all of the xblocks 620 in the xsequence file combined. By way of a non-limiting example, the indicator of size of the xblocks 630 may be implemented as a 32-bit integer.
The number of xblocks indicator 632 indicates the number of the xblocks 620 in the xsequence file. By way of a non-limiting example, the number of xblocks indicator 632 may be implemented as a 32-bit integer.
The number of xblocks per chapter indicator 634 indicates a number of xblocks stored in a particular chapter. Chapters may be used by the directing process 129 of the Sandbox Manager 134 to skip to a particular portion of the xsequence file. By way of a non-limiting example, the number of xblocks per chapter indicator 634 may be implemented as a 32-bit integer.
As mentioned above, the xsequence file format 600 includes one or more xblocks 620 that each contains a portion of the data stored in the original file (e.g., the xlayer file 300). Referring to
The signature value 662 is a value used to authenticate the information stored in an xblock and contains a unique value assigned to the xblock. The signature value 662 may be implemented as a 6-byte array. The value stored in the signature value 662 may be generated using any method and the present teachings are not limited to use with a signature value generated by any particular method.
The flags 668 may include values for various block options. By way of a non-limiting example, the flags 668 may include an indicator that a block stores metadata instead of virtual application data. By way of a non-limiting example, the flags 668 may be implemented as a 16-bit integer.
The xblock index value 670 is a numeric index value assigned to the xblock within the xsequence file. This xblock index value 670 is an index value associated with the block within an xsequence file. For example, if an xsequence file has four xblocks, the xblocks may be assigned index values of 0, 1, 2, and 3 in the order in which the xblocks were written to xsequence file. By way of a non-limiting example, the index value 670 may be implemented as a 32-bit integer.
The xblock identifier 674 identifies the data stored in the xblock within the original file (e.g., the xlayer file 300). The model building server 8 divides the original xlayer file into pages. For example, an xlayer file may be divided into pages P0, P1, P2, P3, P4, . . . PN. The xblock identifier 674 stores the location of the page in the original xlayer file. Thus, when the xblock is read by the Sandbox Manager 134, the Sandbox Manager 134 knows where to write the xblock in the locally reconstructed copy of the xlayer file. By way of a non-limiting example, the xblock identifier 674 may be implemented as a 32-bit integer.
The xblock size indicator 678 indicates the size of the xblock. By way of a non-limiting example, the xblock size indicator 678 may be implemented as a 32-bit integer.
The data portion 680 stores the data of the xblock.
As described above, the streaming model is used to create the initial execution xsequence file, sequence xsequence files, and rest xsequence files in accordance with an order specified in the streaming model. After one or more of these files are downloaded, the Sandbox Manager 134 may begin the process of reassembling or reconstructing the original file (e.g., the xlayer file 300).
Reconstructing the Original File from One or More Xsequence Files
In first block 910, the Sandbox Manager 134 receives an xsequence file.
In next block 912, the Sandbox Manager 134 reads the information stored in the file header portion 610 (see
In decision block 915 (using the information read in block 912), the Sandbox Manager 134 determines whether the xsequence file received in block 910 is valid. An xsequence file must be validated (or authenticated) before it can be used. As mentioned above, the Sandbox Manager 134 may validate an xsequence file by confirming the signature value 622 stores the predetermined value (e.g., the unique string “xsequencedfile”). Further, to ensure compatibility, the Sandbox Manager 134 may confirm that the major and minor versions match those of the virtual runtime engine 131.
The following pseudo code provides a non-limiting example of an implementation of blocks 912 and 915.
In the pseudo code above, if the signature value 622 (read into variable “signature”) does not equal the predetermined value (stored in the constant “GLOBAL_SIGNATURE”), an exception is generated. Further, if the major version identifier 636 (read into variable “MajorVersion”) does not match the major version of the virtual runtime engine 131 (stored in the constant “CURRENT_MAJOR_VERSION”) or the minor version identifier 638 (read into variable “MinorVersion”) does not match the major version of the virtual runtime engine 131 (stored in the constant “CURRENT_MINOR_VERSION”), an exception is generated. After the xsequence file has been verified, in the pseudo code above, the remaining data stored in the file header portion 610 is read (e.g., the flags 625, the size indicator 626, the indicator of size of the original file 628, the indicator of size of the xblocks 630, the number of xblocks indicator 632, and the number of xblocks per chapter indicator 634). At this point, the Sandbox Manager 134 knows the number of blocks stored in the xsequence file (which is provided by the number of xblocks indicator 632) and block sizes (which is provided by the indicator of size of the xblocks 630).
The decision in decision block 915 is “YES” when Sandbox Manager 134 determines the xsequence file is valid. Otherwise, the decision in decision block 915 is “NO” when Sandbox Manager 134 determines the xsequence file is invalid. By way of a non-limiting example, the decision in decision block 915 is “NO” when the pseudo code above generates an exception because the signature value 622 does not equal the predetermined value, the major version identifier 636 does not match the major version of the virtual runtime engine 131, and/or the minor version identifier 638 does not match the minor version of the virtual runtime engine 131. Otherwise, in this example, the decision in decision block 915 is “YES.”
When the decision in decision block 915 is “NO,” the method 900 terminates.
As mentioned above, the xsequence files are configured to be transferred from one computing device to another (e.g., using conventional download or file transfer methods). When the client computing device 9 receives an xsequence file from the server computing device 7, portions of the original file contained in the received xsequence file are used to populate a copy of the original file constructed or assembled on the client computing device 9.
When the decision in decision block 915 is “YES,” in decision block 920, the Sandbox Manager 134 determines whether the xsequence file received is the first one for the original file. The decision in decision block 920 is “YES” when the xsequence file received in block 910 is the first one for the original file. Otherwise, the decision in decision block 920 is “NO” when one or more xsequence files have been received previously for the original file.
When the decision in decision block 920 is “YES,” in block 925, the Sandbox Manager 134 allocates the memory mapped file 1176 illustrated in
In block 930, the Sandbox Manager 134 reads the data portions 680 of the xblocks into the memory mapped file 1176 (optionally allocated in block 925). As explained above, the block structure 660 includes the xblock identifier 674 that indicates the location in the original file from which the data in the xblock was obtained. The xblock identifier 674 may be used to write the data stored in the xblock in the correct location of the memory mapped file 1176.
The following pseudo code provides a non-limiting example of a method of reading a single xblock into memory.
Then, in block 932, the Sandbox Manager 134 sends one or more notifications that data has been downloaded. In block 932, the Sandbox Manager 134 may send a notification to the virtual runtime engine 131 (e.g., that signals an event) that the blocks have been downloaded. The following pseudo code provides a non-limiting example of a method of writing the data in an xblock into the correct location of the memory mapped file 1176 and sending a notification to the virtual runtime engine 131.
In block 932, the Sandbox Manager 134 may also modify the bit array page mask 1178 before sending the notification to the virtual runtime engine 131.
Then, in block 945, the Sandbox Manager 134 instructs the virtual runtime engine 131 to launch the virtualized application file 140 to thereby execute the virtual application 110. Depending upon the implementation details, at this point, an initial execution xsequence file may have been downloaded and used to initiate execution of the virtual application 110. However, the data stored in the initial execution xsequence file may be inadequate to support all features of the virtual application 110. Therefore, in decision block 950, the Sandbox Manager 134 determines whether all of the xsequence files have been downloaded. The method 1000 illustrated in
When the decision in decision block 920 is “NO,” in block 955, the Sandbox Manager 134 reads the data portions 680 of the xblocks into the memory mapped file 1176 (optionally allocated in block 925). Block 955 may be substantially identical to block 930.
Then in block 957, the Sandbox Manager 134 sends one or more notifications that blocks have been downloaded. Block 957 may be substantially identical to block 932. Then, the Sandbox Manager 134 advances to decision block 950.
The decision in decision block 950 is “YES” when all of the xsequence files have been downloaded. The decision in decision block 950 is “NO” when all of the xsequence files have not been downloaded.
When the decision in decision block 950 is “NO,” the Sandbox Manager 134 returns to block 910 whereat the Sandbox Manager 134 receives another xsequence file.
When the decision in decision block 950 is “YES,” in block 940, the copy of the original file (which is at least partially populated) is written to the local cache 139 illustrated in
Thus, the Sandbox Manager 134 need not wait until the entire original file has been assembled to instruct the virtual runtime engine 131 to execute the virtual application 110. In other words, a partially assembled version of the original file may be written to the local cache 139 illustrated in
The copy of the original file is illustrated in
Moreover, those skilled in the art will appreciate that implementations may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. Implementations may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
The exemplary hardware and operating environment of
The computing device 12 includes the system memory 22, a processing unit 21, and a system bus 23 that operatively couples various system components, including the system memory 22, to the processing unit 21. There may be only one or there may be more than one processing unit 21, such that the processor of computing device 12 comprises a single central-processing unit (CPU), or a plurality of processing units, commonly referred to as a parallel processing environment. The computing device 12 may be a conventional computer, a distributed computer, or any other type of computer.
The system bus 23 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. The system memory may also be referred to as simply the memory, and includes read only memory (ROM) 24 and random access memory (RAM) 25. A basic input/output system (BIOS) 26, containing the basic routines that help to transfer information between elements within the computing device 12, such as during start-up, is stored in ROM 24. The computing device 12 further includes a hard disk drive 27 for reading from and writing to a hard disk, not shown, a magnetic disk drive 28 for reading from or writing to a removable magnetic disk 29, and an optical disk drive 30 for reading from or writing to a removable optical disk 31 such as a CD ROM, DVD, or other optical media.
The hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 are connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical disk drive interface 34, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer-readable instructions, data structures, program modules, and other data for the computing device 12. It should be appreciated by those skilled in the art that any type of computer-readable media which can store data that is accessible by a computer, such as magnetic cassettes, flash memory cards, USB drives, digital video disks, Bernoulli cartridges, random access memories (RAMs), read only memories (ROMs), and the like, may be used in the exemplary operating environment. As is apparent to those of ordinary skill in the art, the hard disk drive 27 and other forms of computer-readable media (e.g., the removable magnetic disk 29, the removable optical disk 31, flash memory cards, USB drives, and the like) accessible by the processing unit 21 may be considered components of the system memory 22.
A number of program modules may be stored on the hard disk drive 27, magnetic disk 29, optical disk 31, ROM 24, or RAM 25, including an operating system 35, one or more application programs 36, other program modules 37, and program data 38. A user may enter commands and information into the computing device 12 through input devices such as a keyboard 40 and pointing device 42. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus 23, but may be connected by other interfaces, such as a parallel port, game port, or a universal serial bus (USB). A monitor 47 or other type of display device is also connected to the system bus 23 via an interface, such as a video adapter 48. In addition to the monitor, computers typically include other peripheral output devices (not shown), such as speakers and printers.
The computing device 12 may operate in a networked environment using logical connections to one or more remote computers, such as remote computer 49. These logical connections are achieved by a communication device coupled to or a part of the computing device 12 (as the local computer). Implementations are not limited to a particular type of communications device. The remote computer 49 may be another computer, a server, a router, a network PC, a client, a memory storage device, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computing device 12. The remote computer 49 may be connected to a memory storage device 50. The logical connections depicted in
When used in a LAN-networking environment, the computing device 12 is connected to the local area network 51 through a network interface or adapter 53, which is one type of communications device. When used in a WAN-networking environment, the computing device 12 typically includes a modem 54, a type of communications device, or any other type of communications device for establishing communications over the wide area network 52, such as the Internet. The modem 54, which may be internal or external, is connected to the system bus 23 via the serial port interface 46. In a networked environment, program modules depicted relative to the personal computing device 12, or portions thereof, may be stored in the remote computer 49 and/or the remote memory storage device 50. It is appreciated that the network connections shown are exemplary and other means of and communications devices for establishing a communications link between the computers may be used.
The computing device 12 and related components have been presented herein by way of particular example and also by abstraction in order to facilitate a high-level view of the concepts disclosed. The actual technical design and implementation may vary based on particular implementation while maintaining the overall nature of the concepts disclosed.
Returning to
The foregoing described embodiments depict different components contained within, or connected with, different other components. It is to be understood that such depicted architectures are merely exemplary, and that in fact many other architectures can be implemented which achieve the same functionality. In a conceptual sense, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components herein combined to achieve a particular functionality can be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermedial components. Likewise, any two components so associated can also be viewed as being “operably connected,” or “operably coupled,” to each other to achieve the desired functionality.
While particular embodiments of the present invention have been shown and described, it will be obvious to those skilled in the art that, based upon the teachings herein, changes and modifications may be made without departing from this invention and its broader aspects and, therefore, the appended claims are to encompass within their scope all such changes and modifications as are within the true spirit and scope of this invention. Furthermore, it is to be understood that the invention is solely defined by the appended claims. It will be understood by those within the art that, in general, terms used herein, and especially in the appended claims (e.g., bodies of the appended claims) are generally intended as “open” terms (e.g., the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” etc.). It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases “at least one” and “one or more” to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim recitation to inventions containing only one such recitation, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an” (e.g., “a” and/or “an” should typically be interpreted to mean “at least one” or “one or more”); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should typically be interpreted to mean at least the recited number (e.g., the bare recitation of “two recitations,” without other modifiers, typically means at least two recitations, or two or more recitations).
Accordingly, the invention is not limited except as by the appended claims.
This application claims the benefit of U.S. Provisional Application No. 61/361,373, filed Jul. 2, 2010, which is incorporated herein by reference in its entirety, and this application is a continuation-in-part of U.S. application Ser. No. 12/697,029, filed on Jan. 29, 2010.
Number | Name | Date | Kind |
---|---|---|---|
4468732 | Raver | Aug 1984 | A |
5410667 | Belsan | Apr 1995 | A |
5437031 | Kitami | Jul 1995 | A |
5495610 | Shing et al. | Feb 1996 | A |
5774713 | Yokota | Jun 1998 | A |
5860068 | Cook | Jan 1999 | A |
5958051 | Renaud | Sep 1999 | A |
5987590 | So | Nov 1999 | A |
6023712 | Spear et al. | Feb 2000 | A |
6085251 | Fabozzi, II | Jul 2000 | A |
6108707 | Wiese | Aug 2000 | A |
6175900 | Forin | Jan 2001 | B1 |
6192375 | Gross | Feb 2001 | B1 |
6263363 | Rosenblatt et al. | Jul 2001 | B1 |
6345212 | Nourse | Feb 2002 | B1 |
6366947 | Kavner | Apr 2002 | B1 |
6453334 | Vinson | Sep 2002 | B1 |
6493733 | Pollack et al. | Dec 2002 | B1 |
6564229 | Baweja et al. | May 2003 | B1 |
6675216 | Quatrano et al. | Jan 2004 | B1 |
6704808 | Kasamatsu et al. | Mar 2004 | B2 |
6757893 | Haikin | Jun 2004 | B1 |
7028295 | Li et al. | Apr 2006 | B2 |
7064760 | Capin et al. | Jun 2006 | B2 |
7065504 | Sakuma et al. | Jun 2006 | B2 |
7076768 | Li et al. | Jul 2006 | B2 |
7089259 | Kouznetsov et al. | Aug 2006 | B1 |
7096253 | Vinson et al. | Aug 2006 | B2 |
7096416 | Smith et al. | Aug 2006 | B1 |
7117495 | Blaser et al. | Oct 2006 | B2 |
7130073 | Kumar et al. | Oct 2006 | B2 |
7155448 | Winter | Dec 2006 | B2 |
7162036 | Rowe | Jan 2007 | B2 |
7240162 | De Vries | Jul 2007 | B2 |
7243207 | Prakash | Jul 2007 | B1 |
7246351 | Bloch et al. | Jul 2007 | B2 |
7272613 | Sim et al. | Sep 2007 | B2 |
7337298 | Kawachiya et al. | Feb 2008 | B2 |
7356679 | Le et al. | Apr 2008 | B1 |
7360097 | Rothstein | Apr 2008 | B2 |
7386542 | Maybury et al. | Jun 2008 | B2 |
7386546 | Santry | Jun 2008 | B1 |
7437371 | Rathakrishnan et al. | Oct 2008 | B2 |
7451176 | Anders et al. | Nov 2008 | B2 |
7451196 | de Vries et al. | Nov 2008 | B1 |
7461086 | Hurren et al. | Dec 2008 | B1 |
7490072 | Cowan et al. | Feb 2009 | B1 |
7496931 | Cook et al. | Feb 2009 | B2 |
7499991 | Johnson | Mar 2009 | B2 |
7519959 | Dmitriev | Apr 2009 | B1 |
7523116 | Yan | Apr 2009 | B2 |
7529784 | Kavuri | May 2009 | B2 |
7536505 | Takakuwa | May 2009 | B2 |
7536541 | Isaacson | May 2009 | B2 |
7577751 | Vinson et al. | Aug 2009 | B2 |
7584342 | Nordquist et al. | Sep 2009 | B1 |
7590644 | Matsakis et al. | Sep 2009 | B2 |
7600097 | Wright | Oct 2009 | B1 |
7607127 | Romm et al. | Oct 2009 | B2 |
7623673 | Mercier | Nov 2009 | B2 |
7634477 | Hinshaw | Dec 2009 | B2 |
7634772 | Parthasarathy et al. | Dec 2009 | B2 |
7664367 | Suzuki | Feb 2010 | B2 |
7669189 | Umamageswaran | Feb 2010 | B1 |
7689825 | Iwamura | Mar 2010 | B2 |
7707427 | Kenrich | Apr 2010 | B1 |
7707564 | Marvin | Apr 2010 | B2 |
7743407 | Sprigg et al. | Jun 2010 | B2 |
7752442 | Della-Libera et al. | Jul 2010 | B2 |
7752511 | Fulton et al. | Jul 2010 | B2 |
7761503 | Dhawan et al. | Jul 2010 | B2 |
7797748 | Zheng et al. | Sep 2010 | B2 |
7801827 | Bishop et al. | Sep 2010 | B2 |
7831047 | Rowe | Nov 2010 | B2 |
7836299 | England et al. | Nov 2010 | B2 |
7840961 | Weathersby | Dec 2010 | B1 |
7950026 | Urbach | May 2011 | B1 |
7958497 | Lindo et al. | Jun 2011 | B1 |
7966599 | Malasky et al. | Jun 2011 | B1 |
7970789 | Blaser et al. | Jun 2011 | B1 |
7971032 | Shattuck | Jun 2011 | B2 |
7984043 | Waas | Jul 2011 | B1 |
8010667 | Zhang et al. | Aug 2011 | B2 |
8037289 | Karnik et al. | Oct 2011 | B1 |
8065675 | Strauss et al. | Nov 2011 | B2 |
8069443 | Ackerman et al. | Nov 2011 | B2 |
8073926 | Traut et al. | Dec 2011 | B2 |
8180884 | Hall | May 2012 | B1 |
8219805 | Ie et al. | Jul 2012 | B1 |
8230414 | Hand et al. | Jul 2012 | B1 |
8230442 | Aho et al. | Jul 2012 | B2 |
8271944 | Austin et al. | Sep 2012 | B2 |
8347208 | Howell | Jan 2013 | B2 |
8352430 | Myhill | Jan 2013 | B1 |
8356266 | Ou et al. | Jan 2013 | B1 |
8375140 | Tippin et al. | Feb 2013 | B2 |
8387006 | Taylor | Feb 2013 | B1 |
8429248 | Ketrenos et al. | Apr 2013 | B1 |
8434093 | Larimore et al. | Apr 2013 | B2 |
8453049 | Grieve | May 2013 | B1 |
8468175 | Obata | Jun 2013 | B2 |
8489513 | Bishop et al. | Jul 2013 | B2 |
8510734 | Criddle et al. | Aug 2013 | B2 |
8626806 | Larimore | Jan 2014 | B2 |
8645488 | Ivory et al. | Feb 2014 | B2 |
8677345 | Choi et al. | Mar 2014 | B2 |
8719898 | Barton et al. | May 2014 | B1 |
8745601 | Carlson et al. | Jun 2014 | B1 |
8762951 | Kosche et al. | Jun 2014 | B1 |
8762986 | Gebhart | Jun 2014 | B2 |
8763009 | Degirmenci et al. | Jun 2014 | B2 |
8806325 | Decker | Aug 2014 | B2 |
8954958 | Murphey et al. | Feb 2015 | B2 |
8978012 | Poole | Mar 2015 | B1 |
8990289 | Mott | Mar 2015 | B2 |
9003541 | Patidar | Apr 2015 | B1 |
9098706 | Kennedy | Aug 2015 | B1 |
9158845 | Reddy | Oct 2015 | B1 |
9208169 | Obata | Dec 2015 | B2 |
9229748 | Larimore | Jan 2016 | B2 |
9268542 | Mars et al. | Feb 2016 | B1 |
9405521 | Ou-Yang et al. | Aug 2016 | B2 |
9569286 | Larimore | Feb 2017 | B2 |
20010016905 | Kasamatsu et al. | Aug 2001 | A1 |
20010034736 | Eylon | Oct 2001 | A1 |
20010037399 | Eylon | Nov 2001 | A1 |
20020029283 | Beckett et al. | Mar 2002 | A1 |
20020032754 | Logston et al. | Mar 2002 | A1 |
20020039196 | Chiarabini | Apr 2002 | A1 |
20020065776 | Calder et al. | May 2002 | A1 |
20020066085 | Nowlin, Jr. et al. | May 2002 | A1 |
20020083133 | Feigenbaum | Jun 2002 | A1 |
20020099951 | O'Connor | Jul 2002 | A1 |
20020112078 | Yach | Aug 2002 | A1 |
20020129129 | Bloch et al. | Sep 2002 | A1 |
20020133491 | Sim et al. | Sep 2002 | A1 |
20020138441 | Lopatic | Sep 2002 | A1 |
20020161578 | Saidon et al. | Oct 2002 | A1 |
20020161908 | Benitez | Oct 2002 | A1 |
20020162015 | Tang | Oct 2002 | A1 |
20020174193 | Mikhalchuk | Nov 2002 | A1 |
20020184184 | Holcomb | Dec 2002 | A1 |
20030005118 | Williams | Jan 2003 | A1 |
20030031176 | Sim et al. | Feb 2003 | A1 |
20030051169 | Sprigg et al. | Mar 2003 | A1 |
20030120858 | March | Jun 2003 | A1 |
20030159135 | Hiller | Aug 2003 | A1 |
20030217116 | Currans | Nov 2003 | A1 |
20040003390 | Canter | Jan 2004 | A1 |
20040015747 | Dwyer | Jan 2004 | A1 |
20040044645 | Palumbo | Mar 2004 | A1 |
20040044996 | Atallah | Mar 2004 | A1 |
20040083474 | McKinlay et al. | Apr 2004 | A1 |
20040111671 | Lu | Jun 2004 | A1 |
20040128342 | Maes et al. | Jul 2004 | A1 |
20040133444 | Defaix et al. | Jul 2004 | A1 |
20040139315 | Tokutani et al. | Jul 2004 | A1 |
20040181790 | Herrick | Sep 2004 | A1 |
20040236772 | Arakawa | Nov 2004 | A1 |
20040237082 | Alcazar | Nov 2004 | A1 |
20040255293 | Spotswood | Dec 2004 | A1 |
20050010932 | Kohno et al. | Jan 2005 | A1 |
20050114870 | Song et al. | May 2005 | A1 |
20050132359 | McGuire et al. | Jun 2005 | A1 |
20050198628 | Graham et al. | Sep 2005 | A1 |
20050198647 | Hipp et al. | Sep 2005 | A1 |
20050228963 | Rothman | Oct 2005 | A1 |
20050235154 | Serret-Avila | Oct 2005 | A1 |
20050235282 | Anderson | Oct 2005 | A1 |
20050262553 | Bialick et al. | Nov 2005 | A1 |
20050273772 | Matsakis et al. | Dec 2005 | A1 |
20050283673 | Ode | Dec 2005 | A1 |
20050289546 | Shpeisman et al. | Dec 2005 | A1 |
20060004684 | Kime | Jan 2006 | A1 |
20060048136 | Vries et al. | Mar 2006 | A1 |
20060053209 | Li | Mar 2006 | A1 |
20060053380 | Spataro et al. | Mar 2006 | A1 |
20060074733 | Shukla et al. | Apr 2006 | A1 |
20060075064 | Keohane et al. | Apr 2006 | A1 |
20060085359 | Kim | Apr 2006 | A1 |
20060117325 | Wieland et al. | Jun 2006 | A1 |
20060123185 | de Vries et al. | Jun 2006 | A1 |
20060143135 | Tucker | Jun 2006 | A1 |
20060161910 | Bonsteel | Jul 2006 | A1 |
20060168294 | de Vries et al. | Jul 2006 | A1 |
20060218165 | Vries et al. | Sep 2006 | A1 |
20060222203 | Mercier | Oct 2006 | A1 |
20060230175 | de Vries et al. | Oct 2006 | A1 |
20060242626 | Pham et al. | Oct 2006 | A1 |
20060248442 | Rosenstein et al. | Nov 2006 | A1 |
20060253535 | Betros et al. | Nov 2006 | A1 |
20060256130 | Gonzalez | Nov 2006 | A1 |
20060259585 | Keohane et al. | Nov 2006 | A1 |
20060265761 | Rochette et al. | Nov 2006 | A1 |
20060271596 | Sabsevilz et al. | Nov 2006 | A1 |
20070011672 | Bhide et al. | Jan 2007 | A1 |
20070016721 | Gay | Jan 2007 | A1 |
20070043874 | Nath | Feb 2007 | A1 |
20070043943 | Peretti | Feb 2007 | A1 |
20070074191 | Geisinger | Mar 2007 | A1 |
20070078988 | Miloushev et al. | Apr 2007 | A1 |
20070083482 | Rathi | Apr 2007 | A1 |
20070143672 | Lipton | Jun 2007 | A1 |
20070143704 | Laird-McConnell | Jun 2007 | A1 |
20070156997 | Boule | Jul 2007 | A1 |
20070168953 | Diez et al. | Jul 2007 | A1 |
20070168965 | Zenz et al. | Jul 2007 | A1 |
20070174824 | Relyea et al. | Jul 2007 | A1 |
20070192329 | Croft et al. | Aug 2007 | A1 |
20070198780 | Boyd et al. | Aug 2007 | A1 |
20070226798 | Sibert | Sep 2007 | A1 |
20070234277 | Lei et al. | Oct 2007 | A1 |
20070240155 | Shlomai | Oct 2007 | A1 |
20070245331 | Daynes et al. | Oct 2007 | A1 |
20070277102 | Kanzaki | Nov 2007 | A1 |
20070283324 | Geisinger | Dec 2007 | A1 |
20070288425 | Fuerst et al. | Dec 2007 | A1 |
20070288484 | Yan | Dec 2007 | A1 |
20070294373 | Harrison | Dec 2007 | A1 |
20070294674 | Marilly et al. | Dec 2007 | A1 |
20080010389 | Iwata | Jan 2008 | A1 |
20080016397 | Pagan | Jan 2008 | A1 |
20080034268 | Dodd | Feb 2008 | A1 |
20080034364 | Lam et al. | Feb 2008 | A1 |
20080091739 | Bone et al. | Apr 2008 | A1 |
20080091830 | Koshino | Apr 2008 | A1 |
20080092057 | Monson et al. | Apr 2008 | A1 |
20080109876 | Hitomi et al. | May 2008 | A1 |
20080126785 | Chong et al. | May 2008 | A1 |
20080154985 | Childs et al. | Jun 2008 | A1 |
20080155088 | Chang | Jun 2008 | A1 |
20080155171 | Jeong | Jun 2008 | A1 |
20080163194 | Dias et al. | Jul 2008 | A1 |
20080181230 | Hitt et al. | Jul 2008 | A1 |
20080184135 | Washburn et al. | Jul 2008 | A1 |
20080184211 | Nickolls et al. | Jul 2008 | A1 |
20080201705 | Wookey | Aug 2008 | A1 |
20080215722 | Hogaboom et al. | Sep 2008 | A1 |
20080228770 | Halcrow et al. | Sep 2008 | A1 |
20080235680 | Strauss | Sep 2008 | A1 |
20080244172 | Kano | Oct 2008 | A1 |
20080275938 | Yach | Nov 2008 | A1 |
20080281882 | Hachio et al. | Nov 2008 | A1 |
20080294877 | Haga et al. | Nov 2008 | A1 |
20080298219 | Yamagata et al. | Dec 2008 | A1 |
20080301672 | Rao et al. | Dec 2008 | A1 |
20080320460 | Miller | Dec 2008 | A1 |
20090037287 | Baitalmal et al. | Feb 2009 | A1 |
20090055542 | Zhao et al. | Feb 2009 | A1 |
20090064086 | Faus et al. | Mar 2009 | A1 |
20090076898 | Wang et al. | Mar 2009 | A1 |
20090076966 | Bishop et al. | Mar 2009 | A1 |
20090077551 | Whiteley | Mar 2009 | A1 |
20090077645 | Kottahachchi | Mar 2009 | A1 |
20090110307 | Markowitz | Apr 2009 | A1 |
20090125907 | Wen et al. | May 2009 | A1 |
20090132811 | Koster et al. | May 2009 | A1 |
20090133013 | Criddle et al. | May 2009 | A1 |
20090158432 | Zheng et al. | Jun 2009 | A1 |
20090164570 | Paila | Jun 2009 | A1 |
20090172664 | Mostafa | Jul 2009 | A1 |
20090180475 | Hashimoto | Jul 2009 | A1 |
20090193057 | Maes | Jul 2009 | A1 |
20090198358 | Logan et al. | Aug 2009 | A1 |
20090199175 | Keller et al. | Aug 2009 | A1 |
20090216811 | Manczak et al. | Aug 2009 | A1 |
20090235158 | Rosenstein et al. | Sep 2009 | A1 |
20090240663 | Plattner et al. | Sep 2009 | A1 |
20090248693 | Sagar | Oct 2009 | A1 |
20090248695 | Ozzie | Oct 2009 | A1 |
20090248861 | Kato | Oct 2009 | A1 |
20090249071 | De Atley et al. | Oct 2009 | A1 |
20090249324 | Brar | Oct 2009 | A1 |
20090254575 | Kravets | Oct 2009 | A1 |
20090282399 | Kamrowski | Nov 2009 | A1 |
20090300076 | Friedman et al. | Dec 2009 | A1 |
20090300151 | Friedman et al. | Dec 2009 | A1 |
20090307351 | Raja et al. | Dec 2009 | A1 |
20090307763 | Rawlins et al. | Dec 2009 | A1 |
20090313322 | Sheehan et al. | Dec 2009 | A1 |
20090328030 | Fries | Dec 2009 | A1 |
20100005291 | Hulten et al. | Jan 2010 | A1 |
20100023640 | Vinson et al. | Jan 2010 | A1 |
20100023726 | Aviles | Jan 2010 | A1 |
20100023934 | Sheehan et al. | Jan 2010 | A1 |
20100023974 | Shiragaki et al. | Jan 2010 | A1 |
20100037206 | Larimore et al. | Feb 2010 | A1 |
20100037216 | Carcerano et al. | Feb 2010 | A1 |
20100037235 | Larimore et al. | Feb 2010 | A1 |
20100064295 | Aho et al. | Mar 2010 | A1 |
20100077096 | Philip et al. | Mar 2010 | A1 |
20100082926 | Sahita et al. | Apr 2010 | A1 |
20100088448 | Min et al. | Apr 2010 | A1 |
20100094817 | Ben-Shaul | Apr 2010 | A1 |
20100106804 | He et al. | Apr 2010 | A1 |
20100107163 | Lee | Apr 2010 | A1 |
20100121973 | Lobacheva et al. | May 2010 | A1 |
20100122120 | Lin | May 2010 | A1 |
20100131084 | Van Camp | May 2010 | A1 |
20100132009 | Khemani et al. | May 2010 | A1 |
20100138479 | Zhu | Jun 2010 | A1 |
20100146220 | Panchenko et al. | Jun 2010 | A1 |
20100146590 | Jung | Jun 2010 | A1 |
20100169790 | Vaughan et al. | Jul 2010 | A1 |
20100205604 | Brower et al. | Aug 2010 | A1 |
20100223598 | Levine | Sep 2010 | A1 |
20100235831 | Dittmer | Sep 2010 | A1 |
20100241718 | Rasmussen et al. | Sep 2010 | A1 |
20100250782 | Pratt et al. | Sep 2010 | A1 |
20100257146 | Memon | Oct 2010 | A1 |
20100262948 | Melski et al. | Oct 2010 | A1 |
20100281458 | Paladino et al. | Nov 2010 | A1 |
20100306849 | Zheng et al. | Dec 2010 | A1 |
20100318997 | Li et al. | Dec 2010 | A1 |
20100322523 | Mitsuashi et al. | Dec 2010 | A1 |
20100333085 | Criddle | Dec 2010 | A1 |
20110004840 | Feinberg et al. | Jan 2011 | A1 |
20110010756 | Choi et al. | Jan 2011 | A1 |
20110022940 | King | Jan 2011 | A1 |
20110022947 | Rajkumar | Jan 2011 | A1 |
20110029641 | Fainberg | Feb 2011 | A1 |
20110078625 | Mumford et al. | Mar 2011 | A1 |
20110106908 | Risku et al. | May 2011 | A1 |
20110145428 | Wei et al. | Jun 2011 | A1 |
20110145592 | Greiner | Jun 2011 | A1 |
20110145726 | Wei et al. | Jun 2011 | A1 |
20110153437 | Archer et al. | Jun 2011 | A1 |
20110153975 | Accapadi et al. | Jun 2011 | A1 |
20110153976 | Tamura | Jun 2011 | A1 |
20110154213 | Wheatley | Jun 2011 | A1 |
20110173251 | Sandhu et al. | Jul 2011 | A1 |
20110173607 | Murphey et al. | Jul 2011 | A1 |
20110179411 | Lederer | Jul 2011 | A1 |
20110185013 | Murphey et al. | Jul 2011 | A1 |
20110185043 | Zeller et al. | Jul 2011 | A1 |
20110191772 | Larimore et al. | Aug 2011 | A1 |
20110225584 | Andrade et al. | Sep 2011 | A1 |
20110225592 | Goldin | Sep 2011 | A1 |
20110246659 | Bouazizi | Oct 2011 | A1 |
20110246763 | Karnes | Oct 2011 | A1 |
20110265078 | Beatty et al. | Oct 2011 | A1 |
20110289513 | Degirmenci et al. | Nov 2011 | A1 |
20110289813 | Degirmenci et al. | Nov 2011 | A1 |
20110302274 | Lee et al. | Dec 2011 | A1 |
20120005237 | Obata | Jan 2012 | A1 |
20120005244 | Obata et al. | Jan 2012 | A1 |
20120005246 | Obata | Jan 2012 | A1 |
20120005309 | Obata et al. | Jan 2012 | A1 |
20120005310 | Obata | Jan 2012 | A1 |
20120005334 | Raja et al. | Jan 2012 | A1 |
20120005674 | Larimore et al. | Jan 2012 | A1 |
20120054744 | Singh et al. | Mar 2012 | A1 |
20120090021 | Luh et al. | Apr 2012 | A1 |
20120096071 | Murphey et al. | Apr 2012 | A1 |
20120110337 | Murphey et al. | May 2012 | A1 |
20120125993 | Thiele et al. | May 2012 | A1 |
20120150986 | Piccinini et al. | Jun 2012 | A1 |
20120155358 | Hao et al. | Jun 2012 | A1 |
20120203807 | Larimore et al. | Aug 2012 | A1 |
20120203808 | Larimore et al. | Aug 2012 | A1 |
20130086386 | Murphey et al. | Apr 2013 | A1 |
20130104208 | Kumar et al. | Apr 2013 | A1 |
20130104219 | Kumar et al. | Apr 2013 | A1 |
20130117567 | Chang et al. | May 2013 | A1 |
20130132525 | Tippin | May 2013 | A1 |
20130139250 | Lo et al. | May 2013 | A1 |
20130191882 | Jolfaei | Jul 2013 | A1 |
20130247070 | Larimore et al. | Sep 2013 | A1 |
20130254848 | Ge | Sep 2013 | A1 |
20130271456 | Haswell et al. | Oct 2013 | A1 |
20130275886 | Haswell et al. | Oct 2013 | A1 |
20130283362 | Kress et al. | Oct 2013 | A1 |
20140298401 | Batson et al. | Oct 2014 | A1 |
Entry |
---|
Iowa State University. “Cache Basics and Cache Performance”. URL Link: http://home.eng.iastate.edu/˜zzhang/cpre581/lectures/Lecture12-1p.pdf. Published Fall 2002. Accessed Oct. 2018. (Year: 2002). |
Chapin, “Hive: Operating System Fault Containment for Shared-Memory Multiprocessors,” Jul. 1997, 156 pages. |
Thinstall, “Application Virtualization: A Technical Overview of the Thinstall Application Virtualization Platform,” Nov. 26, 2006, 12 pages. |
Final Rejection received in U.S. Appl. No. 12/188,155, dated Aug. 31, 2012, 22 pages. |
Information Disclosure Statement Transmittal Letter filed herewith on Oct. 15, 2012, 2 pages. |
Non-Final Office Action received in U.S. Appl. No. 12/695,107, dated Dec. 8, 2011, 17 pages. |
Non-Final Office Action received in U.S. Appl. No. 12/188,155, dated Dec. 19, 2011, 19 pages. |
Non-Final Office Action received in U.S. Appl. No. 12/876,085, dated Mar. 8, 2012, 9 pages. |
Non-Final Office Action received in U.S. Appl. No. 12/188,161, dated May 10, 2012, 14 pages. |
Non-Final Office Action received in U.S. Appl. No. 12/879,956, dated Jun. 6, 2012, 11 pages. |
Notice of Allowance received in U.S. Appl. No. 12/877,918, dated Mar. 19, 2012, 25 pages. |
Notice of Allowance received in U.S. Appl. No. 12/877,918, dated Jun. 21, 2012, 31 pages. |
Notice of Allowance received in U.S. Appl. No. 12/877,918, dated Aug. 16, 2012, 22 pages. |
Notice of Allowance received in U.S. Appl. No. 12/877,918, dated Sep. 26, 2012, 24 pages. |
Notice of Allowance received in U.S. Appl. No. 12/697,029, dated Aug. 17, 2012, 21 pages. |
Notice of Allowance received in U.S. Appl. No. 12/188,161, dated Oct. 10, 2012, 22 pages. |
Restriction Requirement received in U.S. Appl. No. 12/188,161, dated Dec. 20, 2011, 5 pages. |
Restriction Requirement received in U.S. Appl. No. 12/876,085, dated Jan. 27, 2012, 6 pages. |
Final Office Action dated Oct. 30, 2012, received in U.S. Appl. No. 12/695,107, 16 pages. |
Final Office Action dated Nov. 14, 2012, received in U.S. Appl. No. 12/876,085, 12 pages. |
Final Office Action dated Nov. 23, 2012, received in U.S. Appl. No. 12/879,956, 11 pages. |
Information Disclosure Statement Transmittal Letter filed herewith on May 23, 2013, 2 pages. |
Non-Final Office Action dated Dec. 13, 2012, received in U.S. Appl. No. 13/449,049, 10 pages. |
Non-Final Office Action dated Dec. 12, 2012, received in U.S. Appl. No. 13/088,265, 24 pages. |
Non-Final Office Action dated Dec. 7, 2012, received in U.S. Appl. No. 13/449,140, 9 pages. |
Non-Final Office Action dated Feb. 28, 2013, received in U.S. Appl. No. 12/188,155, 22 pages. |
Non-Final Office Action dated Mar. 18, 2013, received in U.S. Appl. No. 12/876,085, 13 pages. |
Non-Final Office Action dated Oct. 22, 2012, received in U.S. Appl. No. 12/876,082, 18 pages. |
Non-Final Office Action dated Oct. 24, 2012, received in U.S. Appl. No. 12/916,348, 24 pages. |
Non-Final Office Action dated Nov. 2, 2012, received in U.S. Appl. No. 12/685,576, 8 pages. |
Non-Final Office Action dated Nov. 13, 2012, received in U.S. Appl. No. 12/906,904, 19 pages. |
Notice of Allowance dated Apr. 26, 2013, received in U.S. Appl. No. 12/877,918, 35 pages. |
Notice of Allowance dated Dec. 4, 2012, received in U.S. Appl. No. 12/188,161, 12 pages. |
Notice of Allowance dated May 10, 2013, received in U.S. Appl. No. 12/876,082, 26 pages. |
Notice Of Allowance dated Jan. 4, 2013, received in U.S. Appl. No. 12/188,161, 13 pages. |
Notice Of Allowance dated Feb. 21, 2013, received in U.S. Appl. No. 12/879,956, 17 pages. |
Notice of Allowance dated Apr. 29, 2013, received in U.S. Appl. No. 13/449,049, 9 pages. |
Restriction Requirement dated Mar. 15, 2013, received in U.S. Appl. No. 12/705,492, 5 pages. |
Non-Final Office Action issued in U.S. Appl. No. 12/188,155, dated Feb. 28, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/188,155, dated Oct. 25, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/188,155, dated Feb. 13, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/188,155, dated Jun. 25, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/188,161, dated Dec. 4, 2012. |
Notice of Allowance issued in U.S. Appl. No. 12/188,161, dated Jan. 4, 2013. |
Non-Final Office Action issued in U.S. Appl. No. 12/685,576, dated Nov. 2, 2012. |
Final Office Action issued in U.S. Appl. No. 12/685,576, dated Jan. 30, 2014. |
Non-Final Office Action issued in U.S. Appl. No. 12/685,576, dated Jun. 20, 2013. |
Final Office Action issued in U.S. Appl. No. 12/695,107, dated Oct. 30, 2012. |
Notice of Allowance issued in U.S. Appl. No. 12/697,029, dated May 24, 2013. |
Restriction Requirement issued in U.S. Appl. No. 12/705,492, dated Mar. 15, 2013. |
Restriction Requirement issued in U.S. Appl. No. 12/705,492, dated Aug. 6, 2014. |
Non-Final Office Action issued in U.S. Appl. No. 12/876,082, dated Oct. 22, 2012. |
Notice of Allowance issued in U.S. Appl. No. 12/876,082, dated May 10, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/876,082, dated Feb. 28, 2014. |
Final Office Action issued in U.S. Appl. No. 12/876,085, dated Nov. 14, 2012. |
Non-Final Office Action issued in U.S. Appl. No. 12/876,085, dated Mar. 18, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/876,085, dated Mar. 6, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/876,085, dated Nov. 14, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/877,918, dated Apr. 26, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/877,918, dated Dec. 13, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/877,918, dated Aug. 20, 2013. |
Non-Final Office Action issued in U.S. Appl. No. 12/879,947, dated Jul. 10, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/879,947, dated Jan. 27, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/879,956, dated Feb. 21, 2013. |
Final Office Action issued in U.S. Appl. No. 12/879,956, dated Nov. 23, 2012. |
Non-Final Office Action issued in U.S. Appl. No. 12/906,904, dated Nov. 13, 2012. |
Final Rejection issued in U.S. Appl. No. 12/906,904, dated Jul. 31, 2013. |
Non-Final Office Action issued in U.S. Appl. No. 12/916,348, dated Oct. 24, 2012. |
Final Office Action issued in U.S. Appl. No. 12/916,348, dated Jul. 11, 2013. |
Notice of Allowance issued in U.S. Appl. No. 12/916,348, dated Nov. 13, 2013. |
Non-Final Office Action issued in U.S. Appl. No. 13/088,265, dated Dec. 12, 2012. |
Final Office Action issued in U.S. Appl. No. 13/088,265, dated Jul. 25, 2013. |
Notice of Allowance issued in U.S. Appl. No. 13/088,265, dated Feb. 14, 2014. |
Non-Final Office Action issued in U.S. Appl. No. 13/171,258, dated Apr. 29, 2014. |
Notice of Allowance issued in U.S. Appl. No. 13/449,049, dated Apr. 29, 2013. |
Non-Final Office Action issued in U.S. Appl. No. 13/449,049, dated Dec. 13, 2012. |
Notice of Allowance issued in U.S. Appl. No. 13/449,049, dated Aug. 13, 2013. |
Final Office Action issued in U.S. Appl. No. 13/449,140, dated Jul. 22, 2013. |
Non-Final Office Action issued in U.S. Appl. No. 13/449,140, dated Dec. 7, 2012. |
Non-Final Rejection issued in U.S. Appl. No. 13/449,140, dated Nov. 15, 2013. |
Notice of Allowance issued in U.S. Appl. No. 13/449,140, dated Aug. 11, 2014. |
Non-Final Office Action issued in U.S. Appl. No. 13/683,969, dated Feb. 28, 2014. |
Notice of Allowance issued in U.S. Appl. No. 13/866,682, dated Jun. 25, 2014. |
Non-Final Office Action issued in U.S. Appl. No. 13/918,067, dated Feb. 27, 2014. |
Non-Final Office Action issued in U.S. Appl. No. 12/916,348, dated Sep. 4, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/695,107, dated Sep. 17, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/685,576, dated Sep. 23, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/705,492, dated Sep. 26, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/876,082, dated Sep. 26, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/697,029, dated Oct. 3, 2014. |
Notice of Allowance issued in U.S. Appl. No. 12/906,904, dated Oct. 8, 2014. |
Hung, et al., “Using Behavior Templates to Design Remotely Executing Agents for Wireless Clients,” 2004 4th Workshop on Applications and Services in Wireless Networks (ASWN), (2004). |
Susitaival, et al., “Anaylizing the File Availability and Download Time in a P2P File Sharing System,” IEEE, 2007, pp. 88-95. |
Notice of Allowance received in U.S. Appl. No. 13/866,682, dated Oct. 28, 2014. |
Notice of Allowance received in U.S. Appl. No. 12/705,492, dated Oct. 31, 2014. |
Non-Final Office Action received in U.S. Appl. No. 14/297,506, dated Nov. 6, 2014. |
Non-Final Office Action received in U.S. Appl. No. 13/683,969, dated Nov. 14, 2014. |
Notice of Allowance received in U.S. Appl. No. 13/918,067, dated Nov. 17, 2014. |
Notice of Allowance received in U.S. Appl. No. 13/449,140, dated Nov. 20, 2014. |
Notice of Allowance received in U.S. Appl. No. 12/695,107, dated Jan. 5, 2015. |
Notice of Allowance received in U.S. Appl. No. 12/697,029, dated Jan. 30, 2015. |
Notice of Allowance received in U.S. Appl. No. 13/683,969, dated Feb. 4, 2015. |
Notice of Allowance received in U.S. Appl. No. 13/866,682, dated Feb. 17, 2015. |
Notice of Allowance received in U.S. Appl. No. 12/876,082, dated Feb. 20, 2015. |
Non-Final Office Action received in U.S. Appl. No. 14/297,468, dated Feb. 26, 2015. |
Notice of Allowance received in U.S. Appl. No. 13/918,067, dated Mar. 2, 2015. |
Notice of Allowance received in U.S. Appl. No. 12/695,107, dated Mar. 19, 2015. |
Notice of Allowance received in U.S. Appl. No. 12/916,348, dated Mar. 23, 2015. |
Notice of Allowance received in U.S. Appl. No. 13/683,969, dated Apr. 2, 2015. |
Non-Final Office Action received in U.S. Appl. No. 14/262,511, dated Apr. 27, 2015. |
Notice of Allowance received in U.S. Appl. No. 13/866,682, dated Jun. 5, 2015. |
Notice of Allowance received in U.S. Appl. No. 13/918,067, dated Jun. 15, 2015. |
Notice of Allowance received in U.S. Appl. No. 12/876,082, dated Jun. 17, 2015. |
Non-Final Office Action received in U.S. Appl. No. 14/608,033, dated Jul. 14, 2015. |
Zheng et al., “SODON: A High Availability Multi-Source Content Distribution Overlay,” IEEE, 2004, pp. 87-92. |
Information Disclosure Statement Transmittal Letter filed herewith. |
Non-Final Office Action, dated Feb. 12, 2016, received in U.S. Appl. No. 14/245,707. |
Final Office Action, dated Oct. 16, 2015, received in U.S. Appl. No. 14/297,468. |
Non-Final Office Action, dated Feb. 10, 2016, received in U.S. Appl. No. 14/452,382. |
Notice of Allowance, dated Sep. 12, 2016, received in U.S. Appl. No. 14/452,382. |
Notice of Allowance, dated Jun. 7, 2016, received in U.S. Appl. No. 14/608,444. |
Non-Final Office Action, dated Feb. 12, 2016, received in U.S. Appl. No. 14/789,813. |
Final Office Action, dated Sep. 15, 2016, received in U.S. Appl. No. 14/789,813. |
Notice of Allowance, dated Dec. 21, 2016, received in U.S. Appl. No. 14/789,813. |
Non-Final Office Action, dated Dec. 15, 2016, received in U.S. Appl. No. 14/789,858. |
Final Office Action, dated Jul. 13, 2017, received in U.S. Appl. No. 14/789,858. |
Non-Final Office Action, dated Jul. 28, 2016, received in U.S. Appl. No. 14/877,790. |
Final Office Action, dated May 8, 2017, received in U.S. Appl. No. 14/877,790. |
Notice of Allowance, dated Jun. 23, 2016, received in U.S. Appl. No. 14/877,793. |
Lodi, Giorgia, Middleware Services for Dynamic Clustering of Application Servers (University of Bologna, 2006), 99 pages. |
VMware, “Introduction to VMware ThinApp” (Published Jun. 27, 2008) retrieved from http://www.vmware.com/pdf/thinapp_intro.pdf on Sep. 27, 2015. |
Information Disclosure Statement Transmittal submitted herewith. |
Non-Final Office Action, dated Jul. 5, 2018, received in U.S. Appl. No. 14/789,858. |
Notice of Allowance, dated Jul. 31, 2018, received in U.S. Appl. No. 14/877,790. |
Final Office Action, dated Sep. 12, 2018, received in U.S. Appl. No. 15/081,703. |
Non-Final Office Action, dated Oct. 5, 2017, received in U.S. Appl. No. 14/877,790. |
Non-Final Office Action, dated Nov. 14, 2017, received in U.S. Appl. No. 15/081,703. |
Non-Final Office Action, dated Apr. 19, 2019, received in U.S. Appl. No. 15/081,703. |
Final Office Action, dated Nov. 29, 2019, received in U.S. Appl. No. 15/081,703. |
Non-Final Office Action, dated Aug. 26, 2020, received in U.S. Appl. No. 15/081,703. |
Final Office Action, dated May 26, 2021, received in U.S. Appl. No. 15/081,703. |
Number | Date | Country | |
---|---|---|---|
20120005244 A1 | Jan 2012 | US | |
20160085570 A9 | Mar 2016 | US |
Number | Date | Country | |
---|---|---|---|
61361373 | Jul 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12697029 | Jan 2010 | US |
Child | 13171258 | US |