SERVICE PARTITION VIRTUALIZATION SYSTEM AND METHOD HAVING A SECURE PLATFORM

- Unisys Corporation

A secure platform system and method for a host computing device. The system includes an ultraboot application that operates in the less privileged user memory and divides the host computing device into a resource management partition, at least one virtual service partition and at least one virtual guest partition. The virtual guest partition provides a virtualization environment for at least one guest operating system. The virtual service partition provides a virtualization environment for the basic operations of the virtualization system. The resource management partition maintains a resource database for use in managing the use of the host processor and the system resources. The virtual service partition is a secure virtualization platform (s-Platform) having at least one isolated secure partition for executing at least one secure application therein. The system also includes at least one monitor that operates in the most privileged system memory. The monitor maintains guest applications in the virtual guest partition within memory space allocated by the virtual service partition to the virtual guest partition. The system also includes a context switch between the monitor and the respective virtual guest partitions and the virtual service partition. The context switch controls multitask processing in the partitions on the at least one host processor.

Skip to: Description  ·  Claims  · Patent History  ·  Patent History
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims priority to U.S. Patent Application Ser. No. 61/952,267, filed Mar. 13, 2014, which is incorporated by reference in its entirety.

Secure platform system and method for a host computing device having at least one host processor and system resources including memory divided into most privileged system memory and less privileged user memory. The secure platform system includes an ultraboot application that operates in the less privileged user memory and divides the host computing device into a resource management partition, with at least one virtual service partition and at least one virtual guest partition. The virtual guest partition provides a virtualization environment for at least one guest operating system. The virtual service partition provides a virtualization environment for the basic operations of the virtualization system. The resource management virtual service partition maintains a resource database for use in managing the system resources. The at least one virtual service partition is a secure virtualization platform (s-Platform) having at least one isolated secure partition for executing at least one secure application therein. For every virtual partition, a dedicated monitor operates in the most privileged system memory. The monitor maintains guest applications in the virtual guest partition within memory space allocated by the single virtual service partition to the virtual guest partition. The system also includes a context switch between the monitor and the respective virtual guest partitions and the single virtual service partition. The context switch controls multitask processing in the partitions on the host processor.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a schematic view of a host system partitioned using a para-virtualization system, illustrating system infrastructure partitions, according to an embodiment;

FIG. 2 is a schematic view of the host system of FIG. 1, illustrating the partitioned host system of FIG. 1 and the associated partition monitors of each partition, according to an embodiment;

FIG. 3 is a schematic view of the host system of FIG. 1, illustrating memory mapped communication channels amongst various partitions of the para-virtualization system of FIG. 1, according to an embodiment;

FIG. 4a is a schematic view of a host system partitioned using a reduced service partition configuration or architecture, according to an embodiment;

FIG. 4b is a schematic view of a host system partitioned using an alternative reduced service partition configuration or architecture, according to an embodiment;

FIG. 5 is a schematic view of a secure execution environment for a secure or isolated application, according to an embodiment;

FIG. 6 is a schematic view of a secure execution environment for a plurality of secure applications, according to an embodiment;

FIG. 7 is a schematic view of a portion of a host computing system 70 having a reduced service partition architecture secure platform (s-Platform), according to an embodiment;

FIG. 8 is a schematic view of a reduced service partition architecture secure platform (s-Platform) launcher screen, according to an embodiment;

FIG. 9 is a schematic view of a reduced service partition architecture secure platform (s-Platform) launcher menu screen, according to an embodiment;

FIG. 10 is a schematic view of a secure application lifecycle, showing the various states of a secure application running on a reduced service partition architecture secure platform (s-Platform), according to an embodiment; and

FIG. 11 is a flow diagram of a virtualization method for a host system, using a reduced service partition architecture secure platform (s-Platform), according to an embodiment.

DETAILED DESCRIPTION

Various embodiments of the present invention will be described in detail with reference to the drawings, wherein like reference numerals represent like parts and assemblies throughout the several views. Reference to various embodiments does not limit the scope of the invention, which is limited only by the scope of the claims attached hereto. Additionally, any examples set forth in this specification are not intended to be limiting and merely set forth some of the many possible embodiments for the claimed invention.

The logical operations of the various embodiments of the disclosure described herein are implemented as: (1) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a computer, and/or (2) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a directory system, database, or compiler.

In general the present disclosure relates to methods and systems for providing a securely partitioned virtualization system having dedicated physical resources for each partition. In some such examples, a correspondence between the physical resources available and the resources exposed to the virtualized software allows for control of particular features, such as recovery from errors, as well as minimization of overhead by minimizing the set of resources required to be tracked in memory when control of particular physical (native) resources “change hands” between virtualized software.

Those skilled in the art will appreciate that the virtualization design of the invention minimizes the impact of hardware or software failure anywhere in the system on other partitions, while also allowing for improved performance by permitting the hardware to be directly assigned in certain circumstances, in particular, by recognizing a correspondence between hardware and virtualized resources. These and other performance aspects of the system of the invention will be appreciated by those skilled in the art from the following detailed description of the invention.

By way of reference, non-native software, otherwise referred to herein as “virtualized software” or a “virtualized system”, refers to software not natively executable on a particular hardware system, for example, due to it being written for execution by a different type of microprocessor configured to execute a different native instruction set. In some of the examples discussed herein, the native software set can be the x86-32, x86-64, or IA64 instruction set from Intel Corporation of Sunnyvale, Calif., while the non-native or virtualized system might be compiled for execution on an OS2200 system from Unisys Corporation of Blue Bell, Pa. However, it is understood that the principles of the present disclosure are not thereby limited.

In general, and as further discussed below, the present disclosure provides virtualization infrastructure that allows multiple virtual guest partitions to run within a corresponding set of host hardware partitions. By judicious use of correspondence between hardware and software resources, it is recognized that the present disclosure allows for improved performance and reliability by dedicating hardware resources to that particular partition. When a partition requires service (e.g., in the event of an interrupt or other issues which indicate a requirement of service by virtualization software), overhead during context switching is largely avoided, since resources are not used by multiple partitions. When the partition fails, those resources associated with a partition may identify the system state of the partition to allow for recovery. Also, the entire platform will not be taken down if a single guest fails. Furthermore, due to a distributed architecture of the virtualization software as described herein, continuous operation of virtualized software can be accomplished.

FIG. 1 shows an example arrangement of a para-virtualization system that can be used to accomplish the features described herein. In some embodiments, the architecture discussed herein uses the principle of least privilege to run code at the lowest practical privilege. To do this, special infrastructure partitions run resource management and physical I/O device drivers. FIG. 1 illustrates system infrastructure partitions on the left and user guest partitions on the right. Host hardware resource management runs as an ultravisor application in a special ultravisor partition. This ultravisor application implements a server for a command channel to accept transactional requests for assignment of resources to partitions. The ultravisor application maintains the master in-memory database of the hardware resource allocations. The ultravisor application also provides a read only view of individual partitions to the associated partition monitors.

In FIG. 1, a partitioned host (hardware) system (or node) 10 has lesser privileged memory that is divided into distinct partitions, including special infrastructure partitions, such as a boot partition 12, an idle partition 13, a resource management “ultravisor” partition 14, a first input/output (I/O) virtual machine (IOVM) partition 16, a second IOVM partition 18, a command partition 20, an operations partition 22, and a diagnostics partition 19, as well as virtual guest partitions (e.g., a virtual guest partition X 24, a virtual guest partition Y 26, and a virtual guest partition Z 28). As illustrated, the partitions 12-28 do not access the underlying privileged memory and processor registers 30 directly, but instead access the privileged memory and processor registers 30 via a hypervisor system call interface 32 that provides context switches among the partitions 12-28, e.g., in a conventional manner. However, unlike conventional virtual machine monitors (VMMs) and hypervisors, the resource management functions of the partitioned host system 10 of FIG. 1 are implemented in the special infrastructure partitions 12-22.

Furthermore, rather than requiring the re-write of portions of the guest operating system, drivers can be provided in the guest operating system environments that can execute system calls. As explained in further detail in U.S. Pat. No. 7,984,104, assigned to Unisys Corporation of Blue Bell, Pa., these special infrastructure partitions 12-22 control resource management and physical I/O device drivers that are, in turn, used by operating systems operating as guests in the virtual guest partitions 24-28. Of course, many other virtual guest partitions may be implemented in a particular partitioned host system 10 in accordance with the techniques of the present disclosure.

A boot partition 12 contains the host boot firmware and functions to initially load the ultravisor partition 14, the IOVM partitions 16 and 18, and the command partition 20. Once launched, the ultravisor partition 14 includes minimal firmware that tracks resource usage using a tracking application referred to herein as an ultravisor or resource management application. Host resource management decisions are performed in the command partition 20, and distributed decisions among partitions in the host partitioned system 10 are managed by the operations partition 22. The diagnostics partition 19 is responsible for handling diagnostics logs and dumps.

The I/O to disk drive operations and similar I/O operations are controlled by one or both of the IOVM partitions 16 and 18 to provide both failover and load balancing capabilities. Operating systems in the virtual guest partitions 24, 26, and 28 communicate with the IOVM partitions 16 and 18 via memory channels (FIG. 3) established by the ultravisor partition 14. The partitions communicate only via the memory channels. Hardware I/O resources are allocated only to the IOVM partitions 16 and 18. In the configuration of FIG. 1, the hypervisor system call interface 32 functions as a context switching and containment element (monitor) for the respective partitions.

The resource manager application of the ultravisor partition 14, shown as application 40 in FIG. 3, manages a resource database 33 that keeps track of the assignment of resources to partitions, and further serves a command channel 38 to accept transactional requests for assignment of the resources to respective partitions. As illustrated in FIG. 2, the ultravisor partition 14 also includes a partition (lead) monitor 34 that is similar to a virtual machine monitor (VMM), except that the partition monitor 34 provides individual read-only views of the resource database 33 in the ultravisor partition 14 to associated partition monitors 36 of each partition. Thus, unlike conventional VMMs, each partition has its own monitor instance 36 such that failure of the monitor 36 does not bring down the entire host partitioned system 10.

As will be explained below, the guest operating systems in the respective virtual guest partitions 24, 26, 28 can be modified to access the associated partition monitors 36 that implement together with the hypervisor system call interface 32 a communications mechanism through which the ultravisor partition 14, the IOVM partitions 16 and 18, and any other special infrastructure partitions may initiate communications with each other and with the respective virtual guest partitions. However, to implement this functionality, those skilled in the art will appreciate that the guest operating systems in the virtual guest partitions 24, 26, 28 can be modified so that the guest operating systems do not attempt to use the “broken” instructions in the x86 system that complete virtualization systems must resolve by inserting traps.

Basically, the approximately 17 “sensitive” IA32 instructions (those that are not privileged but that yield information about the privilege level or other information about actual hardware usage that differs from that expected by a guest OS) are defined as “undefined,” and any attempt to run an unaware OS at other than ring zero likely will cause the OS to fail but will not jeopardize other partitions. Such “para-virtualization” requires modification of a relatively few lines of operating system code while significantly increasing system security by removing many opportunities for hacking into the kernel via the “broken” (“sensitive”) instructions. Those skilled in the art will appreciate that the partition monitors 36 could instead implement a “scan and fix” operation whereby runtime intervention is used to provide an emulated value rather than the actual value by locating the sensitive instructions and inserting the appropriate interventions.

The partition monitors 36 in each partition constrain the guest OS and its applications to the assigned resources. Each monitor 36 implements a system call interface 32 that is used by the guest OS of its partition to request usage of allocated resources. The system call interface 32 includes protection exceptions that occur when the guest OS attempts to use privileged processor op-codes. Different partitions can use different monitors 36, which allows the support of multiple system call interfaces 32 and for these standards to evolve over time. Different partitions using different monitors 36 also allows the independent upgrade of monitor components in different partitions.

The monitor 36 preferably is aware of processor capabilities so that the monitor 36 may be optimized to use any available processor virtualization support. With appropriate monitor 36 and processor support, a guest OS in a virtual guest partition (e.g., virtual guest partitions 24-28) need not be aware of the ultravisor system of the invention and need not make any explicit “system” calls to the monitor 36. In this case, processor virtualization interrupts provide the necessary and sufficient system call interface 32. However, to improve performance, explicit calls from a guest OS to a monitor system call interface 32 still are desirable.

The monitor 36 also maintains a map of resources allocated to the partition it monitors, and ensures that the guest OS (and applications) in its partition use only the allocated hardware resources. The monitor 36 can do this because the monitor 36 is the first code running in the partition at the processor's most privileged level. The monitor 36 boots the partition firmware at a decreased privilege. The firmware subsequently boots the OS and applications. Normal processor protection mechanisms prevent the firmware, the OS, and the applications from obtaining the processor's most privileged protection level.

Unlike a conventional VMM, the monitor 36 has no I/O interfaces. All I/O operations are performed by I/O hardware mapped to the IOVM partitions 16 and 18, which use memory channels to communicate with their client partitions. Instead, the primary responsibility of the monitor 36 is to protect processor provided resources (e.g., processor privileged functions and memory management units). The monitor 36 also protects access to I/O hardware primarily through protection of memory mapped I/O operations. The monitor 36 further provides channel endpoint capabilities, which are the basis for I/O capabilities between virtual guest partitions.

The monitor 34 for the ultravisor partition 14 is a “lead” monitor with two special roles. First, the monitor 34 creates and destroys monitor instances 36. Second, the monitor 34 provides services to the created monitor instances 36 to aid processor context switches. During a processor context switch, the monitors 34 and monitor instances 36 save the virtual guest partition state in the virtual processor structure, save the privileged state in the virtual processor structure (e.g., IDTR, GDTR, LDTR, CR3), and then invoke the ultravisor monitor switch service. The ultravisor monitor switch service loads the privileged state of the target partition monitor (e.g., IDTR, GDTR, LDTR, CR3) and switches to the target partition monitor, which then restores the remainder of the virtual guest partition state.

The most privileged processor level (i.e., x86 ring 0) is retained by having the monitor instance 36 running below the system call interface 32. This retention is more effective if the processor implements at least three distinct protection levels (e.g., x86 ring 1, 2, and 3) available to the guest OS and applications. The ultravisor partition 14 connects to the monitors 34 and monitor instances 36 at the base (most privileged level) of each partition. The monitor 34 grants itself read only access to the partition descriptor in the ultravisor partition 14, and the ultravisor partition 14 has read only access to one page of the monitor state stored in the resource database 33.

Those skilled in the art will appreciate that the monitors 34 and monitor instances 36 of the invention are similar to a conventional VMM in that they constrain the partition to its assigned resources, the interrupt handlers provide protection exceptions that emulate privileged behaviors as necessary, and system call interfaces are implemented for “aware” contained system code. However, as explained in further detail below, the monitors 34 and monitor instances 36 of the invention are unlike a conventional VMM in that the master resource database 33 is contained in a virtual (ultravisor) partition for recoverability, the resource database 33 implements a simple transaction mechanism, and the virtualized system is constructed from a collection of cooperating monitors 34 and monitor instances 36 whereby a failure in one monitor 34 or monitor instance 36 need not doom all partitions (only containment failure that leaks out does). As such, as discussed below, failure of a single physical processing unit need not doom all partitions of a system, because partitions are affiliated with different processing units.

The monitors 34 and monitor instances 36 of the invention also are different from conventional VMMs in that each partition is contained by its assigned monitor, partitions with simpler containment requirements can use simpler and thus more reliable (and higher security) monitor implementations, and the monitor implementations for different partitions may, but need not be, shared. Also, unlike conventional VMMs, the lead monitor 34 provides access by other monitor instances 36 to the ultravisor partition resource database 33.

Partitions in the ultravisor environment include the available resources organized by the host node 10. A partition is a software construct (that may be partially hardware assisted) that allows a hardware system platform (or hardware partition) to be “partitioned” into independent operating environments. The degree of hardware assist is platform dependent but, by definition, is less than 100% (because, by definition, a 100% hardware assist provides hardware partitions). The hardware assist may be provided by the processor or other platform hardware features. From the perspective of the ultravisor partition 14, a hardware partition generally is indistinguishable from a commodity hardware platform without partitioning hardware.

Unused physical processors are assigned to a special “idle” partition 13. The idle partition 13 is the simplest partition that is assigned processor resources. The idle partition 13 contains a virtual processor for each available physical processor, and each virtual processor executes an idle loop that contains appropriate processor instructions to reduce processor power usage. The idle virtual processors may cede time at the next ultravisor time quantum interrupt, and the monitor 36 of the idle partition 13 may switch processor context to a virtual processor in a different partition. During host bootstrap, the boot processor of the boot partition 12 boots all of the other processors into the idle partition 13.

In some embodiments, multiple ultravisor partitions 14 also are possible for large host partitions, to avoid a single point of failure. Each ultravisor partition 14 would be responsible for resources of the appropriate portion of the host system 10. Resource service allocations would be partitioned in each portion of the host system 10. This allows clusters to run within a host system 10 (one cluster node in each zone), and still survive failure of an ultravisor partition 14.

As illustrated in FIGS. 1-3, each page of memory in an ultravisor enabled host system 10 is owned by one of its partitions. Additionally, each hardware I/O device is mapped to one of the designated IOVM partitions 16, 18. These IOVM partitions 16, 18 (typically two for redundancy) run special software that allows the IOVM partitions 16, 18 to run the I/O channel server applications for sharing the I/O hardware. Alternatively, for IOVM partitions executing using a processor implementing Intel's VT-d technology, devices can be assigned directly to non-IOVM partitions. Irrespective of the manner of association, such channel server applications include a virtual Ethernet switch (which provides channel server endpoints for network channels) and a virtual storage switch (which provides channel server endpoints for storage channels). Unused memory and I/O resources are owned by a special “available” pseudo partition (not shown in the figures). One such “available” pseudo partition per node of host system 10 owns all resources available for allocation.

Referring to FIG. 3, virtual channels are the mechanisms used in accordance with the invention to connect to zones and to provide relatively fast, safe, recoverable communications among the partitions. For example, virtual channels provide a mechanism for general I/O and special purpose client/server data communication between the virtual guest partitions 24, 26, 28 and the IOVM partitions 16, 18 in the same host 10. Each virtual channel provides a command and I/O queue (e.g., a page of shared memory) between two partitions. The memory for a channel is allocated and “owned” by the virtual guest partition 24, 26, 28. The ultravisor partition 14 maps the channel portion of client memory into the virtual memory space of the attached server partition. The ultravisor application tracks channels with active servers to protect memory during teardown of the owner virtual guest partition until after the server partition is disconnected from each channel. Virtual channels can be used for command, control, and boot mechanisms, as well as for traditional network and storage I/O.

As shown in FIG. 3, the ultravisor partition 14 has a channel server 40 that communicates with a channel client 42 of the command partition 20 to create the command channel 38. The IOVM partitions 16, 18 also include channel servers 44 for each of the virtual devices accessible by channel clients 46. Within each virtual guest partition 24, 26, 28, a channel bus driver enumerates the virtual devices, where each virtual device is a client of a virtual channel. The dotted lines in IOVMa partition 16 represent the interconnects of memory channels from the command partition 20 and operations partitions 22 to the virtual Ethernet switch in the IOVMa partition 16 that may also provide a physical connection to the appropriate network zone. The dotted lines in IOVMb partition 18 represent the interconnections to a virtual storage switch. Redundant connections to the virtual Ethernet switch and virtual storage switches are not shown in FIG. 3. A dotted line in the ultravisor partition 14 from the command channel server 40 to the transactional resource database 33 shows the command channel connection to the transactional resource database 33.

A firmware channel bus (not shown) enumerates virtual boot devices. A separate bus driver tailored to the operating system enumerates these boot devices, as well as runtime only devices. Except for the IOVM virtual partitions 16, 18, no PCI bus is present in the virtual partitions. This reduces complexity and increases the reliability of all other virtual partitions.

Virtual device drivers manage each virtual device. Virtual firmware implementations are provided for the boot devices, and operating system drivers are provided for runtime devices. Virtual device drivers also may be used to access shared memory devices and to create a shared memory interconnect between two or more virtual guest partitions. The device drivers convert device requests into channel commands appropriate for the virtual device type.

In the case of a multi-processor host 10, all memory channels 48 are served by other virtual partitions. This helps to reduce the size and complexity of the hypervisor system call interface 32. For example, a context switch is not required between the channel client 46 and the channel server 44 of the IOVM partition 16 because the virtual partition serving the channels typically is active on a dedicated physical processor.

Additional details regarding possible implementations of an ultravisor arrangement are discussed in U.S. Pat. No. 7,984,104, assigned to Unisys Corporation of Blue Bell, Pa., the disclosure of which is hereby incorporated by reference in its entirety.

According to a further embodiment, for enhanced security, an embedded version of the secure partitions and architecture described hereinabove (generally referred to as secure-partition, or s-Par) is described hereinbelow. As described hereinabove, the s-Par secure partition architecture includes a virtualization boot (“ultraboot”) application and a number of service partitions. The ultraboot application, which is a Unified Extensible Firmware Interface (UEFI) application, is responsible for starting the secure partitions. The Unified Extensible Firmware Interface is an interface between an operating system and platform firmware.

According to a further embodiment, the service partitions are reduced to only those partitions that are needed for basic operations, such as the command partition, the I/O partition(s), and a diagnostic partition. FIG. 4a is a schematic view of a host system 10 partitioned using such reduced service partition configuration or architecture, according to an embodiment. As shown, the host system 10 includes a boot partition 11 and a reduced number of service partitions, such as an IOVM partition 17, a command partition 21 and a diagnostic partition 23. The host system 10 can also include one or more guest partitions, such as the guest partition X 24.

Also, according to a further embodiment, the functionality of these reduced service partitions occupies or is moved into a single service partition. FIG. 4b is a schematic view of a host system 10 partitioned using an alternative reduced service partition configuration or architecture, in which the functionality of the reduced service partitions occupies or is moved into a single service partition 25.

The basic structure of this reduced service partition configuration or architecture (which can be referred to as s-Par Lite) involves a relatively small UEFI application (the ultraboot application) and a single service partition based on embedded Linux or other appropriate operating system.

One purpose of this reduced service partition architecture or configuration is to bring a relatively simplified and more accessible version of the secure partition architecture to computing devices and systems that meet the appropriate requirements needed to support and operate the secure partition architecture. The reduced service partition architecture generally can be considered virtualization for the sake of security, as well as convenience. The reduced service partition architecture allows for a downloadable version of the secure partition architecture that is booted directly from the UEFI firmware of the computing device or system.

Also, because the reduced service partition architecture has a smaller footprint than a conventional secure partition architecture, the reduced service partition architecture can be loaded directly from the flash memory of a computing device. Therefore, instead of the computing device booting the reduced service partition architecture (as with a conventional secure partition architecture), the computing device actually contains the reduced service partition architecture as part of its firmware, and executes the reduced service partition architecture as part of the boot sequence of the computing device. Also, as will be discussed hereinbelow, the reduced service partition architecture can be stored on and loaded from a data storage disk or device of the computing device.

According to an embodiment, the reduced service partition architecture requires no separation between the computing device and the reduced service partition architecture. The reduced service partition architecture is embedded in the firmware of the computing device, and therefore makes the computing device appear to an end user as a set of resources that can be assigned to various operating systems. The reduced service partition architecture also allows for a relatively greater level of security, by using a UEFI secure boot to guarantee that the firmware of the computing device, and the reduced service partition architecture as one of its components, are not compromised.

In general, the reduced service partition architecture is an embedded version of the secure partition architecture. The secure partition architecture and design facilitates the ability to implement the reduced service partition architecture. As discussed hereinabove, the core mission of the secure partition architecture is to create and maintain isolated secure partitions. Isolated secure partitions are achieved by providing a Trusted Computing Base (TCB). The TCB contains all of the elements of the system responsible for supporting the security policy and supporting the isolation of objects (code and data) on which the protection is based. The TCB can be divided into two basic categories, based on whether the TCB executes in root mode or executes in non-root mode.

There are two code components that execute in VT-x root mode. The monitor component, which includes VMM handlers, is associated with a dedicated secure partition. The context switch component is associated with a (physical) logical processor.

The monitor assists the VT-x hardware in enforcing the isolation policy. The VMM handlers provide minimal emulation of “legacy” traditional computing device architecture, e.g., advanced programmable interrupt controller (APIC), input/output APIC (IOAPIC), peripheral interface controller (PIC), real-time controller (RTC), programmable interval timer (PIT), advanced configuration and power interface (ACPI) fixed registers, and the COM2 debug output port.

The context switch and VT-x boot (VMXON) for logical-processors (logical processor cores) enables the sharing of logical processors by the secure partition architecture service partitions. The context switch component also enables a control service to perform housekeeping (create/start/halt) of virtual processors in the context of the logical-processor. The context switch component also enables Intel HLT op-code to put unassigned or inactive logical-processors into an ACPI C1 suspended state.

With respect to the TCB executing in a non-root mode, there are several non-root mode code system elements. The ultravisor services are implementations, e.g., C language implementations, which rely only on shared memory. The control service maintains the isolation policy (e.g., processor cores, memory segments/sections, DIRECT devices). The idle service provides for a secure scrub of physical memory devices. The logger and diagnostic service provides secure diagnostic logs for TCB, service and virtual guest components. The ACPI service, which is not a core part of the TCB, provides access to securely enumerate PCY I/O devices (and eventually the host ACPICA AML interpreter).

According to an embodiment, the entire reduced service partition TCB is loaded and booted via the UEFI driver, ultraboot.efi. In this manner, the reduced service partition architecture is placed in the UEFI firmware of the computing device and execution is started from the moment the UEFI firmware loads the driver.

According to a further embodiment, using the s-Par service partition architecture or the s-Par Lite reduced service partition architecture, one or more secure or isolated applications are executed without the need for any specific operating system. The isolated applications also can be executed using a forward fabric architecture, which allows applications and/or services to run across multiple operating systems instantiations that may exist within single or multiple platforms. A secure or isolated application is built using the s-Par service partition, the s-Par Lite reduced service partition, or a forward fabric architecture, and the secure or isolated application is executed within its own isolated secure partition. Alternatively, the secure or isolated application shares its partition only with other secure applications that are allowed to be executed along with the primary secure application.

FIG. 5 is a schematic view of a secure execution environment 50 for a secure or isolated application, according to an embodiment. The secure execution environment 50 includes an isolated, forward fabric or reduced service (s-Par Lite) environment 52. However, it should be understood that the environment 52 can be an isolated s-Par service environment. The isolated environment 52 includes a virtual machine (VM) partition 54 and an isolated application image 56.

The isolated application image 56 includes a first or primary secure or isolated application (code to execute) 58, a security manifest layer or portion 62, and a signing properties or information portion 64. The isolated application image 56 also includes a secure application operating system (OS) layer or portion (such as a JeOS —Just Enough Operating System) 66, which includes a secure application runtime layer or portion 68. Although the JeOS portion 66 is shown as part of the isolated application image 56, the JeOS portion 66 typically is added to the isolated application image 56 by the forward fabric or reduced service (s-Par Lite) environment 52. The JeOS portion 66 typically resides on a read-only memory (ROM) disk that is assigned to the virtual machine (VM) partition 54 at start-up.

The secure execution environment 50 is one type of isolated application environment, according to an embodiment. In the secure execution environment 50, the secure or isolated application 58 can run only by itself. In another type of secure execution environment, as will be described in greater detail hereinbelow, a secure or isolated application can run with some other secure or isolated application.

The secure execution environment 50 is controlled by the security manifest portion 62. The security manifest portion 62 of the secure or isolated application 58 specifies the type of secure or isolated application 58. Also, in the case where the secure or isolated application 58 shares the virtual machine (VM) partition 54, the security manifest portion 62 specifies the application identification (ID) that can share the virtual machine (VM) partition 54 with the secure or isolated application 58.

The security manifest portion 62 also provides information about the isolation and sandboxing of the secure or isolated application 58. Sandboxing, also known as containerization, is an approach that limits or contains the environment in which certain applications can execute. The security manifest portion 62 provides control over whether more than one secure or isolated applications can execute together in the same partition, or whether the secure or isolated applications need separate partitions. The security manifest portion 62 also enforces what specific hardware and software resources the secure or isolated application 58 can access.

According to an embodiment, the secure execution environment 50 provides additional isolation and at a greater level for the secure or isolated application 58 than conventional sandboxing. While conventional sandboxing can provide isolation between applications within an operating system, the secure execution environment 50 provides isolation security for the secure or isolated application 58 at a greater level by the secure or isolated application 58 executing in its own guest or service partition.

According to an embodiment, in addition to providing full isolation for the secure or isolated application 58, the developer of the secure or isolated application 58 must own the developer certificate provided by the partition manufacturer to sign the secure or isolated application 58 and to prove that the secure or isolated application 58 is authentic and comes from the trusted source. No one without the official certificate is able to start the secure or isolated application 58 on the isolated environment 52.

According to an embodiment, the secure or isolated application 58 is executed without any standard operating system (OS). Instead, the secure or isolated application 58 makes use of the JeOS. JeOS refers to a customized operating system that fits the needs of a particular application, e.g., the secure or isolated application 58. A JeOS operating system is an operating system that includes only the portions of an operating system required to support a particular application.

In this manner, the secure application operating system (OS) layer or portion 66 is a JeOS that includes only the operating system portions needed to support the secure or isolated application 58. The secure application operating system (OS) layer or portion 66 also provides the basic input/output (I/O) functionality and process scheduling needed to execute the secure or isolated application 58.

According to an embodiment, the secure or isolated application 58 runs on top of the JeOS, which provides the application programming interfaces (APIs) for the software developer. The software developer is able to create an application to run in this environment using standard development tools and compilers.

Once the developer has the program and security manifest ready, the developer signs the secure or isolated application 58 with (i) the unique developer certificate issued by the partition manufacturer, (ii) the unique isolated application identification (ID), and (iii) the universally unique identifier (UUID) of the isolated environment 52. This signing is required for creating a valid isolated application image 56 that will be recognized by the isolated environment 52.

According to an embodiment, the isolated environment 52 supports secure or isolated applications 58 by verifying the authenticity of the signed image and allowing this image to run only on the environments for which they were signed. The installation of the secure or isolated application 58 is performed by the user.

The secure application runtime layer or portion 68 provides the runtime needed to execute the secure or isolated application 58. As discussed hereinabove, secure application runtime layer or portion 68 is part of the secure application operating system layer or portion 66.

FIG. 6 is a schematic view of a secure execution environment 70 for a plurality of secure or isolated applications, according to an embodiment. The secure execution environment 70 includes the isolated, forward fabric or reduced service (s-Par Lite) environment 52. However, it should be understood that the environment 52 can be an isolated s-Par service environment. The isolated environment 52 includes the virtual machine (VM) partition 54 and isolated application images 56A and 56B for the first or primary isolated or secure application 58A and the second isolated or secure application 58B, respectively.

Each isolated application image 56A, 56B includes a secure or isolated application (code to execute) 58A, 58B, a security manifest layer or portion 62A, 62B, and a signing properties or information portion 64A, 64B. Each isolated application image 56A, 56B also includes a secure application operating system (OS) layer or portion (e.g., a JeOS) 66A, 66B. Each JeOS 66A, 66B includes a secure application runtime layer or portion 68A, 68B.

As discussed hereinabove, the secure execution environment 70 is the type of secure execution environment in which a secure or isolated application (e.g., the first or primary secure or isolated application 58A) can run with some other secure or isolated applications (e.g., the second secure or isolated application 58B). However, according to an embodiment, the first or primary isolated or secure application 58A can be run only with other isolated or secure applications that are allowed to be executed therewith in the secure execution environment 70.

According to a further embodiment, as discussed hereinabove, the s-Par Lite reduced service partition architecture can run as part of the host computing device firmware. Alternatively, the s-Par Lite reduced service partition architecture can be loaded to the host computing device from a memory device, such as a hard disk, a universal serial bus (USB) drive or a smart card (SC). In either event, the s-Par Lite reduced service partition architecture is capable of partitioning the host computing device. Furthermore, this capability of dividing the host computing device among many different partitions without hardware virtualization, but relying on existing and future processor virtualization technology, allows the s-Par Lite reduced service partition architecture to act as a secure platform itself.

In this context, it is possible to think of operating systems like Windows and Linux, as well as s-Par Lite secure or isolated applications, as individual applications running on an s-Par Lite secure platform, which can be referred to as an s-Platform. The s-Platform architecture provides an environment where each secure or isolated application can be written using secure application technology, and launched or executed directly from the s-Platform, and running its own secure and isolated partition on the s-Platform. Also, the launching of operating system virtual machines, such as Windows and Linux virtual machines, is possible, and these operating system virtual machines appears as secure applications on the s-Platform.

Thus, the s-Platform operates as an s-Par Lite computing device that presents and executes secure applications, s-Platform hosts, and operating system virtual machines as applications on the s-Platform. According to an embodiment, all of these applications are available from the moment the computing device is turned on, and all of these applications are accessible from an s-Platform user interface (UI), as will be discussed in greater detail hereinbelow. The s-Platform architecture does not attempt to substitute for or replace any operating system, but it does remove the need for any specific operating system for the secure or isolated application running on the s-Platform. Also, while the s-Platform architecture may be more focused on running secure or isolated applications, the s-Platform architecture is also able to run existing operating systems, as discussed hereinabove. In this context, operating systems like Windows and Linux appear as a special version of a secure or isolated application, and executes with all of existing s-Platform features, including s-Platform security features.

FIG. 7 is a schematic view of a portion of a host computing system 70 having a reduced service partition architecture secure platform (s-Platform) 72, according to an embodiment. The s-Platform 72 includes an s-Par Lite reduced service partition 74, which operates as the secure platform. The s-Platform 72 also can include a UEFI application 76, which can be part of the firmware of the host computing system 70.

As discussed hereinabove, the s-Platform 72 provides an environment in which one or more secure or isolated applications (e.g., a first secure application 78, a second secure application 82 and a third secure application 84) can run as secure, individual applications on the s-Platform 72. Also, as discussed hereinabove, a single application partition (shown as partition 86) can include more than one secure application (e.g., a fourth secure application 88 and a fifth secure application 92) therein. Also, as discussed hereinabove, the s-Platform 72 provides an environment in which one or more operating systems (e.g., a Windows operating system 94 and a Linux operating system 96) can run thereon as individual applications. The s-Platform 72 also can include an S-Par Lite launcher application 98 running thereon, as will be discussed in greater detail hereinbelow.

The s-Platform architecture controls the lifecycle of the secure applications and guests running thereon according to rules and settings provided by the user of the host computing device. Although the s-Platform architecture may seem to act as an operating system of operating systems, the s-Platform architecture instead runs as part of the firmware of the host computing device to partition the computing device and securely isolate each secure application running thereon.

FIG. 8 is a schematic view of a reduced service partition architecture secure platform (s-Platform) launcher screen 102, according to an embodiment. The s-Platform architecture provides the user of the host computing device with the launch or launcher screen 102 when the host computing device is powered on. The s-Platform launcher screen 102 is the primary user interface (UI) for running s-Platform secure applications, interacting with s-Platform secure applications, and controlling various operations of the s-Platform architecture.

The s-Platform launcher screen 102 is presented as the primary user interface as soon as the host computing device is powered on and boots. Using the s-Platform launcher screen 102, a user can start running secure applications, stop running secure applications, or temporarily suspend secure applications. Also, using the s-Platform launcher screen 102, a user can launch regular operating systems running on the s-Platform 72. Such operating systems appear to the user as a regular secure application, but instead of an application being run, the operating system is run.

The s-Platform launcher screen 102 is divided into a number of sections, e.g., launcher menu or pad section 104, a scrollable column section 106 and a mini-windows section 108. The launcher menu or pad section 104 typically appears on the bottom of the s-Platform launcher screen 102, sliding up to appear on the bottom of the s-Platform launcher screen 102 or sliding down to be hidden from the s-Platform launcher screen 102. The launcher menu or pad section 104 typically shows one or more folders 112, as well as the one or more applications 114 in each folder.

The scrollable column section 106 typically appears on the right side of the s-Platform launcher screen 102. The scrollable column section 106 provides one or more icons 115 of the active applications currently running on the s-Platform. Each active application icon 115 has a colored ring around it to identify to the user the status of the particular application. For example, a green ring indicates that the particular application currently is executing, a red ring indicates that the particular application currently is stopped, and a yellow ring indicates that the particular application currently is suspended.

The mini-windows section 108 of the s-Platform launcher screen 102 shows one or more mini windows 116. Each mini window 116 provides video output from each active application that supports video.

FIG. 9 is a more detailed schematic view of the launcher menu or pad section 104, according to an embodiment. The launcher menu or pad section 104 allows a user to organize the secure applications available to be run on the s-Platform. The launcher menu or pad section 104 is a scrollable view that presents available folders 112 and applications 114. A user can search for a particular application 114 by scrolling through the launcher menu or pad section 104 to find the application folder icon 112. Alternatively, the launcher menu or pad section 104 includes a text box 116 that allows a user to type in the name or the beginning of the name of the desired application 114. The launcher menu or pad section 104 brings the searched application 114 to the center of the launcher menu or pad section 104.

Applications can be displayed directly in the launcher menu or pad section 104, or applications can be grouped inside of one or more folders 112. The user can click on a particular folder 112 to display its contents. Clicking on a particular folder 112 causes the folder 112 to slide out the applications 114 within the folder 112 and into view, as shown in FIG. 9. Clicking again on the folder 112 causes the applications 114 within the folder 112 to slide back into the folder 112. The launcher menu or pad section 104 also includes an icon 118 for creating a new folder 112, an icon 122 for adding an application 114 to a selected folder 112, and an icon 124 for removing an application 114 from a folder 112.

FIG. 10 is a schematic view of a secure application lifecycle, showing the various states of a secure application running on a reduced service partition architecture secure platform (s-Platform), according to an embodiment. A secure or isolated application running on the s-Platform 72 can be in one of a number of various states during its lifecycle. Each secure application can be in an active state 132, an inactive state 134, a running state 136 or a suspended state 138.

Each secure application can be active or inactive. Active applications are marked for immediate execution, and are displayed in an active application portion of the launcher menu or pad section 104 of the s-Platform launcher screen 102. Once an application is in an active state, the application can be started or executed. When an application is executed, the application is running in its isolated partition on the s-Platform.

When an application is in its inactive state, the application is not executing. When an application is in its inactive state, the application is unloaded from memory and the resources of the inactive application are returned to the pool of application resources. An application in its inactive state is removed from the active application portion of the launcher menu or pad section 104 of the s-Platform launcher screen 102.

An application suspended state occurs when the monitor suspends the particular application during its execution. In the suspended state, an application may stay loaded in memory, with all of its resources remaining loaded in memory. Alternatively, the resources of an application in the suspended state may be returned to the pool of application resources, for use by another application. Applications can be requested to be suspended, or applications may choose to suspend themselves via an appropriate API call.

The s-Platform may suspend one or more applications to regain some of the resources of the one or more applications to execute one or more other applications. Only applications that advertise a willingness to be suspended would be considered by the s-Platform for suspension. A suspended application can be resumed by the s-Platform either via user request or via a notification message generated by the s-Platform, by an external event or by another application.

The s-Platform provides a global notification system that allows the s-Platform to send notification messages to one or more applications. The global notification system also allows applications to send notification messages to other applications, as long as the security manifest of the particular application allows notification messages to be sent or received.

Also, a secure application specifies within its security manifest if the application should respond to notification messages while the application is suspended. If an application allows notification messages to be received while the application is in a suspended state, the s-Platform automatically tries to resume the suspended application. However, resuming a suspended application may not be possible if there are not enough resources in the resource pool to resume the application. In such case, the notification message will be queued up for the application. Also, notification messages sent to inactive applications will not be delivered, and the API will report the error to the entity sending the notification message.

Another feature of the s-Platform architecture is that a secure or isolated application running on the s-Platform of one host computing system can be moved to and run on the s-Platform of another host computing system, including a mobile device having an s-Platform running thereon. The relocation of a secure or isolated application is accomplished by first suspending the secure or isolated application by changing its state from a run state to a suspended state, then transferring the persistent state of the suspended secure or isolated application to the target s-Platform (e.g., via wifi, Bluetooth or a cloud environment), and then running the secure or isolated application on the target s-Platform by changing its state from the suspended state to the run state.

Transferring an application to a mobile device typically requires that the application be built using dual binaries. That is, the application is compiled to execute on different physical platforms, e.g., the s-Platform and the target mobile device. In this manner, one of the binaries is executed on the s-Platform and the other binary is run on the target mobile device. When the application transfer is to occur, the application on the s-Platform is notified and the application suspends itself by saving its data model and transferring the saved data model to the mobile device.

FIG. 11 is a flow diagram of a virtualization method 140 for a host system, using a reduced service partition architecture secure platform (s-Platform), according to an embodiment. The method 140 includes providing an ultraboot application (shown as 142). As discussed hereinabove, the ultraboot application is a UEFI application that is part of the firmware of the host computing device.

The method 140 also includes executing the ultraboot application to create a secure virtualization platform (s-Platform) (shown as 144). As discussed hereinabove, the ultraboot application is responsible for bootstrapping the secure partition tool, including the reduced service partition configuration or architecture. The ultraboot application divides the hosting computing device into at least one virtual service partition and at least one virtual guest partition.

The at least one virtual guest partition provides a virtualization environment for the at least one virtual operating system. The virtual service partition provides a virtualization environment for the basic operations of the virtualization system. The resource management partition maintaining a resource database for use in managing the use of the at least one host processor and the system resources. Also, as discussed hereinabove, according to an embodiment, the at least one virtual service partition is a secure virtualization platform (s-Platform) having at least one isolated secure partition for executing at least one secure application therein.

The method 140 also includes building a secure or isolated application (shown as 146). As discussed hereinabove, the secure or isolated application is built using the s-Par Lite reduced service partition architecture.

The method 140 also includes executing the secure or isolated application in an isolated secure partition within or on the secure virtualization platform (shown as 148). As discussed hereinabove, the secure or isolated application is executed within its own isolated secure partition within the secure virtualization platform.

The method 140 also includes maintaining guest applications in the virtual guest partition(s) (shown as 152). As discussed hereinabove, a monitor that operates in the most privileged system memory maintains guest applications in the virtual guest partition(s).

The method 140 also includes controlling multitask processing in the partitions (shown as 154). As discussed hereinabove, a context switch between the monitor and the virtual guest partitions controls the multitask processing in the partitions of the computing device.

The method 140 also can include saving/resuming the current execution state of the secure or isolated application (shown as 156). As discussed hereinabove, the current execution state of the secure or isolated application can be shut down or suspended, and saved to a physical storage device. Also, the previously-saved current execution state of the secure or isolated application can be loaded from the physical storage device, and then restarted or resumed directly from the last point of execution, without losing any execution progress.

The method 140 also can include transferring the secure or isolated application (shown as 158). As discussed hereinabove, each secure or isolated application can be transferred between different secure virtualization platforms and computing devices.

One of ordinary skill in the art will appreciate that any process or method descriptions herein may represent modules, segments, logic or portions of code which include one or more executable instructions for implementing logical functions or steps in the process. It should be further appreciated that any logical functions may be executed out of order from that described, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those reasonably skilled in the art. Furthermore, the modules may be embodied in any non-transitory computer readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions.

It will be apparent to those skilled in the art that many changes and substitutions can be made to the embodiments described herein without departing from the spirit and scope of the disclosure as defined by the appended claims and their full scope of equivalents.

Claims

1. A virtualization system for a host computing device having at least one host processor and system resources including memory divided into most privileged system memory and less privileged user memory, the system comprising:

an ultraboot application that operates in the less privileged user memory and divides the host computing device into a resource management partition, at least one virtual service partition and at least one virtual guest partition, the at least one virtual guest partition providing a virtualization environment for the basic operations of the virtualization system, and the resource management partition maintaining a resource database for use in managing the use of the at least one host processor and the system resources,
wherein the at least one virtual service partition is a secure virtualization platform (s-Platform) having at least one isolated secure partition for executing at least one secure application therein;
at least one monitor that operates in the most privileged system memory and maintains guest applications in the at least one virtual guest partition within memory space allocated by the virtual service partition to the at least one virtual guest partition; and
a context switch between the at least one monitor and the respective virtual guest partitions and the virtual service partition for controlling multitask processing in the partitions on the at least one host processor.

2. The system as recited in claim 1, wherein the secure virtualization platform further includes at least one isolated secure partition for executing an operating system therein.

3. The system as recited in claim 1, wherein the secure virtualization platform further includes at least one isolated secure partition for executing a plurality of secure applications within the isolated secure partition.

4. The system as recited in claim 1, wherein the secure virtualization platform comprises a reduced s-Par service partition (s-Par Lite) architecture.

5. The system as recited in claim 4, wherein the reduced s-Par service partition (s-Par Lite) architecture runs as part of the firmware of the host computing device.

6. The system as recited in claim 4, wherein the reduced s-Par service partition (s-Par Lite) architecture is loaded onto the host computing device from a memory device coupled to the host computing device.

7. The system as recited in claim 1, wherein the at least one isolated secure partition includes a security manifest portion for controlling the execution of the at least one secure application within the isolated secure partition.

8. The system as recited in claim 1, wherein the secure virtualization platform includes a user interface that allows a user of the host computing device to manage the execution of the at least one secure application within the isolated secure partition.

9. The system as recited in claim 1, wherein the secure virtualization platform includes a notification system for sending a notification message to the at least one secure application and for allowing a first secure application to send a notification message to a second secure application.

10. The system as recited in claim 1, wherein the at least one secure application is configured to be able to save its current execution state to a physical data storage device coupled to the isolated secure partition, and wherein the secure application is configured to be able resume its previously-saved current execution state without losing any execution progress.

11. The system as recited in claim 1, wherein the at least one virtual service partition further comprises a plurality of secure virtualization platforms, and wherein the at least one secure application is configured to be transferred from a first secure virtualization platform to a second secure virtualization platform.

12. The system as recited in claim 1, wherein the at least one secure application is configured to be transferred from the secure virtualization platform to at least one computing device coupled to the host computing device.

13. A virtualization method for a host computing device having at least one host processor and system resources including memory divided into most privileged system memory and less privileged user memory, the method comprising:

providing an ultraboot application that operates in the less privileged user memory and divides the host computing device into a resource management partition, at least one virtual service partition and at least one virtual guest partition,
executing the ultraboot application to divide the host computing device into at least one virtual service partition and at least one virtual guest partition, the at least one virtual guest partition providing a virtualization environment for at least one guest operating system, the virtual service partition providing a virtualization environment for the basic operations of the virtualization system, and the resource management partition maintaining a resource database for use in managing the use of the at least one host processor and the system resources,
wherein the at least one virtual service partition is a secure virtualization platform (s-Platform) having at least one isolated secure partition for executing at least one secure application therein;
building at least one secure application;
executing the at least one secure application in the at least one isolated secure partition of the secure virtualization platform;
maintaining, by a monitor in the most privileged system memory, guest applications in the at least one virtual guest partition within memory space allocated by the at least one virtual service partition to the at least one virtual guest partition; and
controlling multitask processing in the partitions on the at least one host processor by a context switch between the at least one monitor and the respective virtual guest partitions and the at least one virtual service partition.

14. The method as recited in claim 13, wherein the secure virtualization platform further comprises at least one isolated secure partition for executing an operating system therein, and wherein the method further comprises executing the operating system in the at least one isolated secure partition.

15. The method as recited in claim 13, wherein the secure virtualization platform further includes at least one isolated secure partition for executing a plurality of secure applications within the isolated secure partition.

16. The method as recited in claim 13, wherein the secure virtualization platform comprises a reduced s-Par service partition (s-Par Lite) architecture.

17. The method as recited in claim 16, further comprising running the reduced s-Par service partition (s-Par Lite) architecture as part of the firmware of the host computing device.

18. The method as recited in claim 16, further comprising loading the reduced s-Par service partition (s-Par Lite) architecture onto the host computing device from a memory device coupled to the host computing device.

19. The method as recited in claim 13, wherein the at least one isolated secure partition includes a security manifest portion for controlling the execution of the at least one secure application within the isolated secure partition.

20. The method as recited in claim 13, wherein the secure virtualization platform includes a user interface that allows a user of the host computing device to manage the execution of the at least one secure application within the isolated secure partition.

21. The method as recited in claim 13, wherein the secure virtualization platform includes a notification system for sending a notification message to the at least one secure application and for allowing a first secure application to send a notification message to a second secure application.

22. The method as recited in claim 13, wherein the at least one secure application is configured to be able to save its current execution state to a physical data storage device coupled to the isolated secure partition, and wherein the secure application is configured to be able resume its previously-saved current execution state without losing any execution progress.

23. The method as recited in claim 13, wherein the at least one virtual service partition further comprises a plurality of secure virtualization platforms, and wherein the at least one secure application is configured to be transferred from a first secure virtualization platform to a second secure virtualization platform.

24. The method as recited in claim 13, wherein the at least one secure application is configured to be transferred from the secure virtualization platform to at least one computing device coupled to the host computing device.

25. The method as recited in claim 13, further comprising changing the state of a secure application to an active state.

26. The method as recited in claim 25, further comprising running a secure application that is in the active state.

27. The method as recited in claim 13, further comprising changing the state of a secure application to an inactive state.

28. The method as recited in claim 13, further comprising changing the state of a secure application to a suspended state.

Patent History
Publication number: 20150261952
Type: Application
Filed: Nov 13, 2014
Publication Date: Sep 17, 2015
Applicant: Unisys Corporation (Blue Bell, PA)
Inventors: Robert J. Sliwa (Malvern, PA), Michael J. DiDomenico (Malvern, PA), Brittney Burchett (Malvern, PA), William Deck (Malvern, PA)
Application Number: 14/540,467
Classifications
International Classification: G06F 21/53 (20060101); G06F 9/455 (20060101); G06F 9/48 (20060101);