Software applications may store sensitive data such as passwords, account numbers, financial and health records. Various safeguards may be used to protect such sensitive data, for example, a host operating system may prevent unauthorized users from accessing operating system resources, and the application may encrypt sensitive data, but the application has no safeguard against processes having higher privileges, including the host operating system itself. Secured execution technologies provide the capability to run applications without requiring trust in the system administrator or the system software itself, such as a host operating system or hypervisor. In order to do so, a secured execution technology may create an enclave—a protected environment in which the data within the enclave is isolated from the rest of the system. Code and data inside an enclave are not visible and cannot be manipulated by untrusted processes outside the enclave, and the only way to communicate from within the enclave with the unsecured environment outside the enclave is by sending and receiving messages.
One aspects of the disclosure provides a method for creating trusted applications stored in memory of a host computing device. The method includes creating, by one or more processors of the host computing device, an enclave manager in an untrusted environment of the host computing device, the enclave manager including instructions for creating one or more enclaves; generating, by the one or more processors, an enclave in memory of the host computing device using the enclave manager; generating, by the one or more processors, one or more enclave clients of the enclave by the enclave manager such that the one or more enclave clients configured to provide one or more entry points into the enclave; and creating, by the one or more processors, one or more trusted application instances in the enclave.
In one example, the entry points include a plurality of different functions. In this example, the plurality of different functions include one or more of an initialize function, a finalize function, a run function, a donate thread function, a handle signal function, and a destroy function. In addition, the initialize function allows the one or more enclave clients to take system resources to run the one or more trusted application instances. In addition or alternatively, the finalize function allows the one or more enclave clients to relinquish system resources. In addition or alternatively, the run function allows the one or more enclave clients to execute functions of the one or more trusted application instances. In addition or alternatively, the donate thread function allows the one or more enclave clients to have an operating system of the host computing device provide a thread to enter the enclave. In addition or alternatively, the handle signal function allows the one or more enclave clients handle signals sent to the one or more trusted application instances. In addition or alternatively, the destroy function allows the one or more enclave clients to terminate the enclave.
In another example, the one or more enclave clients are further configured to allow code to run in the enclave. In another example, generating the enclave includes using an application having a trusted application designation. In another example, the method also includes using the enclave manager to maintain a hierarchical namespace by binding the enclave to an identifier in the hierarchical namespace. In this example, the one or more trusted application instances includes code that stores sensitive data of an application running in the untrusted environment. In addition or alternatively, the enclave manager is created by the application. In addition or alternatively, the one or more trusted application instances includes code that executes the sensitive data of the application. In another example, the method also includes using the enclave manager to provide platform services including a software-based clock. In another example, the enclave is generated in a system having an isolation kernel and isolation capable hardware. In another example, the enclave is generated in a system having hardware secure execution primitives and isolation capable hardware. In another example, the enclave is generated in a system having a hardware secure element. In another example, enclave is generated in a system remote from the untrusted environment.
Another aspect of the disclosure provides a method for handling threads of execution using an enclave stored in memory of a host computing device. The method includes receiving, by one or more processors, from an application running in the enclave, a request for a new thread of execution for a function of the application; adding, by the one or more processors, the request for a new thread to a queue of requests the request; requesting, by one or more processors, host software of the host computing device to create the new thread requested by the function in the enclave based on the queue of requests; and allowing, by one or more processors, the new thread to enter the enclave.
In one example, the host software includes a host operating system. In another example, the host software includes a host hypervisor. In another example, the method also includes entering a first thread into the enclave, wherein entering the first thread triggers the request for the new thread and the first thread requires the functionality of the enclave in order to accomplish a task. In another example, the queue of requests is maintained by runtime functionality of the enclave as metadata. In another example, the method also includes using metadata of the enclave to track the function, an argument for the function, and a return value for the new thread. In another example, the method also includes using metadata of the enclave to track a status of the new thread in order to allow the application to access a return value for the new thread. In this example, the method also includes using the host software to send the return value for the thread to the new thread.
In another example, the method also includes allowing the new thread to exit the enclave and, in response to receiving a request form the new thread for a second new thread, using the host software create the second new thread outside of the enclave. In this example, the method also includes after the new thread has exited the enclave, allowing the new thread to enter the enclave and allowing the second new thread to enter the enclave. In addition or alternatively, the method also includes using the queue of request to identify a second function, executing the second function in the enclave using the second new thread to obtain a return value, and allowing the second new thread to exit the enclave after executing the second function. In addition or alternatively, after allowing the second new thread to enter the enclave, determining that the queue of requests is empty and based on the determination, allowing the second new thread to exit the enclave. In addition or alternatively, after allowing the second new thread to enter the enclave, determining that the queue of requests is empty and based on the determination, tearing down the enclave.
In another example, the method also includes creating the queue of requests in metadata of the enclave using runtime functionality of the enclave. In another example, the method also includes updating the queue of requests as the application running in the enclave sends new requests for additional thread of execution for one or more functions of the application. In another example, the new thread is configured to enter the enclave and execute the function. In another example, the enclave is implemented in a system having an isolation kernel and isolation capable hardware. In another example, the enclave is implemented in a system having hardware secure execution primitives and isolation capable hardware. In another example, the method also includes generating the enclave in a system having a hardware secure element. In another example, the enclave is implemented in a system remote from the untrusted environment.
Another aspect of the disclosure provides a method for handling file operations for files of an enclave stored in memory of a host computing device. The method includes receiving, by one or more processors of the host computing device, a request from a function in an enclave to perform a file operation at a file path; delegating, by the one or more processors, the file operation to a host; translating, by the one or more processors, a value of a flag of the file path into a native value of the host computing device for the flag; and forwarding, by the one or more processors, the file path to an enclave manager outside the enclave for further forwarding to host software of the host computing device.
In one example, the file path indicates that the file is in a host access domain configured for handling non-sensitive data available and modifiable by other untrusted software running on the host computing device. In this example, the flag indicates that the file in the host access domain is handled as if in the secure access domain configured for handling encrypted and/or signed data. In addition or alternatively, the method also includes using the file path to determine whether to delegate the file operation to the host software. In another example, the method also includes using the enclave manager to request that the host software opens a file at the file path. In this example, the method also includes receiving, using the enclave manager, a file descriptor from the host software for the file and translating a value of the file descriptor from a native value of the host computing device for the file descriptor into a new value for use inside of the enclave. In addition, the method also includes using a registry to track a mapping between the native value for the file descriptor and the new value. In this example, translating the value of the file descriptor is based on the registry.
In another example, the method also includes using a registry to track a mapping between the native value for the flag and an pre-translation value of the flag for use within the enclave. In this example, translating the value of the flag is based on the registry. In addition or alternatively, the file path indicates that the file is in a secure access domain configured for handling encrypted and/or signed data. In addition or alternatively, the file path indicates that the file is in a virtual memory access domain not backed by persistent storage. In another example, the method also includes adding a prefix to the file path, and wherein the file path forwarded to the enclave manager is the prefixed file path. In another example, the host software includes a host operating system. In another example, the host software includes a host hypervisor. In another example, the method also includes generating the enclave manager outside of the enclave, and the enclave manager includes instructions for creating one or more enclaves. In another example, the method also includes generating the enclave in a system having an isolation kernel and isolation capable hardware. In another example, the method also includes generating the enclave in a system having hardware secure execution primitives and isolation capable hardware. In another example, the method also includes the enclave in a system having a hardware secure element. In another example, the method also includes generating the enclave in a system remote from the untrusted environment.
Another aspect of the disclosure provides a method for handling signals delivered from host software to an enclave stored in memory of a host computing device. The method includes receiving, by one or more processors of the host computing device, a signal at the enclave; in response to receiving the signal, mapping, by the one or more processors, a user-defined signal handler in the enclave to the received signal; sending, by the one or more processors, the mapping to an enclave manager outside of the enclave; generating, by the one or more processors, using the enclave manager instructions indicating that when the signal is received by the host software, the host software must send a host signal function into the enclave to find the user-defined signal handler in order to handle the signal inside of the enclave; and sending the instructions to the host software.
In one example, the method also includes using an enclave manager and the mapping to define a function for the user-defined signal handler outside of the enclave. In another example, the method also includes translating a host value for the signal to an enclave value for the signal for use when the signal is within the enclave. In this example, the translating also includes translating the host value for the signal to a bridge value for signal outside of the enclave and when the signal enters the enclave, translating the bridge value into an enclave value for use when the signal is within the enclave. In another example, the method also includes translating a host value for the signal to an enclave value for the signal for use when the signal is outside of the enclave. In this example, the translating also includes, before the signal is allowed to leave the enclave, translating the enclave value to a bridge value and when the signal has left the enclave, translating the bridge value into the host value for use when the signal is outside of the enclave.
In another example, the method also includes receiving, at the host software, the signal; in response to receiving the signal at the host software, using the instructions to identify the host signal function; and using the host signal function to find the user-defined signal handler in order to handle the signal inside of the enclave. In this example, if the user-defined signal handler is not found, ignoring the signal received at the host software. In another example, the signal is received at the enclave from outside of the enclave. In another example, the method also includes sending, by the enclave, the signal to the enclave manager in order to send the signal to a second enclave. In this example, the method also includes upon receipt of the signal at the enclave manager, using the enclave manager to forward a function to the host software, in response to receiving the function using the host software, interrupting code running in the second enclave and sending a signal to a signal manager of the second enclave to establish a secure channel with the enclave, and sending the signal to the second enclave over the secure channel. In this example, the method also includes finding the user-defined signal handler in order to handle the signal inside of the second enclave. In addition or alternatively, the method also includes, after the signal is handled, resuming the interrupted code.
In another example, the host software includes a host operating system. In another example, the host software includes a host hypervisor. In another example, the method also includes generating the enclave manager outside of the enclave, and the enclave manager includes instructions for creating one or more enclaves. In another example, the method also includes generating the enclave in a system having an isolation kernel and isolation capable hardware. In another example, the method also includes generating the enclave in a system having hardware secure execution primitives and isolation capable hardware. In another example, the method also includes generating the enclave in a system having a hardware secure element. In another example, the method also includes generating the enclave in a system remote from the untrusted environment.
Overview
The technology generally relates to a uniform enclave interface. Secured execution technologies may differ significantly from vendor to vendor in their backend implementations. For instance, enclaves may be supported by different application programming interfaces, applications, and system software (for instance, different operating systems) running on different types of hardware and/or machines. Therefore, for an application to take advantage of the protected environment of a particular secured execution technology backend, the application would need to be designed specifically for the particular secured execution technology, operating system, and in some instances, hardware, backend. The uniform enclave interface described herein implements an abstract set of security guarantees based on which the programmers or users may write software without taking account of how the secured technology is implemented on a particular backend implementation. In other words, the features described herein may be implemented using various different application programming interfaces, applications, and system software (for instance, different operating systems) running on different types of hardware and/or machines and effectively “hide” these details and differences from a user writing software using the uniform enclave interface.
The uniform enclave interface may provide a framework to enable code and data to be securely stored and/or run inside enclaves. The framework may include several basic components, such as an enclave manager, one or more enclave clients, and one or more trusted applications. The enclave manager may be in an untrusted environment and may be configured to create enclaves and enclave clients. The enclave clients may be configured to provide limited entry points for code to enter and exit the enclaves. The trusted applications may be base classes configured to allow users to augment with custom logic handling inside the enclave, resulting in trusted user application instances that can securely run inside the enclave.
Enclaves often are not implemented with a full-fledged operating system and therefore cannot complete certain tasks necessary for running trusted user application instances. In this regard, the uniform enclave interface may provide additional features to enable trusted user application instances to run securely inside the enclaves.
Thread creation and scheduling features may be implemented in the uniform enclave interface. In this regard, when a function inside an enclave requests a new thread, an enclave runtime may exit the enclave to request that the host create a new thread. A queue of new thread requests may be kept inside the enclave. After the host creates the new thread, the enclave runtime re-enters the enclave and waits for the new thread to also enter the enclave. Once the new thread enters the enclave, it checks the queue of new thread requests to execute the function that requested it. When the new thread returns from the function that requested it, it saves the return value and exits the enclave.
File operation features may also be implemented in the uniform enclave interface. In this regard, file paths are separated into access domains having different security properties. A file path may be designated with a path prefix to indicate that the file path belongs to a particular access domain. For example, for file paths in a host access domain containing non-sensitive data, an IO manager inside the enclave may delegate file operations on such file paths directly to the host. For another example, for file paths in a secure access domain containing encrypted or signed data, the IO manager may still delegate the file operations on such file paths to the host, but does not give the host access to cryptographic keys stored inside the enclave such that the host may not access decrypted/unsigned data. For yet another example, for file paths in a virtual memory device domain containing highly sensitive data, the IO manager may not delegate file operations on such file paths to the host at all, rather, the IO manager directly instructs CPU hardware to perform the file operations.
Signal handling features may also be implemented in the uniform enclave interface. In this regard, a framework is provided such that a user may register a signal and a user-defined signal handler for the signal inside the enclave. The signal is also registered on the host with a corresponding host signal handler configured to identify the enclave where the corresponding user-defined signal handler is, enter the enclave, and find and call the corresponding user-defined signal handler to handle the signal. In addition, for signals sent between two enclaves, a remote procedure call (“RPC”) may be established between the two enclaves to ensure secure delivery even if the host is hostile.
Example Systems
Although only a few computing devices and a storage systems are depicted in the system 100, the system may be expanded to any number of additional devices. In addition to a system including a plurality of computing devices and storage systems connected via a network, the features described herein may be equally applicable to other types of devices such as individual chips, including those incorporating System on Chip (SoC) or other chips with memory, that may include one or more enclaves.
Memory 114 of each of computing devices 110, 120, 130 can store information accessible by the one or more processors 112, including instructions that can be executed by the one or more processors. The memory can also include data that can be retrieved, manipulated or stored by the processor. The memory can be of any non-transitory type capable of storing information accessible by the processor, such as a hard-drive, memory card, ROM, RAM, DVD, CD-ROM, write-capable, and read-only memories.
The instructions can be any set of instructions to be executed directly, such as machine code, or indirectly, such as scripts, by the one or more processors. In that regard, the terms “instructions,” “application,” “steps,” and “programs” can be used interchangeably herein. The instructions can be stored in object code format for direct processing by a processor, or in any other computing device language including scripts or collections of independent source code modules that are interpreted on demand or compiled in advance. Functions, methods, and routines of the instructions are explained in more detail below.
Data may be retrieved, stored or modified by the one or more processors 112 in accordance with the instructions. For instance, although the subject matter described herein is not limited by any particular data structure, the data can be stored in computer registers, in a relational database as a table having many different fields and records, or XML documents. The data can also be formatted in any computing device-readable format such as, but not limited to, binary values, ASCII or Unicode. Moreover, the data can comprise any information sufficient to identify the relevant information, such as numbers, descriptive text, proprietary codes, pointers, references to data stored in other memories such as at other network locations, or information that is used by a function to calculate the relevant data.
The one or more processors 112 can be any conventional processors, such as a commercially available CPU. Alternatively, the processors can be dedicated components such as an application specific integrated circuit (“ASIC”) or other hardware-based processor. Although not necessary, one or more of computing devices 110 may include specialized hardware components to perform specific computing processes, such as decoding video, matching video frames with images, distorting videos, encoding distorted videos, etc. faster or more efficiently.
Although
Each of the computing devices 110, 120, 130 can be at different nodes of a network 150 and capable of directly and indirectly communicating with other nodes of network 150. Although only a few computing devices are depicted in
Like the memory discussed above, the storage system 140 may also store information that can be accessed by the computing devices 110, 120, 130. However, in this case, the storage system 140 may store information that can be accessed over the network 150. As with the memory, the storage system can include any non-transitory type capable of storing information accessible by the processor, such as a hard-drive, memory card, ROM, RAM, DVD, CD-ROM, write-capable, and read-only memories.
In this example, the instructions of each of computing devices 110, 120, 130 may include one or more applications. These applications may define enclaves 160, 170, 180, 190 within memory, either locally at memory 114 or remotely at the storage system 140. Each enclave may be “hosted” by the hardware on which the enclave is stored and the software, including operating system software, which is executed on the host computing device. For instance, computing device 110 may be a host computing device for enclaves 160 and 170, and computing device 120 may be a host computing device of enclave 180. In addition, each of enclaves 160, 170, 180 and 190 may be implemented using or on various different application programming interfaces, applications, and system software running on different types of machines (i.e. different types of computing devices). As an example, computing devices 110 and 120 may be different types of machines, running different applications and software with different security protocols, running different operating systems, using different hardware devices. Similarly, enclaves 160, 170, 180 and 190 may each be backed or created by different application programming interfaces and/or applications with different system configurations.
Each enclave can be used to store data and instructions while at the same time limit the use of such data and instructions by other applications. For instance the data may include sensitive information such as passwords, credit card data, social security numbers, or any other information that a user would want to keep confidential. And, as discussed further below, the instructions may be used to limit the access to such data. Although computing device 110 includes only two enclaves, computing device 120 includes only 1 enclave, computing device 130 includes no enclaves, and storage system 140 includes only 1 enclave, any number of enclaves may be defined with the memory of the computing devices 110, 120 or storage system 140.
The Enclave Manager 230 may create one or more enclaves, such as Trusted Enclave 1 of N 242 and Trusted Enclave M or N 244, where N is the total number of enclaves generated by the Enclave Manager 230. In each of the enclaves created by the Enclave Manager 230, a trusted application instance, such as Trusted Application Instance 252 and Trusted Application Instance 254, may be stored and/or executed. For example, Trusted Application Instance 252 and Trusted Application Instance 254 may be two different sets of codes that stores and/or executes sensitive data of User Application 210, or copies of the same code that stores and/or executes sensitive data of User Application 210.
The framework provided by the uniform enclave interface may define an abstraction that allows users to concretize with specific instructions. In this regard, the uniform enclave interface may define a “Trusted Application,” which is the base class for all user enclaves, such as Trusted Enclave 1 of N 242 and Trusted Enclave M or N 244. Users of the uniform enclave interface can then extend this abstract base class by augmenting with custom logic handling to create “Trusted User Applications” that perform specific functions defined by the user. For example, Trusted Application Instance 252 and Trusted Application Instance 254 are trusted user applications defined by the user using the Trusted Application abstract base class.
The Enclave Manager 230 may create Trusted Enclave 1 of N 242 and Trusted Enclave M of N 244 on the same backend, on two backends of a same type, or on two backends of different types. In this regard, the enclave manager may have features that enable implementation of enclaves across multiple different and/or different types of backends. For instance, the Enclave Manager 230 may be configured to bind enclaves to identifiers or names in a namespace. For example, the Enclave Manager 230 may bind each enclave instance it creates, such as Trusted Enclave 1 of N 242 and Trusted Enclave M of N 244, to a name in a common, hierarchical namespace. This way, a uniform reference may be made to loaded enclaves regardless of differences in enclave identifiers due to particular implementations. For another instance, since not all backends make available all platform resources to an enclave, the enclave manager may also provide platform services to enclaves. For example, the Enclave Manager 230 may implement a clock via software for an Intel SGX backend, since a high-frequency hardware clock is not provided by Intel SGX.
The Enclave Manager 230 may also generate one or more enclave clients to provide entry points for code to enter and exit the enclaves. Enclave clients are handles that allow code to run in an enclave. As shown, Enclave Manager 230 creates Enclave Client J of K 262 to provide entry points for Trusted Enclave 1 of N 242, and Enclave Client 1 of K 264 to provide entry points for Trusted Enclave M of N 244, where K is the total number of enclave clients generated by the Enclave Manager 230. Both Enclave Client J of K 262 and Enclave Client 1 of K 264 are in the Untrusted Application Context 220, and provide an interface between the User Application 210 and Trusted Application Instance 252 and Trusted Application Instance 254.
The entry points may include any number of different functions, such as “enter and initialize,” “enter and finalize,” “enter and run,” “enter and donate thread,” “enter and handle signal,” and “enter and destroy.” As such, these functions, such as “enter and run,” “enter and donate thread,” etc. may be interfaces of one or more enclave clients generated by an Enclave Manager, such as an Enclave Manager 230. For instance, Enclave Client J of K 262 may use “enter and initialize” to send code into Trusted Enclave 1 of N 242 to take system resources required to run the Trusted Application Instance 252, and to provide configuration data to the Trusted Enclave 1 of N 242. Enclave Client J of K 262 may use “enter and finalize” to relinquish let go of the system resources in Trusted Enclave 1 of N 242 that is no longer needed. Enclave Client J of K 262 may use “enter and run” to execute functions of the Trusted Application Instance 252. Enclave Client J of K 262 may use “enter and donate thread” to have the operating system provide a thread to enter into the Trusted Enclave 1 of N 242. When the Trusted Application Instance 252 wants to send a signal (for instance to another enclave, a particular thread within the enclave, a process outside of the enclave, to the signal's own thread, etc.), or when a signal is sent to the Trusted Application Instance 252, Enclave Client J of K 262 may use “enter and handle signal” to handle the signal. When Enclave Client J of K 262 is no longer needed, Enclave Client J of K 262 may use “enter and destroy” to terminate Trusted Enclave 1 of N 242. The actual implementation details of such functions may be specific to the features of the backend in which the enclave is operating.
As noted above, the uniform enclave interface 200 may be used for enclaves implemented across any of a number of different types of application programming interfaces, applications, and system software (for instance, different operating systems) running on different types of machines. As such, the uniform enclave interface may also support any number of different types of security architectures and system configurations, such as the example configurations shown in
Enclaves often are not implemented with a full-fledged operating system and therefore cannot complete certain tasks necessary for running a trusted application instance inside an enclave. For example, an application programming interface of the backend may not be able to implement CPU scheduling or resource allocation. Thus, the enclave must rely on the untrusted host software, such as an operating system or hypervisor, for certain tasks. One way to accomplish this is to incorporate a scheduler code in the enclave, but this would overcomplicate the enclave, which would increase an attack surface at the enclave's boundary.
Events of the operations of
Thread A in Enclave 432 then exits the Enclave 410 via exit point “host_donate_thread( )”, for instance, making a call to request the Operating System 420 for a new thread. Once outside the Enclave 410, Thread A 430 requests Operating System 420 to create a thread by calling “pthread_create( )” A return value is represented by “pthread_create return”. The Operating System 420 responds by sending the return value to Thread A 430 and creates a new thread, Thread B 440, outside the Enclave 410.
After learning from “pthread_create return” (“return from pthread_create( )”)that a new thread, Thread B 440, has been created by the Operating System 420, Thread A 430 re-enters the Enclave 410 to wait for Thread B 440 to also enter the Enclave 410. Once Thread B 440 enters Enclave 410 via entry point “donate_thread( )” Thread B in Enclave 442 checks the “start_routine” queue and executes the function in the queue that requested it (i.e. requested a new thread that is now Thread B). In addition, Thread B 440 entering Enclave 410 also triggers the removal of the function from the queue (and/or the request for a new thread, now Thread B, from the queue). Once Thread B in Enclave 442 finishes executing the function requested of it, Thread B in Enclave 442 saves the return value and then exits the Enclave 410 (not shown).
If, upon entering Enclave 410, Thread B in Enclave 442 found that the “start_routine” queue is empty, Thread B in Enclave 442 then would either leave the Enclave 410 and return to some location where it is needed outside the Enclave or tear down the Enclave 410 due to an unexpected condition, such as when the queue is empty.
Applications operating inside an enclave commonly must save state in order to be effective, but the enclave does not have direct access to any persistent hardware and the host, such as an operating system or hypervisor, is not trusted to securely persist sensitive data on the enclave's behalf. Further, applications running in the enclave may not have been written with an adversarial host in mind, and therefore security requirements of individual data persistence operations may need to be inferred based on context. To reduce the attack surface at the enclave's boundary, instead of including file system implementation in the enclave, the example features described herein selectively delegate file operations to the host, such as an operating system or hypervisor, and provide additional protections by the enclave as needed.
In this regard, file paths are separated into access domains having different security properties. The access domains may be configured during initialization of the enclave. A file path may be designated with a path prefix to indicate that the file path belongs to a particular access domain. All file paths having the same path prefix belong to the same access domain, unless the path prefix is superseded by a more specific prefix for another access domain.
Likewise for directories, the same security properties can be maintained for all members of one directory recursively. The access domains may be nested within each other by having a path with another access domain as a directory ancestor, in which case the descendent access domain does not inherit security properties from the ancestor. For instance, for a given access domain at “/ABC” and another one at “/ABC/123r”, these directories are nested. However, the access domains may not be related in any meaningful way: the fact that “/ABC/123” shares part of its prefix with “/ABC” does not mean that it inherits any of the properties of “/ABC”).
The first file operation shown is an open operation. Initially, the CPU is executing code, here Thread 510, inside of Enclave 520. Inside the Enclave 520, an application of the Enclave User Code 522 requests to open a file at file path “/insecure/file.” The request reaches and initiates the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to an IO Manager 526 within the Enclave 520, which is responsible for deciding whether to delegate the file operations to the Host Operating System 540. The IO Manager 526 looks up the file path “/insecure/file,” determines that the file path indicates that the file is in the host access domain and may add a path prefix to the file path.
The file path may also include flags for the POSIX calls, like open, that may include additional arguments that tell it to open the file read-only/read-write/etc or whether to create the file if it doesn't exist, etc. However, across different backends, the values of those flags (e.g., is read-write a “1” or a “2”) can vary, so translation needs to occur. As such, the IO Manager 526 then translates any flag, which may be different for different backends (i.e. different application programming interfaces, etc.), into corresponding host or native values of the Host Operating System 540 (“NATIVE” or Host Access Domain), and delegates the open operation to the Host Operating System 540 using the native values. This enables the IO Manager 526 to function like a virtual filesystem.
Next, the IO Manager 526 passes on the prefixed path to the Enclave Manager 530 outside the Enclave 520. The Enclave Manager 530 then requests the Host Operating System 540 to open the file at the prefixed file path. The Host Operating System 540 opens the file and returns a file descriptor “hostFD” to the Enclave Manager 530. The Enclave Manager 530 then returns hostFD from the open file call.
The IO Manager may maintain a registry or mapping of host file descriptors, internal file descriptors (that is, file descriptors to be used inside of the enclave) and other information. For instance, when the IO Manager, registers hostFD, the IO Manager also creates a mapping between the host file descriptor (hostFD) and its own set of file descriptors (in this case, fd). In this regard, all interactions with the file descriptor inside of the enclave is according to the IO Manager's mapping (i.e. hostFD is used outside of the enclave and hostFD is referred to as fd inside the enclave). As such, the file descriptor “fd” is then passed back to the POSIX Layer 524 and then to the Enclave User Code 522.
The second file operation shown is a read operation. An application of the Enclave User Code 522 requests to read the file with file descriptor fd. The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file descriptor fd (“lookupFD(fd)”) in the mapping (i.e. hostFD), delegates the read operation to the Host Operating System 540, and translates any flag into native values of the Host Operating System 540. Next, the IO Manager 526 passes on the file descriptor hostFD to the Enclave Manager 530 outside the Enclave 520. The Enclave Manager 530 then requests the Host Operating System 540 to read the file with the file descriptor hostFD. The Host Operating System 540 reads the file and returns data read from the file to the Enclave Manager 530. The Enclave Manager 530 passes the data to the IO Manager 526 inside the Enclave 520, which in turn passes the data back to the POSIX Layer 524, and the POSIX Layer 524 passes the data back to the Enclave User Code 522.
The third file operation shown is a close operation. An application of the Enclave User Code 522 requests to close the file with file descriptor fd. The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file descriptor fd, delegates the close operation to the Host Operating System 540, and translates any flag into native values of the Host Operating System 540. The IO Manager 526 also deregisters the file with file descriptor fd. Next, the IO Manager 526 passes on the file descriptor hostFD to the Enclave Manager 530 outside the Enclave 520. The Enclave Manager 530 then requests the Host Operating System 540 to close the file with the file descriptor hostFD. The Host Operating System 540 then closes the file.
The first file operation shown is an open operation. Initially, the CPU is executing code, here Thread 510, inside of Enclave 520. Inside the Enclave 520, an application of the Enclave User Code 522 requests to open a file at file path “/secure/file.” The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager looks up the file path “/secure/file,” determines that the file path indicates that the file is in the secure access domain (“SECURE”), and adds a file prefix to the file path. The IO Manager 526 then translates any flag into native values of the Host Operating System 540, and delegates the open operation to the Host Operating System 540 using the native values. Next, the IO Manager 526 passes on the prefixed file path to the Enclave Manager 530 outside the Enclave 520. The Enclave Manager 530 then passes the prefixed path to the Host Operating System 540 to open the file. The Host Operating System 540 opens the file and returns a file descriptor hostFD to the Enclave Manager 530. IO Manager 526 then registers the file descriptor hostFD and stores to the mapping, as discussed above, the file descriptor fd. The file descriptor fd is then passed back to the POSIX Layer 524 and then to the Enclave User Code 522.
The second file operation shown is a read operation. An application of the Enclave User Code 522 requests to read the file with file descriptor fd. The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file descriptor fd (“lookupFD(fd)”) in the mapping (i.e. hostFD), delegates the read operation to the Host Operating System 540, and translates any flag into native values of the Host Operating System 540. Next, the IO Manager 526 passes on the file descriptor hostFD to the Enclave Manager 530 outside the Enclave 520. The Enclave Manager 530 then requests the Host Operating System 540 to read the file with the file descriptor hostFD. The Host Operating System 540 reads the file and returns encrypted data read from the file to the Enclave Manager 530. Since the encryption key is located only inside the Enclave 520, the Host Operating System 540 would not be able to read the original data. The Enclave Manager 530 then passes the encrypted data to the IO Manager 526 inside the Enclave 520. Once inside the Enclave 520, the IO Manager 526 decrypts the encrypted data with the encryption key inside the Enclave 520 and passes the decrypted data back to the POSIX Layer 524, which the POSIX Layer 524 passes to the Enclave User Code 522. In this regard, encrypted and/or signed data is persisted by creating mirror operations, such that where there is a read operation in the host domain, there is a corresponding read operation in the enclave.
The third file operation shown is a close operation. An application of the Enclave User Code 522 requests to close the file with file descriptor fd. The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file descriptor fd (“lookupFD(fd)”) in the mapping (i.e. hostFD) in order to translate from the enclave value to the native value of the host Operating System 540 and delegates the read operation to the Host Operating System 540 using the native value. The IO Manager 526 also deregisters the file with file descriptor fd. Next, the IO Manager 526 passes on the file descriptor hostFD (i.e. the native value) to the Enclave Manager 530 outside the Enclave 520. The Enclave Manager 530 then requests the Host Operating System 540 to close the file with the file descriptor hostFD. The Host Operating System 540 closes the file. Additionally or alternatively, files in the host access domain can also be treated with similar security properties as files in the secure access domain by specifying a flag with the file operation. For example, in
The first file operation shown is an open operation. Initially, the CPU is executing code, here Thread 510, inside of the enclave 520. Inside the Enclave 520, an application of the Enclave User Code 522 requests to open a file at file path “/dev/random.” The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file path “/dev/random” and determines that the file path indicates that the file is in the virtual memory access domain (“MEMORY”). Recognizing that highly sensitive data is being handled, the IO Manager 526 does not delegate any operation to the Host Operating System 540 or create any mirror operations to the Host Operating System 540, but simply registers the file as internal in the mapping as described above, and returns file descriptor fd to the POSIX Layer 524. The POSIX Layer 524 in turn passes the file descriptor fd back to the Enclave User Code 522.
The second file operation shown is a read operation. An application of the Enclave User Code 522 requests to read the file with file descriptor fd. The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file descriptor fd and determines that the file descriptor indicates that the file is in the virtual memory access domain. Recognizing that highly sensitive data is being handled, the IO Manager 526 does not delegate any operation to the Host Operating System 540 or create any mirror operations to the Host Operating System 540. Rather, the IO Manager sends a request for a random number (“RDRAND”) to be generated directly to the CPU Hardware 550. The CPU Hardware 550 generates secure random data and directly sends the secure random data back to the IO Manager 526 in the Enclave 520. This way, the untrusted Host Operating System 540 cannot manipulate the secure random data. The IO Manager 526 then passes the secure random data to the POSIX Layer 524, which the POSIX Layer 524 passes to the Enclave User Code 522.
The third file operation shown is a close operation. An application of the Enclave User Code 522 requests to close the file with file descriptor fd. The request reaches the POSIX Layer 524 within the Enclave 520. The POSIX Layer 524 then passes on the request to the IO Manager 526 within the Enclave 520. The IO Manager 526 looks up the file descriptor fd and determines that the file descriptor indicates that the file is in the memory device access domain. Recognizing that highly sensitive data is being handled, the IO Manager 526 does not delegate any operation to the Host Operating System 540 or create any mirror operations to the Host Operating System 540, but simply deregisters the file as internal, and nothing is returned o the POSIX Layer 524. Thus, the POSIX Layer 524 passes nothing to the Enclave User Code 522.
Although
As such, the example systems described herein provide a framework that implements signals inside an enclave so that users could register their own signal handler or ignore certain signals inside the enclave, just as they could if the application is running directly on the host. The example systems maintain a mapping between registered signals and registered handlers inside the enclave. A signal handler registered by a user is stored as a signal handler inside the enclave. Meanwhile, a function that enters the enclave and calls the corresponding signal handler in the enclave is registered as a host signal handler on the host. Thus, when a signal arrives, the host signal handler is called by the host operating system to identify the right enclave to enter, enter the boundary of that enclave, and then find and call the registered signal handler inside the enclave.
However, signals may be defined differently across different platforms, and may also be defined differently inside the enclave by the user as compared to by the host. Thus, a user who registers one signal number or value inside the enclave may end up registering a completely different signal number or value on the host. For instance, SIGURS1 may have a value of 4 inside of the enclave and a value of 7 outside of the enclave. To avoid this problem, as in the examples above, the native values may be translated to enclave values. As an example, register(SIGUSR1) call may invoke translation from the enclave value of SIGUSR1 to the native value of SIGUSR1, and a deliverSignal(SIGUSR1) call may invoke translation from native value of SIGUSR1 to the encalve value of SIGUSR1. In other words, the signal value may also be translated between values native to the host operating system and native to the client. In some instances, a bridge value may be used such that every time a user registers a signal, it may be translated to this bridge value before exiting the enclave. Once outside the enclave, the bridge value may be translated into a corresponding host value before it is registered on the host. Likewise, when a signal arrives at the enclave, it may be first translated into the bridge value before entering the enclave, and once inside the enclave, the bridge value may be translated into a corresponding enclave value
Once inside the Enclave 620, the Signal Manager 626 and finds that myHandler is registered by the user to handle SIGUSR1. The function myHandler then calls myHandler in the Enclave User Code 622 to handle SIGUSR1. After SIGUSR1 is handled, the Host Operating System 640 then resumes the application in the Enclave User Code 622.
Events of the example operations of
The signal reaches POSIX Layer 664 of the Second Enclave 660, and then tells the Signal Manager 666 of the Second Enclave 660 to send the signal to the Enclave 620. The Signal Manager 666 of the Second Enclave 660 then forwards the signal to the Enclave Manager 630. The Enclave Manager 630 forwards the kill function, now directed to a specific thread (“thread1”) rather than a process or enclave, to the Host Operating System 640. The Host Operating System 640 interrupts Enclave User Code 622 of the Enclave 620. However, instead of passing on the signal SIGUSR1, the Host Operating System 640 is hostile and sends a signal SIGWRONG to the Signal Manager 626 of the Enclave 620.
The Signal Manager 626 of the Enclave 620 looks up SIGWRONG and may establish a secure channel, for instance via RPC, with the Signal Manager 626 of the Second Enclave 660. Over the established RPC, the Signal Manager 666 of the Second Enclave 660 sends the signal SIGUSR1 to the Signal Manager 626 of the Enclave 620. The Signal Manager 626 of the Enclave 620 then calls the user defined signal handler myHandler in the Enclave User Code 622 to handle SIGUSR1. After SIGUSR1 is handled, the Host Operating System 640 then resumes the application in the Enclave User Code.
Unless otherwise stated, the foregoing alternative examples are not mutually exclusive, but may be implemented in various combinations to achieve unique advantages. As these and other variations and combinations of the features discussed above can be utilized without departing from the subject matter defined by the claims, the foregoing description of the embodiments should be taken by way of illustration rather than by way of limitation of the subject matter defined by the claims. In addition, the provision of the examples described herein, as well as clauses phrased as “such as,” “including” and the like, should not be interpreted as limiting the subject matter of the claims to the specific examples; rather, the examples are intended to illustrate only one of many possible embodiments. Further, the same reference numbers in different drawings can identify the same or similar elements.
The present application is a continuation of U.S. patent application Ser. No. 17/046,593, filed Oct. 9, 2020, which is a national phase entry under 35 U.S.C. § 371 of International Application No. PCT/US2018/042625, filed Jul. 18, 2018, which claims the benefit of the filing date of U.S. Provisional Application No. 62/664,438, filed Apr. 30, 2018, the disclosures of which are hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5970250 | England et al. | Oct 1999 | A |
6085217 | Ault | Jul 2000 | A |
6779112 | Guthery | Aug 2004 | B1 |
6938159 | O'Connor et al. | Aug 2005 | B1 |
7624433 | Clark et al. | Nov 2009 | B1 |
7661131 | Shaw et al. | Feb 2010 | B1 |
7788711 | Sun et al. | Aug 2010 | B1 |
7904940 | Hernacki et al. | Mar 2011 | B1 |
8145909 | Agrawal et al. | Mar 2012 | B1 |
8155036 | Brenner et al. | Apr 2012 | B1 |
8220035 | Pravetz et al. | Jul 2012 | B1 |
8245285 | Ravishankar et al. | Aug 2012 | B1 |
8442527 | Machiraju et al. | May 2013 | B1 |
8631486 | Friedman et al. | Jan 2014 | B1 |
9246690 | Roth et al. | Jan 2016 | B1 |
9251047 | McKelvie et al. | Feb 2016 | B1 |
9374370 | Bent, II et al. | Jun 2016 | B1 |
9444627 | Varadarajan et al. | Sep 2016 | B2 |
9444948 | Ren et al. | Sep 2016 | B1 |
9460077 | Casey | Oct 2016 | B1 |
9531727 | Himberger et al. | Dec 2016 | B1 |
9584517 | Roth et al. | Feb 2017 | B1 |
9615253 | Osborn | Apr 2017 | B1 |
9710748 | Ross et al. | Jul 2017 | B2 |
9735962 | Yang et al. | Aug 2017 | B1 |
9754116 | Roth et al. | Sep 2017 | B1 |
9779352 | Hyde et al. | Oct 2017 | B1 |
9940456 | Nesher et al. | Apr 2018 | B2 |
10007464 | Blinzer | Jun 2018 | B1 |
10021088 | Innes et al. | Jul 2018 | B2 |
10375177 | Bretan | Aug 2019 | B1 |
10382202 | Ohsie et al. | Aug 2019 | B1 |
10530777 | Costa | Jan 2020 | B2 |
11210412 | Ghetti et al. | Dec 2021 | B1 |
20030074584 | Ellis | Apr 2003 | A1 |
20030200431 | Stirbu | Oct 2003 | A1 |
20030202523 | Buswell et al. | Oct 2003 | A1 |
20030236975 | Birk et al. | Dec 2003 | A1 |
20040030764 | Birk et al. | Feb 2004 | A1 |
20040093522 | Bruestle et al. | May 2004 | A1 |
20050050316 | Peles | Mar 2005 | A1 |
20050144437 | Ransom et al. | Jun 2005 | A1 |
20050166191 | Kandanchatha et al. | Jul 2005 | A1 |
20050198622 | Ahluwalia et al. | Sep 2005 | A1 |
20050204345 | Rivera et al. | Sep 2005 | A1 |
20060095969 | Portolani et al. | May 2006 | A1 |
20060130131 | Pai et al. | Jun 2006 | A1 |
20060174037 | Bernardi et al. | Aug 2006 | A1 |
20060225055 | Tieu | Oct 2006 | A1 |
20060274695 | Krishnamurthi et al. | Dec 2006 | A1 |
20080005573 | Morris et al. | Jan 2008 | A1 |
20080005798 | Ross | Jan 2008 | A1 |
20080091948 | Hofmann et al. | Apr 2008 | A1 |
20080244257 | Vaid et al. | Oct 2008 | A1 |
20090077655 | Sermersheim et al. | Mar 2009 | A1 |
20090228951 | Ramesh et al. | Sep 2009 | A1 |
20100150352 | Mansour et al. | Jun 2010 | A1 |
20100313246 | Irvine et al. | Dec 2010 | A1 |
20110075652 | Ogura | Mar 2011 | A1 |
20110113244 | Chou et al. | May 2011 | A1 |
20110225559 | Nishide | Sep 2011 | A1 |
20120151568 | Pieczul et al. | Jun 2012 | A1 |
20120159184 | Johnson et al. | Jun 2012 | A1 |
20120272217 | Bates | Oct 2012 | A1 |
20120275601 | Matsuo | Nov 2012 | A1 |
20130159726 | McKeen et al. | Jun 2013 | A1 |
20130166907 | Brown et al. | Jun 2013 | A1 |
20130312074 | Sarawat et al. | Nov 2013 | A1 |
20130312117 | Sapp, II et al. | Nov 2013 | A1 |
20140086406 | Polzin et al. | Mar 2014 | A1 |
20140089617 | Polzin et al. | Mar 2014 | A1 |
20140089712 | Machnicki et al. | Mar 2014 | A1 |
20140157410 | Dewan et al. | Jun 2014 | A1 |
20140189246 | Xing et al. | Jul 2014 | A1 |
20140189326 | Leslie et al. | Jul 2014 | A1 |
20140267332 | Chhabra et al. | Sep 2014 | A1 |
20140281544 | Paczkowski et al. | Sep 2014 | A1 |
20140281560 | Ignatchenko et al. | Sep 2014 | A1 |
20140297962 | Rozas | Oct 2014 | A1 |
20140337983 | Kang et al. | Nov 2014 | A1 |
20150033012 | Scarlata et al. | Jan 2015 | A1 |
20150089173 | Chhabra et al. | Mar 2015 | A1 |
20150131919 | Dewangan et al. | May 2015 | A1 |
20150178226 | Scarlata et al. | Jun 2015 | A1 |
20150200949 | Willhite et al. | Jul 2015 | A1 |
20150281279 | Smith et al. | Oct 2015 | A1 |
20160036786 | Gandhi | Feb 2016 | A1 |
20160080379 | Saboori et al. | Mar 2016 | A1 |
20160110540 | Narendra Trivedi et al. | Apr 2016 | A1 |
20160147979 | Kato | May 2016 | A1 |
20160171248 | Nesher | Jun 2016 | A1 |
20160173287 | Bowen | Jun 2016 | A1 |
20160179702 | Chhabra et al. | Jun 2016 | A1 |
20160188350 | Shah et al. | Jun 2016 | A1 |
20160188873 | Smith et al. | Jun 2016 | A1 |
20160188889 | Narendra Trivedi et al. | Jun 2016 | A1 |
20160219044 | Karunakaran et al. | Jul 2016 | A1 |
20160219060 | Karunakaran et al. | Jul 2016 | A1 |
20160226913 | Sood et al. | Aug 2016 | A1 |
20160283411 | Sheller et al. | Sep 2016 | A1 |
20160285858 | Li et al. | Sep 2016 | A1 |
20160316025 | Lloyd et al. | Oct 2016 | A1 |
20160330301 | Raindel et al. | Nov 2016 | A1 |
20160350534 | Poornachandran et al. | Dec 2016 | A1 |
20160359965 | Murphy et al. | Dec 2016 | A1 |
20160366123 | Smith et al. | Dec 2016 | A1 |
20160371540 | Pabbichetty | Dec 2016 | A1 |
20160380985 | Chhabra et al. | Dec 2016 | A1 |
20170093572 | Hunt | Mar 2017 | A1 |
20170185766 | Narendra Trivedi et al. | Jun 2017 | A1 |
20170201380 | Schaap et al. | Jul 2017 | A1 |
20170223080 | Velayudhan et al. | Aug 2017 | A1 |
20170256304 | Poornachandran et al. | Sep 2017 | A1 |
20170264643 | Bhuiyan et al. | Sep 2017 | A1 |
20170286320 | Chhabra et al. | Oct 2017 | A1 |
20170286721 | Oct 2017 | A1 | |
20170338954 | Yang et al. | Nov 2017 | A1 |
20170346848 | Smith et al. | Nov 2017 | A1 |
20170353319 | Scarlata et al. | Dec 2017 | A1 |
20170364908 | Smith et al. | Dec 2017 | A1 |
20170366359 | Scarlata et al. | Dec 2017 | A1 |
20180059917 | Takehara | Mar 2018 | A1 |
20180089468 | Rozas et al. | Mar 2018 | A1 |
20180097809 | Chakrabarti et al. | Apr 2018 | A1 |
20180113811 | Apr 2018 | A1 | |
20180114012 | Sood et al. | Apr 2018 | A1 |
20180114013 | Sood et al. | Apr 2018 | A1 |
20180183578 | Chakrabarti | Jun 2018 | A1 |
20180183580 | Scarlata et al. | Jun 2018 | A1 |
20180183586 | Bhargav-Spantzel et al. | Jun 2018 | A1 |
20180191695 | Lindemann | Jul 2018 | A1 |
20180210742 | Costa | Jul 2018 | A1 |
20180211018 | Yang | Jul 2018 | A1 |
20180212971 | Costa | Jul 2018 | A1 |
20180212996 | Nedeltchev et al. | Jul 2018 | A1 |
20180213401 | Yang | Jul 2018 | A1 |
20180232517 | Roth et al. | Aug 2018 | A1 |
20180234255 | Fu | Aug 2018 | A1 |
20180278588 | Cela et al. | Sep 2018 | A1 |
20180285560 | Negi et al. | Oct 2018 | A1 |
20180295115 | Kumar et al. | Oct 2018 | A1 |
20180300556 | Varerkar et al. | Oct 2018 | A1 |
20180337920 | Stites et al. | Nov 2018 | A1 |
20180349649 | Martel et al. | Dec 2018 | A1 |
20180351941 | Chhabra | Dec 2018 | A1 |
20190026234 | Harnik et al. | Jan 2019 | A1 |
20190028460 | Bhargava et al. | Jan 2019 | A1 |
20190034617 | Scarlata | Jan 2019 | A1 |
20190044724 | Sood et al. | Feb 2019 | A1 |
20190044729 | Chhabra | Feb 2019 | A1 |
20190050551 | Goldman-Kirst et al. | Feb 2019 | A1 |
20190058577 | Bowman et al. | Feb 2019 | A1 |
20190058696 | Bowman et al. | Feb 2019 | A1 |
20190103074 | Chhabra et al. | Apr 2019 | A1 |
20190109877 | Samuel et al. | Apr 2019 | A1 |
20190147188 | Benaloh et al. | May 2019 | A1 |
20190149531 | Kakumani et al. | May 2019 | A1 |
20190158474 | Kashyap et al. | May 2019 | A1 |
20190163898 | Clebsch et al. | May 2019 | A1 |
20190197231 | Meier | Jun 2019 | A1 |
20190245882 | Kesavan et al. | Aug 2019 | A1 |
20190253256 | Saab et al. | Aug 2019 | A1 |
20190258811 | Ferraiolo et al. | Aug 2019 | A1 |
20190310862 | Mortensen et al. | Oct 2019 | A1 |
20200233953 | Palsson | Jul 2020 | A1 |
20200387470 | Cui et al. | Dec 2020 | A1 |
Number | Date | Country |
---|---|---|
1685297 | Oct 2005 | CN |
103826161 | May 2014 | CN |
106997438 | Aug 2017 | CN |
107111715 | Aug 2017 | CN |
107787495 | Mar 2018 | CN |
107851162 | Mar 2018 | CN |
1757067 | Feb 2007 | EP |
0143344 | Jun 2001 | WO |
2012082410 | Jun 2012 | WO |
2014062618 | Apr 2014 | WO |
2014158431 | Oct 2014 | WO |
2014196966 | Dec 2014 | WO |
2015066028 | May 2015 | WO |
2015094261 | Jun 2015 | WO |
2016209526 | Dec 2016 | WO |
2018027059 | Feb 2018 | WO |
Entry |
---|
Extended European Search Report for European Patent Application No. 22207041.9 dated Feb. 10, 2023. 8 pages. |
Office Action for Chinese Patent Application No. 201880092471.6 dated Aug. 31, 2023. 10 pages. |
Office Action for Chinese Patent Application No. 201880092577.6 dated Sep. 11, 2023. 8 pages. |
“Proceedings of USENIX ATC '17 2017 USENIX Annual Technical Conference”, USENIX, USENIX, the Advanced Computing Systems Association, Jul. 12, 2017 (Jul. 12, 2017), pp. 1-811, XP061023212, [retrieved on Jul. 12, 2017]. |
First Examination Report for Indian Patent Application No. 202047046012 dated Sep. 17, 2021. 7 pages. |
First Examination Report for Indian Patent Application No. 202047046246 dated Dec. 6, 2021. 5 pages. |
First Examination Report for Indian Patent Application No. 202047046281 dated Dec. 7, 2021. 6 pages. |
Google Cloud Platform, retrieved from https://cloudplatform.googleblog.com/2017/08/Titan-in-depth-security-in-plaintext.html (2017). |
International Preliminary Report on Patentability for International Application No. PCT/US2018/042625 dated Nov. 12, 2020. 12 pages. |
International Preliminary Report on Patentability for International Application No. PCT/US2018/042684 dated Nov. 12, 2020. 12 pages. |
International Preliminary Report on Patentability for International Application No. PCT/US2018/042695 dated Nov. 12, 2020. 9 pages. |
International Search Report and Written Opinion for PCT Application No. PCT/US2018/042625, dated Nov. 30, 2018. 19 pages. |
International Search Report and Written Opinion for PCT Application No. PCT/US2018/042684, dated Dec. 5, 2018. 19 pages. |
International Search Report and Written Opinion for PCT Application No. PCT/US2018/042695, dated Oct. 4, 2018. 16 pages. |
Invitation to Pay Additional Fees, Communication Relating to the Results of the Partial International Search, and Provisional Opinion Accompanying the Partial Search Result for PCT Application No. PCT/US2018/042625, dated Oct. 8, 2018. 14 pages. |
Invitation to Pay Additional Fees, Communication Relating to the Results of the Partial International Search, and Provisional Opinion Accompanying the Partial Search Result for PCT Application No. PCT/US2018/042684, dated Oct. 10, 2018. 14 pages. |
Jouppi, N., et al., “In-Datacenter Performance Analysis of a Tensor Processing Unit”, 44th International Symposium on Computer Architecture (ISCA), (2017) 17 pgs. |
M. M. Ozdal, “Emerging Accelerator Platforms for Data Centers,” in IEEE Design & Test, vol. 35, No. 1, pp. 47-54, Feb. 2018 (Year: 2018). |
McKeen, Frank, et al., “Intel® Software Guard Extensions (Intel® SGX) Support for Dynamic Memory Management Inside an Enclave”, Intel Corporation (2016) 9 pgs. |
Office Action for European Patent Application No. 18750026.9 dated May 9, 2022. 6 pages. |
Office Action for European Patent Application No. 18753285.8 dated Jul. 5, 2022. 8 pages. |
The Next Platform, retrieved from https://www.nextplatform.com/2017/04/05/first-depth-look-googles-tpu-architecture/ (2017). |
Number | Date | Country | |
---|---|---|---|
20230077623 A1 | Mar 2023 | US |
Number | Date | Country | |
---|---|---|---|
62664438 | Apr 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17046593 | US | |
Child | 17950205 | US |