WO2013142517A1 - Method and system for process working set isolation - Google Patents

Method and system for process working set isolation Download PDF

Info

Publication number
WO2013142517A1
WO2013142517A1 PCT/US2013/033009 US2013033009W WO2013142517A1 WO 2013142517 A1 WO2013142517 A1 WO 2013142517A1 US 2013033009 W US2013033009 W US 2013033009W WO 2013142517 A1 WO2013142517 A1 WO 2013142517A1
Authority
WO
WIPO (PCT)
Prior art keywords
secure
key
cache
data
code
Prior art date
Application number
PCT/US2013/033009
Other languages
French (fr)
Inventor
William V. Oxford
Original Assignee
Krimmeni Technologies, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Krimmeni Technologies, Inc. filed Critical Krimmeni Technologies, Inc.
Priority to JP2015501858A priority Critical patent/JP2015511050A/en
Priority to KR1020147029364A priority patent/KR20150011802A/en
Priority to EP13765051.1A priority patent/EP2828759A4/en
Publication of WO2013142517A1 publication Critical patent/WO2013142517A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/14Protection against unauthorised use of memory or access to memory
    • G06F12/1416Protection against unauthorised use of memory or access to memory by checking the object accessibility, e.g. type of access defined by the memory independently of subject rights
    • G06F12/1425Protection against unauthorised use of memory or access to memory by checking the object accessibility, e.g. type of access defined by the memory independently of subject rights the protection being physical, e.g. cell, word, block
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0806Multiuser, multiprocessor or multiprocessing cache systems
    • G06F12/0815Cache consistency protocols
    • G06F12/0837Cache consistency protocols with software control, e.g. non-cacheable data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0806Multiuser, multiprocessor or multiprocessing cache systems
    • G06F12/0842Multiuser, multiprocessor or multiprocessing cache systems for multiprocessing or multitasking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/14Protection against unauthorised use of memory or access to memory
    • G06F12/1458Protection against unauthorised use of memory or access to memory by checking the subject access rights
    • G06F12/1466Key-lock mechanism
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/14Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using a plurality of keys or algorithms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/30Public key, i.e. encryption algorithm being computationally infeasible to invert or user's encryption keys not requiring secrecy
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3236Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
    • H04L9/3242Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving keyed hash functions, e.g. message authentication codes [MACs], CBC-MAC or HMAC
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1052Security improvement

Definitions

  • This disclosure relates in general to security in computer systems. More specifically, this disclosure relates to securing data (including instructions) associated with processes of a computing system. Even more particularly, this disclosure related to securing data associated with processes of a computing system that are executing in conjunction with an implementation of a recursive security protocol.
  • a secondary, but related problem is that of copyright control.
  • the vast majority of written, audio and visual works of art that are created today either begin or end up in digital format.
  • One of the characteristics of digital data is that it can easily be substantially exactly duplicated. This property facilitates a wide variety of inexpensive distribution mechanisms, most of which are not easily controlled.
  • the inherent inability to limit the distribution of digital content has had far-reaching implications on the field of copyright law over the last couple of decades.
  • access to data that is used by one software process can be denied to any other software process.
  • Embodiments of these systems and methods for data access control can be used in a large number of potential application areas, including the areas of security which may encompass, but are not limited to, the following: digital security, copyright control, conditional access, protection against undesirable computer viruses, etc.
  • embodiments may be utilized in conjunction with a recursive security protocol to augment such a security protocol.
  • embodiments present a simple and easily understood security protocol, made up of three intersecting technology components working together in a unique cooperative framework.
  • the simplicity of the individual components, the complete architectural independence and their low implementation overhead make this system suitable for a wide variety of architectures and deployment scenarios.
  • Embodiments can thus be deployed in simple, low power systems as well as sophisticated, complex high-throughput designs with minimal changes to any pre-existing software.
  • embodiments of such an approach can be shown to possess "Zero-Knowledge" aspects and thus can be provably secure in the face of well-known attack strategies, such as an Adaptive Chosen-Ciphertext attack.
  • attack strategies such as an Adaptive Chosen-Ciphertext attack.
  • a correctly implemented Recursive Security system can be shown to be impervious to Replay Attacks and offer an immunity to Return-Oriented Programming exploits that cannot be matched by competing solutions.
  • Embodiments of a recursive security protocol can also be useful in the fight against malware of all kinds.
  • the Recursive Security protocol can be used to prevent unauthorized and/or modified software executables from running on a system of any architecture.
  • a process may be executing on a processor in a secure mode and data stored in a line of a cache, wherein the data was stored by the process executed on the processor in the secure mode. Access to such lines of cache may be controlled using a secure descriptor associated with the process such that only the process can access the line of the cache, wherein the secure descriptor is based on a secret key stored in the hardware of the system comprising the processor and the cache. According to some embodiments then, access may be controlled even after the process has terminated.
  • the secure mode was entered based on the secure descriptor, an entire working set of the process is stored in the cache and writes to a memory location other than the cache are disabled in the secure mode.
  • the line of the cache may be associated with the secure descriptor associated with the process or a security flag associated with the line of the cache may be set when the process writes the data.
  • controlling access to a line of cache may include determining that the line of cache is being accessed by a currently executing process, determining if a currently executing process is executing in secure mode, determining a secure descriptor associated with the currently executing process, comparing the secure descriptor and with the secure descriptor associated with the line and allowing access only if the currently executing process is executing in secure mode and the secure descriptors match.
  • FIGURE 1 depicts one embodiment of an architecture for content distribution.
  • FIGURE 2 depicts one embodiment of a target device.
  • FIGURE 3 depicts one embodiment of a secure execution controller.
  • FIGURES 4A and 4B depict an embodiment of a cache used for process working set
  • FIGURE 5 depicts an embodiment of secured code block execution.
  • FIGURE 6 depicts an embodiment of secured code block execution.
  • FIGURE 7 depicts an embodiment of secured code block execution.
  • FIGURES 8-14 depicts an embodiment of process working set isolation.
  • FIGURE 15 depicts an embodiment of compound key generation.
  • FIGURE 16 depicts an embodiment of compound key generation.
  • FIGURE 17 depicts an embodiment of compound key generation.
  • FIGURE 18 is a representation of an embodiment of a decryption key data structure.
  • FIGURE 19 is a diagram for an embodiment of the encryption and distribution process of a security protocol.
  • FIGURE 20 is a diagram of the decryption and loading process for an embodiment of a security protocol.
  • FIGURE 21 is a diagram of one embodiment of the encryption/decryption process of a security protocol.
  • FIGURE 22 is a representation of an embodiment of a key list data structure.
  • FIGURE 23 is a diagram of an embodiment of the temporary key ownership transfer
  • FIGURE 24 depicts one embodiment of the creation of a compound key.
  • FIGURES 25A and 25B depict embodiments of the creation of digital signatures or their equivalents.
  • FIGURES 26A and 26B depict embodiments of the use of a compound key structure with a secured code block.
  • FIGURE 27 depicts one embodiment of the use of a compound message digest.
  • FIGURE 28A, 28B and 28C depict embodiments of a secured code block message.
  • FIGURE 29 depicts an embodiment of a decryption operation.
  • FIGURE 30 depicts one embodiment of the use of a compound key.
  • FIGURE 31 depicts one embodiment of the use of a compound key in the authorization of a candidate code block.
  • FIGURE 32 depicts one embodiment of a decryption operation.
  • FIGURE 33 depicts one embodiment of the validation of a code block.
  • FIGURE 34 depicts one embodiment of a decryption operation performed using a recursive security protocol.
  • FIGURE 35 depicts one embodiment of the operation of code validation.
  • FIGURE 36 depicts one embodiment of a digital signature function block.
  • the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion.
  • a process, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, article, or apparatus.
  • "or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
  • any examples or illustrations given herein are not to be regarded in any way as restrictions on, limits to, or express definitions of, any term or terms with which they are utilized. Instead, these examples or illustrations are to be regarded as being described with respect to one particular embodiment and as illustrative only. For example, though embodiments as described herein have been described in conjunction with their
  • Embodiments of the present invention can be implemented in a computer communicatively coupled to a network (for example, the Internet, an intranet, an internet, a WAN, a LAN, a SAN, etc.), another computer, or in a standalone computer.
  • a network for example, the Internet, an intranet, an internet, a WAN, a LAN, a SAN, etc.
  • the computer can include a central processing unit (“CPU”) or processor, at least one read-only memory (“ROM”), at least one random access memory (“RAM”), at least one hard drive (“HD”), and one or more input/output (“I/O") device(s).
  • the I/O devices can include a keyboard, monitor, printer, electronic pointing device (for example, mouse, trackball, stylist, etc.), or the like.
  • the computer has access to at least one database over the network.
  • ROM, RAM, and HD are computer memories for storing computer-executable instructions executable by the CPU or capable of being complied or interpreted to be executable by the CPU.
  • computer readable medium is not limited to ROM, RAM, and HD and can include any type of data storage medium that can be read by a processor.
  • a computer-readable medium may refer to a data cartridge, a data backup magnetic tape, a floppy diskette, a flash memory drive, an optical data storage drive, a CD-ROM, ROM, RAM, HD, or the like.
  • a computer readable medium for example, a disk, CD-ROM, a memory, etc.
  • the computer-executable instructions may be stored as software code components on a DASD array, magnetic tape, floppy diskette, optical storage device, or other appropriate computer- readable medium or storage device.
  • the computer-executable instructions may be lines of C++, Java, JavaScript, or any other programming or scripting code.
  • HTML may utilize JavaScript to provide a means of automation and calculation through coding.
  • Other software/hardware/network architectures may be used.
  • the functions of the present invention may be implemented on one computer or shared among two or more computers. In one embodiment, the functions of the present invention may be distributed in the network. Communications between computers implementing embodiments of the invention can be accomplished using any electronic, optical, radio frequency signals, or other suitable methods and tools of communication in compliance with known network protocols. In another embodiment, this communication between systems may be effected by using a printed medium, where a user can provide the communicated data to a target "endpoint" system by entering it manually.
  • a module is one or more computer processes, computing devices or both, configured to perform one or more functions.
  • a module may present one or more interfaces which can be utilized to access these functions. Such interfaces include APIs, web services interfaces presented for a web services, remote procedure calls, remote method invocation, etc.
  • DRM Digital Rights Management
  • the ability to decrypt the data may be mediated by a single (usually global) key that according to embodiments remains secret.
  • Another concern is that of whether or not to globally encrypt a distributed data set (which can then be freely shared, as we discussed earlier) or to distribute multiple individual encrypted copies of this same data set, where each of the designated authorized recipients is given an individually encrypted copy.
  • it is in most cases actually a less secure strategy than to perform a single "global" encryption (with an associated "global” encryption key) and to just distribute the singly (and globally) encrypted data set.
  • This is due to the fact that the encrypted data sets will all have a common plaintext source, with common statistics that can be analyzed in order to provide a wealth of additional information regarding the value of the secret keys used in the encryption process. So the correct strategy in most cases is to perform a single encryption (with a single global secret key) and to distribute only the globally encrypted data set.
  • the security "envelope” should extend the boundaries of the control mechanism beyond just the decryption process. If even one correctly decrypted, but otherwise "uncontrolled” digital copy is created, that uncontrolled copy can be digitally duplicated without limit. Once the "digital genie" is freed, it can never be put back into the bottle. Thus, to truly control data (copyrighted or otherwise), entities that correctly decrypt encrypted data should be kept from redistributing decrypted versions. It is thus desirable to control both decryption as well as any potential re-distribution in order to achieve the goal of effective control of digital data (e.g., copyrighted data).
  • the transmission link should exhibit the same robustness against external observers and interference as the primary means of distribution. Otherwise, prospective attackers may simply target the weaker link.
  • no single key e.g., a global key
  • Each key must be combined with at least one other key to construct a compound key.
  • precursor keys the original individual keys of which a compound key is comprised.
  • any compound key may be constructed by combining at least two precursor keys it can be seen that, given a minimally bipartite compound key, a single compound key may in fact be based on any number of precursor keys. We will discuss how this is accomplished below.
  • any of the other precursor keys may then potentially be public data, and may thus either be published or not, depending on the needs and architecture of the overall security system. It can be shown that, as long as there is at least one secret precursor key in a given compound key's chain of construction, then the overall security of the compound-key based system can essentially be conditioned on the security of that single secret precursor key.
  • a compound key may be generated by a secure oneway hash function.
  • a compound key can be generated by concatenating at least two precursor keys and passing the resultant concatenated data set through a one-way hash function.
  • the one-way property of the hash function makes this kind of transformation irreversible. That means there is no practical way to recreate the value of any of the precursor keys from the resulting compound key.
  • a second attribute of a one-way hash function is that it may include a built-in data compression function. Thus, no matter how long the input data set (e.g., the precursor keys may be of any arbitrary length), the resulting output (the compound key) will have a fixed length.
  • the one-way compound key procedure can be generalized such that none of the precursor key inputs must be of a fixed length. However, in the case where the assumption is made that one of the precursor keys (for example, the secret precursor key) is of a fixed length, then one can further assign that fixed length precursor key to carry the secret key value (upon which the overall security of the system depends).
  • this is effectively the goal of a successful security system; that of condensing the requisite secret knowledge down to a minimum size; as long as that minimum size is sufficiently large to prevent it from being easily guessed.
  • FIGURE 16 One example of how we might construct such a reversible compound key is shown in FIGURE 16. Of course, it should be realized there are a number of methods by which this could be accomplished, and the example shown in FIGURE 16 is simply one such example. The common feature of such a structure, however, may be that there are at least two "precursor" inputs.
  • the plaintext 1610 and the key 1620 correspond to the two precursors (e.g., the secret key precursor and the public key precursor) of the one-way compound key structure that we discussed earlier.
  • the reversible compound key may be created using at least two precursors.
  • the construction can be generalized into a "cascaded” or “chained” compound key structure, where a final compound structure is dependent on any number of precursor inputs.
  • FIGURE 16 One example of how to create such a "cascaded" reversible compound key is also shown in FIGURE 16.
  • a reversible compound key may then be used as a digital signature resulting from the "seeding" of the hash function with the secret precursor key and one of a public - private key set.
  • Such a construction could then be used for signing digital documents in a secure manner on a given platform.
  • one precursor for compound key operation may be a secret key stored in the hardware of the target device.
  • a hardware secret key may, in many cases, serve as a part of the root of a "Chain of Trust" of such a recursive security system.
  • other aspects of the system could also be a part in this hardware "Chain of Trust”.
  • Such aspects could include the secure one-way hash function, a one-time- programmable serial number register (which could be architecturally visible) or even some parametric property of the silicon die itself, such as a threshold voltage versus temperature curve or some value that is only observable when the chip in question is put into Scan / Test mode, for example.
  • a particular chip could be distinctly and individually differentiated from an otherwise functionally identical device.
  • such a secret key may only be accessible when a processor of a target device is operating in a secure execution mode (also referred to as secured mode).
  • a process executing in secure mode on such a target device may have access to the secret key and may generate data based on this secret key.
  • a secret key (or some derivative thereof) in a calculation that may potentially expose some other secret; either if the calculation's operation is halted prior to completion or if some intermediate result of such calculation is exposed to an outside observer.
  • the working set e.g., the data read or written from memory such as cache, main memory, registers, etc.
  • such a security system may be vulnerable to man in the middle attacks and differential cryptanalysis. This is due to the fact that the partial result of an otherwise invalid operation may provide a window into what would be an otherwise opaque "black-box" based system. In other words, working backwards from a working set of a process, it may be possible to discover a derivative value of the secret key that is being used by the secure process and thus compromising the chain of trust of the security system.
  • embodiments of such systems and methods may isolate the working set of a process executing in secure mode such that the data is inaccessible to any other process, even after the original process terminates.
  • the entire working set of a currently executing process may be stored in cache (e.g., an on-chip cache) and off-chip writes and write-through of that cache disallowed when executing in secured mode.
  • cache e.g., an on-chip cache
  • those cache lines may be associated with a secure descriptor for the currently executing process.
  • the secure descriptor may uniquely specify those associated "dirty" cache lines as belonging to the executing secure process, such that access to those cache lines can be restricted to only that process.
  • the secure descriptor may be a compound key.
  • a compound key may be produced for use as a secure process descriptor using the target device's secret key.
  • a compound key may be produced without comprising the target device's secret key.
  • a dedicated hash functional block is provided in the target device, the output of such a hash block (or a secure execution controller comprising the hash block) may be used to create these secure process descriptors using the secret key of the target device.
  • additional values may also be used in conjunction with the target device's secret key in the evaluation of the one-way hash function in order to produce this secure descriptor. Such additional values may or may not be visible to the processor without compromising the value of the secret key. Some examples of these additional values might include a timestamp, a process ID, the previously-calculated result of the hash function or any other attribute that can be represented in digital form.
  • the size of these additional values can be completely arbitrary.
  • the secure process descriptor may include information regarding the time of execution of the secure process, as well as the entire calling chain of the secure process in question.
  • the working set for a secure process overflows the on-chip cache, and portions of that cache that include those dirty lines associated with the secure process descriptor need to be written to main memory (e.g., a page swap or page out operation) external data transactions between the processor and the bus (e.g., an external memory bus) may be encrypted.
  • the key for such an encryption may be the secure descriptor itself or some derivative value thereof, for example, the output of the hash function with the secure process descriptor and the secret key.
  • an encryption key might be an encrypted version of the secure process descriptor.
  • the encryption key used in this latter case may be the output of the hash function of the secret key concatenated with the current secure process descriptor and some other value. This latter value could then be published (e.g., written out to memory in the clear). In that case, then only the secure process that actually generated the data that was encrypted and then subsequently written out to memory in the first place could regenerate the correct decryption key and thus, restore the original data as it is read from memory back into the data cache.
  • the two processes should communicate a shared secret decryption key between one and the each other.
  • the shared secret decryption key is generated by a reversible compound key process
  • the shared data may be writeable by the secure process that is the recipient of the shared data.
  • the shared key is based on a one-way compound key mechanism, then the shared data may be limited to read-only access for the recipient.
  • a subset of the processes working set that is considered "secure” may be created (e.g., only a subset of the dirty cache lines for the process may be associated with the secure descriptor) and only encrypt those cache lines or the portion of the cache containing those lines, when it is written out to external memory.
  • an off-chip storage mechanism e.g., a page
  • swapping module can be run asynchronously in parallel with an interrupting process (e.g., using a DMA unit with integrated AES encryption hardware acceleration) and thus, could be designed to have a minimal impact on the processor performance.
  • interrupting process e.g., using a DMA unit with integrated AES encryption hardware acceleration
  • a separate secure "working set encapsulation" module may be used to perform the encryption prior to allowing working set data to be written out to memory.
  • recursive security devices may be made substantially impervious to replay attacks and offer an immunity to return-oriented, or other, programming exploits, that cannot be matched in competing solutions. As such, these recursive security systems may provide a number of advantages relative to the implementation of security using obfuscation alone.
  • FIGURE 1 depicts one embodiment of such a topology.
  • a content distribution system 101 may operate to distribute digital content (which may be for example, a bitstream comprising audio or video data, a software application, etc.) to one or more target units 100 (also referred to herein as target or endpoint devices) which comprise protocol engines.
  • These target units may be part of, for example, computing devices on a wireline or wireless network or a computer device which is not networked, such computing devices including, for example, a personal computers, cellular phones, personal data assistants, media players which may play content delivered as a bitstream over a network or on a computer readable storage media that may be delivered, for example, through the mail, etc.
  • This digital content may compose or be distributed in such a manner such that control over the execution of the digital content may be controlled and security implemented with respect to the digital content.
  • control over the digital content may be exercised in conjunction with a licensing authority 103.
  • This licensing authority 103 (which may be referred to as a central licensing authority, though it will be understood that such a licensing authority need not be centralized and whose function may be distributed, or whose function may be accomplished by content distribution system 101 , manual distribution of data on a hardware device such as a memory stick, etc.) may provide a key or authorization code.
  • This key may be a compound key (DS), that is both cryptographically dependent on the digital content distributed to the target device and bound to each target device (TDn).
  • a target device may be attempting to execute an application in secure mode.
  • This secure application (which may be referred to as candidate code or a candidate code block (e.g., CC)) may be used in order to access certain digital content.
  • the licensing authority 103 must supply a correct value of a compound key (one example of which may be referred to as an Authorization Code) to the target device on which the candidate code block is attempting to execute in secure mode (e.g., supply DS1 to TD1 ).
  • a compound key one example of which may be referred to as an Authorization Code
  • No other target device e.g., TDn, where TDn ⁇ TD1
  • the compound key e.g., DS1
  • no other compound key DSn assuming DSn ⁇ DS1
  • Target Device 100 e.g., TD1
  • the target device 100 engages a hash function (which may be hardware based) that creates a message digest (e.g., MD1 ) of that candidate code block (e.g., CC1 ).
  • the seed value for this hash function is the secret key for the target device 100 (e.g., TD1 's secret key (e.g., SK1 )).
  • such a message digest (e.g., MD1 ) may be a Message Authentication Code (MAC) as well as a compound key, since the hash function result depends on the seed value of the hash, the secret key of the target device 100 (e.g., SK1 ).
  • MAC Message Authentication Code
  • the resulting value of the message digest (e.g., MD1 ) is cryptographically bound to both the secret key of the target device 100 and to the candidate code block.
  • the licensing authority distributed compound key e.g., DS1
  • the value of the message digest e.g., MD1
  • the candidate code block e.g., CC1
  • the target device 100 can then run the candidate code block in secure mode.
  • the target device 100 when secure mode execution for a target device 100 is performed the target device 100 may be executing code that has both been verified as unaltered from its original form, and is cryptographically "bound" to the target device 100 on which it is executing.
  • This method of ensuring secure mode execution of a target device may be contrasted with other systems, where a processor enters secure mode upon hardware reset and then may execute in a hypervisor mode or the like in order to establish a root-of-trust.
  • any or all of these data such as the compound key from the licensing authority, the message digest, the candidate code block, etc.
  • embodiments of the systems and methods presented herein may, in addition to protecting the secret key from direct exposure, protect against indirect exposure of the secret key on target devices 100 by securing the working sets of processes executing in secure mode on target devices 100.
  • FIGURE 2 an architecture of one embodiment of a target device that is
  • Elements of the target unit may include a set of blocks, which allow a process to execute in a secured mode on the target device such that when a process is executing in secured mode the working set of the process may be isolated. It will be noted that while these blocks are described as hardware in this embodiment, software may be utilized to accomplish similar functionality with equal efficacy. It will also be noted that while certain embodiments may include all the blocks described herein other embodiments may utilize lesser or additional blocks.
  • the target device 100 may comprise a CPU execution unit 120 which may be a processor core with an execution unit and instruction pipeline.
  • Clock or date/time register 102 may be a free-running timer that is capable of being set or reset by a secure interaction with a central server. Since the time may be established by conducting a query of a secure time standard, it may be convenient to have this function be on-chip.
  • Another example of such a date/time register may be a register whose value does not necessarily increment in a monotonic manner, but whose value does not repeat very often. Such a register could be useful in the case where a unique timestamp value might be required for a particular reason, but that timestamp value could not necessarily be predicted ahead of time.
  • a pseudo-random number generator may be a suitable mechanism for implementing such a register. Another option for implementing such a function would be to use the output of a hardware hash function 160 to produce the current value of this register. In the case where the output of such a hash function is used as a seed or salt value for the input of the hash function, the resulting output series may resemble a random number sequence statistically, but the values may nonetheless be deterministic, and thus, potentially predictable.
  • Target unit 100 may also contain a true random number generator 182 which may be configured to produce a sequence of sufficiently random numbers or which can then be used to supply seed values for a pseudo-random number generation system. This pseudo-random number generator can also potentially be implemented in hardware, software or in "secure" software.
  • One-way hash function block 160 may be operable for implementing a hashing function substantially in hardware.
  • One-way hash function block 160 may be a part of a secure execution controller 162 that may be used to control the placement of the target device 100 in secure mode or that maybe used to control memory accesses (e.g., when the target device 100 is executing in secured mode), as will be described in more detail herein at a later point.
  • one way has function block 160 may be implemented in a virtual
  • the secure mode "evaluation" operation proceeds independently of the execution of the secure process that it is evaluating.
  • a chain of nested evaluations may have a definitive termination point (which may be referred to as the root of the "chain of trust” or simply the "root of trust”).
  • this "root of trust” may be the minimum portion of the system that should be implemented in some non-changeable fashion (e.g., in hardware). This minimum feature may be referred to as a "hardware root of trust”.
  • one such hardware root of trust might be a One-Way hash function that is realized in firmware (e.g., in non-changeable software).
  • Another portion of the target unit 100 may be a hardware-assisted encryption/decryption block 170 (which may be referred to as the encryption system or block, the decryption system or block or the encryption/decryption block interchangeably), which may use either the target unit's 100 secret key(s) or public/private keys (described later) or a derivative thereof, as described earlier.
  • This encryption/decryption block 170 can be implemented in a number of ways. It should also be noted that such a combination of a One-Way Hash Function and a subsequent encryption/decryption system may comprise a digital signature generator that can be used for the validation of any digital data, whether that data is distributed in encrypted or in plaintext form.
  • the speed and the security of the entire protocol may vary depending on the construction of this block, so it may be configured to be both flexible enough to accommodate security system updates as well as fast enough to allow the system to perform real-time decryption of time-critical messages.
  • encryption and decryption will be utilized interchangeably herein when referring to engines (algorithms, hardware, software, etc.) for performing encryption/decryption.
  • engines algorithms, hardware, software, etc.
  • the same or similar encryption or decryption engine may be utilized for both encryption and decryption.
  • the encryption and decryption functions may or may not be substantially similar, even though the keys may be different.
  • Target device 100 may also comprise a data cache 180, an instruction cache 1 10 where code that is to be executed can be stored, and main memory 190.
  • Data cache 180 may be almost any type of cache desired such as a L1 or L2 cache.
  • data cache 180 may be configured to associate a secure process descriptor with one or more pages of the cache and may have one or more security flags associated with (all or some subset of the) lines of a data cache 180.
  • a secure process descriptor may be associated with a page of data cache 180.
  • embodiments of target device 100 may isolate the working set of a process
  • the entire working set of a currently executing may be stored in data cache 180 and writes to main memory 190 and write-through of that cache (e.g., to main memory 190) disallowed (e.g., by secured execution controller 162) when executing in secured mode.
  • any of those lines of data cache 180 that are written to while executing in secure mode e.g., a "dirty" cache line
  • those cache lines may be associated with a secure process descriptor for the currently executing process.
  • the secure process descriptor may uniquely specify those associated "dirty" cache lines as belonging to the executing secure process, such that access to those cache lines can be restricted to only that process (e.g. be by secured execution controller 162).
  • main memory e.g., a page swap or page out operation
  • external data transactions between the processor and the bus e.g., an external memory bus
  • the encryption (and decryption) of data written to main memory may be controlled by secure execution controller 162.
  • the key for such an encryption may be the secure process descriptor itself or some derivative thereof and that secure descriptor may itself be encrypted (e.g., using the target device's 100 secret key 104 or some derivative thereof) and stored in the main memory 190 in encrypted form as a part of the data being written to main memory.
  • Instruction cache 1 10 is typically known as an l-Cache. In some embodiments, a
  • this l-Cache 1 10 characteristic of portions of this l-Cache 1 10 is that the data contained within certain blocks be readable only by CPU execution unit 120. In other words, this particular block of l-Cache 130 is execute-only and may not be read from, nor written to, by any executing software. This block of l-Cache 130 will also be referred to as the "secured l-Cache" 130 herein. The manner by which code to be executed is stored in this secured l-Cache block 130 may be by way of another block which may or may not be depicted. Normal l-Cache 150 may be utilized to store code that is to be executed normally as is known in the art.
  • certain blocks may be used to accelerate the operation of a secure code block.
  • a set of CPU registers 140 may be designated to only be accessible while the CPU 120 is executing secure code or which are cleared upon completion of execution of the secure code block (instructions in the secured l-cache block 130 executing in secured mode), or if, for some reason a jump to any section of code which is located in the non-secure or "normal" l-Cache 150 or other area occurs during the execution of code stored in the secured l-Cache 130.
  • CPU execution unit 120 may be configured to track which registers 140 are read from or written to while executing the code stored in secured l-cache block 130 and then automatically clear or disable access to these registers upon exiting the "secured execution" mode. This allows the secured code to quickly "clean-up" after itself such that only data that is permitted to be shared between two kinds of code blocks is kept intact. Another possibility is that an author of code to be executed in the secured code block 130 can explicitly identify which registers 140 are to be cleared or disabled. In the case where a secure code block is interrupted and then resumed, then these disabled registers may potentially be re-enabled if it can be determined that the secure code that is being resumed has not been tampered with during the time that it was suspended.
  • a set of registers 140 which are to be used only when the CPU 120 is executing secured code may be identified. In one embodiment this may be accomplished utilizing a version of the register renaming and scoreboarding mechanism, which is practiced in many contemporary CPU designs.
  • the execution of a code block in secured mode is treated as an atomic action (e.g., it is non- interruptible) which may make this such renaming and scoreboarding easier to implement.
  • another method which may be utilized for protecting the results obtained during the execution of a secured code block that is interrupted mid-execution from being exposed to other execution threads within a system is to disable stack pushes while a the target device 100 is operating in secured execution mode.
  • This disabling of stack pushes will mean that a secured code block is thus not interruptible in the sense that, if the secured code block is interrupted prior to its normal completion, it cannot be resumed and therefore must be restarted from the beginning.
  • the "secured execution" mode is disabled during a processor interrupt, then the secured code block may also potentially not be able to be restarted unless the entire calling chain is restarted.
  • Each target unit 100 may also have one or more secret key constants 104; the values of neither of which are software-readable.
  • the first of these keys (the primary secret key) may be organized as a set of secret keys, of which only one is readable at any particular time. If the "ownership" of a unit is changed (for example, the equipment containing the protocol engine is sold or its ownership is otherwise transferred), then the currently active primary secret key may be "cleared” or overwritten by a different value. This value can either be transferred to the unit in a secure manner or it can be already stored in the unit in such a manner that it is only used when this first key is cleared.
  • a secondary secret key may be utilized with the target unit 100 itself. Since the CPU 120 of the target unit 100 cannot ever access the values of either the primary or the secondary secret keys, in some sense, the target unit 100 does not even "know" its own secret keys 104. These keys are only stored and used within the security execution controller 162 of the target unit 100 as will be described. [0121 ] In another embodiment, the two keys may be constructed as a list of "paired" keys, where one such key is implemented as a one-time-programmable register and the other key in the pair is implemented using a re-writeable register.
  • the re-writeable register may be initialized to a known value (e.g., zero) and the only option that may be available for the system to execute in secure mode in that state may be to write a value into the re-writeable portion of the register.
  • a known value e.g., zero
  • the system may only then be able to execute more general purpose code while in secure mode. If this re-writeable value should be re-initialized for some reason, then the use of a new value each time this register is written may provide increased security in the face of potential replay attacks.
  • Yet another set of keys may operate as part of a temporary public/private key system (also known as an asymmetric key system or a PKI system).
  • the keys in this pair may be generated on the fly and may be used for establishing a secure communications link between similar units, without the intervention of a central server.
  • these keys may be larger in size than those of the set of secret keys mentioned above.
  • These keys may be used in conjunction with the value that is present in the on-chip timer block in order to guard against "replay attacks", among other things. Since these keys may be generated on the fly, the manner by which they are generated may be dependent on the random number generation system 180 in order to increase the overall system security.
  • one method that can be used to affect a change in "ownership" of a particular target unit is to always use the primary secret key as a compound key in conjunction with another key 107, which we will refer to as a timestamp or timestamp value, as the value of this key may be changed (in other words may have different values at different times), and may not necessarily reflect the current time of day.
  • This timestamp value itself may or may not be itself architecturally visible (e.g., it may not necessarily be a secret key), but nonetheless it will not be able to be modified unless the target unit 100 is operating in secured execution mode.
  • the consistent use of the timestamp value as a component of a compound key whenever the primary secret is used can produce essentially the same effect as if the primary secret key had been switched to a separate value, thus effectively allowing a "change of ownership" of a particular target endpoint unit without having to modify the primary secret key itself.
  • target device may use secure execution controller 162 and data cache 180 to isolate the working sets of processes executing in secure mode such that the data is inaccessible to any other process, even after the original process terminates.
  • This working set isolation may be accomplished in certain embodiments by disabling off-chip writes and write-through of data cache when executing in secured mode, associating lines of the data cache written by the executing process with a secure descriptor (that may be uniquely associated with the executing process) and restricting access to those cache lines to only that process using the secure process descriptor.
  • a secure process descriptor may be a compound key such as an authorization code or some derivative value thereof.
  • the secure descriptor associated with the currently executing process may be compared with the secure descriptor associated with the requested line of the data cache. If the secure descriptors match, the data of that cache line may be provided to the executing process while if the secure descriptors do not match the data may not be provide and another action may be taken.
  • a subset of the processes working set that is considered "secure” may be created (e.g., only a subset of the dirty cache lines for the process may be associated with the secure descriptor) and only encrypt those cache lines or the portion of the cache containing those lines, when it is written out to external memory.
  • an off-chip storage mechanism e.g., a page
  • swapping module can be run asynchronously in parallel with an interrupting process (e.g., using a DMA unit with integrated AES encryption hardware acceleration) and thus, could be designed to have a minimal impact on the main processor performance.
  • interrupting process e.g., using a DMA unit with integrated AES encryption hardware acceleration
  • a separate secure "working set encapsulation" software module may be used to perform the encryption prior to allowing working set data to be written out to memory.
  • FIGURE 15 a general structure consisting of a first One-Way Hash function 1510, its associated input data set 1520 and its resultant output 1523.
  • the input data set 1520 can be further broken down into three components, Secret Key 1521 , Precursor Key 1522 and Payload Data 1 1523.
  • the size of the resultant output 1532 of the first One-Way Hash function 1510 is typically constant in size, no matter how large the input data set 1520 may be.
  • This feature is typically referred to as the built-in "data compression" functionality of any One-Way Hash function.
  • the built-in data compression property may be utilized the following examples, the overall structure of embodiments of the systems depicted herein do not depend on this data compression function.
  • first One- Way Hash function 1510 and second One-Way Hash function 1540 may, in fact, be identical in operation, but may also be different.
  • the same Secret Key 1521 is used as a part of the input data set to both first One-Way Hash functions 1510 and second One-Way Hash function 1540, but these keys may also be different.
  • the resulting output 1550 of second One-Way Hash function 1540 is then referred to as Compound Key 2.
  • the Payload Data 1 portion 1523 of the input data set 1520 of first One-Way Hash function 1510 may also be replaced with a different Payload Data set.
  • this concatenated structure produces a "key-chaining" mechanism whereby the eventual result may be a single, fixed-length compound key with an arbitrarily large set of dependencies.
  • the compound encryption mechanism may be chained to allow the production of a single compound key value that is cryptograph ically dependent on an arbitrary number of arbitrarily large precursors using simple aggregation.
  • a logically equivalent structure can be constructed using an encryption function instead of a One-Way hash function.
  • This encryption function may be a symmetric encryption function or an asymmetric encryption function without affecting the operating principal.
  • we will show a structure that is based on a symmetric encryption mechanism.
  • the encryption chain may be executed in either forward or reversed input/output order in order to recreate a particular intermediate key value.
  • the structure, which is shown in Figure 16 is referred to as a "reversible" Compound Key construction.
  • the specific encryption functions performed at any of the stages in the forward or reverse process may or may not be the same.
  • the number of iterations through the various encryption stages can accumulate indefinitely without affecting the overall functionality of the "chained" Reversible Compound Key mechanism.
  • the overall security of the "chained" Compound Key structure may depend on the ability of the system to keep the intermediate keys secret (e.g., isolated) from other processes that are not part of the "chain". In fact, it may be desirable to keep at least some of these intermediate values isolated from any other process, whether that process is a part of the "chain” or not. Embodiments which allow such an isolation mechanism are discussed below.
  • a “hybrid” Compound Key mechanism can be constructed, including both One-Way and Reversible Compound Key elements.
  • An example of such a structure is shown in FIGURE 17. This kind of mechanism can be useful in order to ensure security of a chain of secure processes as well as the input data that is supplied to those secure processes.
  • compound key generation shown in FIGURE 15 can be utilized in the architecture of embodiments of a secured execution controller and a data cache.
  • FIGURE 3 one embodiment of the architecture of a secure execution controller is depicted.
  • secure execution controller 362 is associated with a CPU of a system in which it is included and is intended to support the running of a candidate code block in secure mode on the main CPU.
  • secure execution controller 362 may comprise one or more of registers, including a secret hardware key 310 which is not visible to the CPU, secure mode control register 350, authorization code register 360, secure mode status register 352, hash seed register 312 and hardware generated compound key register 314.
  • all but secret hardware key 310 may be readable by a CPU without affecting the overall security of the system, although any of these other registers may or may not be visible.
  • Secure mode control register 350 may be a register that may be written to in order to attempt to place the target device in a secure mode.
  • the secure mode control register 350 may have a register into which a memory location (e.g. in an l-cache or main memory) corresponding to the beginning address of a candidate code block (e.g., a code block to be executed in secured mode) may be written and a separate register into which the length of such a candidate code block may be written.
  • Authorization code register 360 may be a location into which an authorization code or another type of key or data may be written.
  • Secure mode status register 352 may be a memory-mapped location comprising one or more bits that may only be set by hardware comparison block 340 and which can indicate whether or not the target device 100 is operating in secure mode.
  • Hardware hash function block 320 may be operable for implementing a hash function
  • Hardware hash function block 320 may, for example, implement a SHA 256 or some similar one-way hash function.
  • this hash function may also be implemented in software or in firmware running on either a separate processor from the CPU of the system, or even a process that is run on the CPU in secure mode, using a virtual hardware hash function methodology as described earlier.
  • Hardware hash function block 320 may take as input one or more of the values stored in the hash seed register 312, secret hardware key 310 or data from another location, concatenate these inputs (e.g., prepend or append one input to another) and hash the resulting data set to generate a message authentication code, which we have referred to earlier as a one-way compound key.
  • the input data for the hardware hash function 510 may be constructed by a concatenation of the secret hardware key 514, the hash seed precursor key 516 and the secure code block candidate 532. There may be no fundamental difference in the operation of the hash function 510, almost no matter what the input data 514, 516 and 532 represent or how large any of these data sets may be. It should also be noted here, that the other inputs to the hardware hash function 510 that are shown coming from the secure mode controller state machine 580 represent control inputs as opposed to input data to the hash function.
  • This value 524 is typically referred to as a Message Authentication Code (or MAC) in modern cryptographic literature, and this result 524 has also been referred to herein as a compound key (e.g., hardware-generated). Due to the inherent compression function of (almost all) secure one-way hash mechanisms, the resulting compound key 524 will be of constant size, almost no matter how large the input data sets that were used or even how many times the data has been iterated through the hash function 510.
  • MAC Message Authentication Code
  • Hardware comparison block 340 may be configured to compare the data in hardware generated compound key register 314 with the data in authorization code register 360. If the two values are identical the hardware comparison block 340 is configured to set the one or more bits in secure mode status register 352 that place the target device in secure mode.
  • Secure mode controller state machine 370 may be logic (e.g., hardware, software or some combination) that may operate based on the state of bits of secure mode control register 350 or secure mode status register 352. Secure mode controller state machine 370 is configured for controlling inputs to hardware hash function block 320, such that the precursors may be utilized in the correct manner to generate the desired output 314 of hardware hash function block 320. For example, secure mode controller state machine 370 may be configured to cause the resulting output to be loaded into hardware generated compound key register 314 at the proper time. Additionally, secure mode controller state machine 370 may be configured to cause the correct data to be written to secure mode status register 352. [0146] Secure mode controller state machine 370 may also be configured for controlling memory access when the target device is executing in secure mode.
  • Secure mode controller state machine 370 may also be configured for controlling memory access when the target device is executing in secure mode.
  • secure mode controller state machine 370 may be configured to determine which of the pages of the data cache have been assigned to that process and store a secure descriptor for that process in the data cache in association with the one or more of the pages of the data cache.
  • These secure process descriptors may thus be used to associate a particular set of data that is being stored in the data cache with a specific process that is executing in secured mode.
  • Such a secure process descriptor may, for example, be the value that is based on the data that is located in authorization code register 360 or the hardware-generated compound key register 314.
  • secure mode controller state machine 370 may be able to receive memory accesses by the process executing in secure mode and determine if the memory access is a read or a write access.
  • the secured mode controller state machine 370 may be configured to determine the cache line of the data cache corresponding to the address where the data is to be written and then set a security flag associated with that cache line to indicate that the data contained in that cache line is secure. In certain embodiments, secured mode controller state machine 370 is also configured to prevent any writes to any memory location which is not in the data cache, for example by disabling write- through, write-back or other operations of the data cache or memory controllers of the target device.
  • the secured mode controller state machine 370 may be
  • the secured mode controller state machine 370 may be configured to allow the requested data to be read from main memory and placed in the data cache in a page associated with the process. If a cache hit occurs the secured mode controller state machine 370 may be configured to the determine the cache line
  • the memory access may be allowed to proceed (e.g., the data read from the cache line).
  • secured mode controller state machine 370 may be configured to obtain the secure process descriptor associated with the page in the data cache containing that cache line and compare it with a secure process descriptor associated with the currently executing. If the secure process descriptors match, then the memory access may be allowed to proceed. If the secure descriptors do not match, another action may be taken such as either returning a garbage or preset value in response to the memory access or alternately returning a "no-valid data" at that address message to the CPU, whereupon the CPU memory management unit may then request a replacement cache line to read in from system memory.
  • only the data cache is used to store the entire working set of a process executing in secure mode and any writes to memory other than to the data cache by the process may be disabled.
  • any lines of the data cache that are written to e.g., so-called "dirty" cache lines
  • a secure process descriptor that may uniquely and precisely specify which process to whom the "dirty" cache line belongs. Access to these cache lines may only be allowed to the owner of the particular "dirty" cache line such that any cache line modified during the operation of a secure process is unreadable by any other process, even after the original process has terminated.
  • data that belongs to one instance of a process is unambiguously isolated from any other process.
  • data cache 400 may be almost any type of cache, including a L1 cache a L2 cache, a direct mapped cache, a 2-way set associative cache, a 4-way set associative, a 2-way skewed associative cache, etc. that may be implemented in conjunction with almost any management or write policies desired.
  • the cache 400 may comprise a set of pages 410. When used when referring to the cache herein, a page may be understood to mean cache block or a cache set.
  • the data cache 400 is configured to store a secure descriptor associated with one or more pages 410 of the cache.
  • FIGURE 4B depicts a view of one embodiment of a page 410a of cache 400.
  • the cache comprises logic 412 designed to store a secure process descriptor in association with the page 410a and to provide the secure process descriptor in response to a request for the secure process descriptor for page 410a or in conjunction with a read to a cache line 402 of page 410a.
  • Each cache line 402 of the page 410a includes bits for the data, address tags and flags 420.
  • the flags 420 may include bits such as a valid bit or dirty bit.
  • flags 420 may include a secure bit 422.
  • Cache 400 may be configured such that a secure bit 422 for a cache line 402 may be set (e.g., when a process executing in secure mode writes to that cache line 402).
  • block of code (which will be referred to as a "secure work function") may be executed in secure mode on embodiments of a system such as those described herein is to execute a pair of extra functions, one on either side (e.g., before or after) of the secure work function.
  • a function (or set of functions) that is executed immediately prior to a secure work function will be referred to as the "prologue” and a function (or set of functions) which is executed immediately after the secure work function will be referred to as the "epilogue”.
  • the prologue in order to execute a secure work function on a CPU, then that secure work function should be preceded by a prologue and followed by an epilogue.
  • the purpose of the prologue is at least threefold.
  • the prologue should prepare the input arguments that are passed to the secure work function for use by the secure work function. This preparation may involve, for example, a decryption process, which may be required for those input arguments that may not be passed to the secure work function in the clear.
  • a second function of the prologue may be to construct a compound key whose value is dependent on a number of data elements.
  • Such data elements may include the hardware secret key of the target device, the Authorization Code of the parent (e.g., calling) function, a list of one or more input arguments to the secure work function (either in encrypted or non-encrypted form), the executable image of the secure work function itself, or some other information that may be used in determining whether or not the secure work function should be allowed to execute on the target device in secure mode.
  • a third function of the prologue could be to initiate a request that the CPU begin executing the secure work function in secure mode.
  • the purpose of the epilogue may be to "clean up" after the execution of the secure work function is complete.
  • One function the epilogue may be to prepare any designated output parameters for use by subsequent code blocks (e.g., to be executed after the secure work function), be they secure or not.
  • this preparation may involve encrypting of the designated output (or returned data) from the secure work function so that any observing process other than the intended recipient of such output arguments, including either hardware or software-based observers, may be precluded from effectively intercepting that data.
  • the encryption key that may be used may be a reversible compound key that is passed to the secure routine as one of its calling arguments.
  • a second function of the epilogue may be to either programmatically or automatically
  • FIGURES 5-7 depict a block diagram of one embodiment of a flow for placing a target device in secure mode.
  • a code block 531 may be configured to execute in secured mode.
  • Such a code block may be received, for example, from a content distribution system or loaded from a computer readable medium, etc.
  • an authorization code may be received, for example, from a licensing authority, read from a computer readable medium, input by a user, etc.
  • Both the code block (referred to as a candidate code block at some locations herein, as it is a "candidate" to execute in secure mode) and the authorization code 520 may be stored in the main memory 530 of the target device.
  • the candidate code block is comprised of a prologue function, a secure work function and an epilogue function, in that order.
  • the Authorization Code that would be associated with the secure work function may include dependencies on all three functional sections of the candidate code block.
  • the prologue and epilogue functions may be implemented substantially in a fixed manner (in other words, in hardware or firmware). In that case, then it is possible that the Authorization Code for the candidate code block may have more limited dependencies on the prologue and epilogue functions.
  • CPU execution unit 550 may access secure mode control register 560 of secure execution controller 570 and set the bits of secure mode control register 560 to initiate the placement of the target device in secure mode.
  • the memory location e.g., the location in l-cache to which the code block 531 is being transferred or the location in main memory 530
  • the memory location of the candidate code block 531 along with the length of the candidate code block 531 may be written into the secure mode control register 560.
  • secure mode controller state machine 580 may perform one or more functions.
  • secure mode controller state machine 580 may then configure the target device such that the candidate code block 531 is provided to the hardware hash block 510 of the secure execution controller 570. This configuration may be done, for example, based on the location in memory of the candidate code block written into secure mode control register 560.
  • the secure mode controller state machine 580 may go out to main
  • the secure mode controller state machine 580 may observe the data bus transactions as some other portion of the target device loads the candidate code block 531 from main memory 530 into the l-cache 540, confirming that the candidate code block 510 has been loaded in its entirety into the l-cache 540.
  • the secure mode controller state machine 580 may cause another portion of the target device to perform this transfer from main memory 530 into the l-cache 540. In yet another embodiment, the secure mode controller state machine 580 may observe the data transferred from main memory 530 and keep track of the data as it is transferred into the l-cache 540.
  • the bits comprising the candidate code block 531 may be provided to the hardware hash function block 510 as they are transferred across a bus from the main memory 530 to the l-cache 540.
  • the hardware hash block 512 may create a compound key from the candidate code block 531 , secret hardware key 514 and optionally one or more other precursor values stored in hash seed register 516.
  • CPU execution unit may write authorization code 520 associated with candidate code block 531 into authorization code register 522 of secure execution controller 570.
  • the compound key is generated by the hardware hash block 512 it is written to hardware generated compound key register 524.
  • Secured mode controller state machine 580 is then configured to initiate a comparison between the value in hardware generated compound key register 524 and the value in authorization code register 522. If these values match, hardware comparison block 532 may write the bits in secure mode status register 534 that place the target device in secure mode.
  • the code block 510 can then be executed by the CPU execution unit 550 in secured mode. If the values do not match, the target device will not be placed in secure mode, however, the code block 510 may (or may not) be still allowed to execute (although not in secured mode).
  • authorization code may be a compound key (DS), that is both cryptographically dependent on the candidate code block distributed to the target device and bound to each target device (e.g., using the secret key of that target device).
  • DS compound key
  • the correct authorization code (e.g., constructed using both the candidate code block and the secret key of the target device) must be provided. No other target device can run the candidate code block correctly with that authorization code and no other compound key works with that candidate code block on that target device.
  • the compound key provided by the licensing authority was created using the original code block and the secret key, it can be assured that the candidate code block on the target device has not been modified or tampered with before placing the device in secure mode, as if the candidate code block has been modified in any way the compound key generated at the target device will not match the compound key received (e.g., from the licensing authority) and thus the target device will not be placed in secured mode.
  • the use of the hash function on the target device validates that the candidate code block has not been tampered with and (e.g., by use of the compound key "chaining" method described earlier) ensures the order of execution of processes, as well as verifies that the candidate code block is authorized to run in secure mode on the target device.
  • calling arguments have not been modified (maliciously or otherwise); a process is executed to completion (e.g., with or without interruption) and the working set of the process remains isolated from external observation.
  • the first of these three desired is achievable if the calling arguments (or an appropriate subset thereof) are included with the rest of a candidate code block to be secured by the hash function. This concept was discussed above with respect to embodiments of the contents of a candidate code block.
  • Working set isolation it may be desired that any data that is modified or generated during the execution of a process in secure mode (other than possibly returned arguments) remain unreadable by any other process, even after the original process has terminated.
  • Working set isolation may be more complicated than just ensuring that any of the system memory (e.g., data cache or main memory) that is used when executing a process in secure mode is isolated from external observation as there are a number of well- known side-channel or indirect methods for attacking an otherwise closed security system, of which timing attacks and Differential Power Analysis (DPA) are a couple of the more powerful of such widely-practiced schemes.
  • DPA Differential Power Analysis
  • the data cache of the processor may be used to store the entire working set of the currently executing secure code segment and writes by the process to any other part of memory may be disallowed and write-through or write-back of the lines of the data cache (or any other type of memory synchronization between the data cache and main memory) may also be disallowed.
  • any lines of the data cache that are written to by the secure process while in secure mode may be tagged with a unique secure process descriptor that uniquely and precisely specifies the process to which that data cache line belongs. Access to those data cache lines (or pages) may then be restricted to only the process associated with that secure descriptor.
  • the secure process descriptor is sufficiently unique to be able to not only distinguish between different processes from different code blocks, but also between different processes resulting from executing the same code block at different times.
  • a secure descriptor can be a compound key.
  • the compound key mechanism can be utilized to produce this secure descriptor without compromising the target device's secret key.
  • an added advantage is that the existing hardware based hash bock and hardware compare block described earlier can be used to create or compare these secure process descriptors without exposing any intermediate data to an external attacker.
  • a simple and effective secure process descriptor that may be utilized is the authorization code associated with, and used to verify, the code block being executed in secured mode.
  • Example precursors that may be utilized to create other examples of secure process descriptors are, for example, the target device's secret key, the message digest (e.g., authorization code) of the code block executing in secure mode, the secure process descriptor of the parent process (e.g., the calling function of the currently executing process) or the calling arguments of the currently executing process.
  • FIGURES 8- 14 It will now be useful to illustrate a flow of one embodiment of securing the working set of a process executing in secured mode. To illustrate this embodiment, attention is directed to FIGURES 8- 14. Referring first to FIGURE 8, it will be recalled from the discussion above that when a code block is verified the authorization code for the code block is placed in authorization code register 812 of secure execution controller 820 and when the code block is verified the bit in secure mode status register 810 placing the target device in secure mode are set and the code block 852 executed in secured mode on CPU execution unit 850. During execution of this code block 852 then, a memory access to an address may be made. Such a memory access may be received by secure mode controller state machine 880.
  • the memory access may be received in a number of ways, for example, from the memory controller of the target device, from a "snoop" of the system bus, from a translation lookaside buffer or other cache management device, or in a wide variety of other manners.
  • secure mode controller state machine 880 When secure mode controller state machine 880 receives such a memory access, it may determine if the memory access is read access or a write access (step 803) and if it is determined that the memory access is a read access it can then be determined if the address corresponding to the memory access has been previously stored in thee data cache 840 (step 805). This determination may be made, for example, based on whether a cache hit or a cache miss occurs. Again, this data may be obtained in a number of ways, such as from a memory controller, a translation lookaside buffer or other address resolution mechanism, etc.
  • the read may be allowed (step 807).
  • the data at the desired address can then be read in from main memory 890 and placed in a line 846 in data cache 840 of a page 842 used by the currently executing process.
  • the data associated with the requested address is read from main memory 890 and placed in cache line 846a of page 842a.
  • the memory access is a write (step 803), it can be determined if the write is to an address that is located within data cache 840 (step 813). If the address is not within the data cache 840 the write may be disallowed (step 815) or the write may be allowed, but to the data cache only (e.g., any data cache write-through options may be disabled). Now looking at FIGURE 1 1 , if the write is to an address that is located within data cache 840 (step 813), the write may be allowed to the appropriate cache line 846 in the page 842 containing that cache line 846. For purposes of this example, assume that the memory access is a write to the data in cache line 846a of page 842a. The secure mode controller state machine 880 may also set the security bit of the cache line 846 which was written (step 817) (in the example illustrated security bit 848a of cache line 846a of page 842a has been set).
  • step 813 if the write is to an address that that is located within data cache 840 (step 813), it can be determined if a secure process descriptor associated with the executing process may be generated (step 819) and stored (step 821 ) in the data cache 840 in association with the page 842 containing the cache line 846 to which the write was made. It should be noted, that these steps may only occur if such a secure process descriptor was not previously associated with the page (step 823).
  • the secure descriptor for the executing process may be the
  • authorization code used to verify the code block that is being executed by the current process.
  • This authorization code may be resident in authorization code register 812 of secure execution controller 820.
  • the authorization code in authorization code register 812 may be stored in the secure descriptor area 844 of data cache 840 associated with the page 842 containing the cache line 846 to which the write was made.
  • the authorization code in authorization code register 812 is stored in secure descriptor area 844a associated with page 842a containing cache line 846a.
  • a memory access received by the secure mode controller state machine is a read (step 803) of a datum that was previously stored in data cache 840 (step 805) (e.g., a cache hit) it can be determined if the security bit 848 associated with the cache line 846 being accessed has been set (step 823). If the security bit has not been set (step 823) the read from data cache 840 may be allowed (step 825).
  • step 823 if the security bit 848 associated with the cache line 846 being accessed has been set (step 823) the secure process descriptor associated with the page 842 of the cache line 846 being accessed may be obtained (step 825) from the secure process descriptor area 844 associated with the page 842 containing the accessed cache line 846.
  • the secure process descriptor associated with the process can then be obtained (step 827) and can then be determined if these secure descriptors are the same (step 829).
  • the secure process descriptor for the executing process may either be the authorization code resident in authorization code register 812 of secure execution controller 820 or some derivative value thereof.
  • the secure process descriptor obtained from secure process descriptor area 844 associated with the page 842 containing the accessed cache line 846 may be provided to hardware compare block 814 of secure execution controller 820 where it is compared either with the authorization code resident in
  • authorization code register 812 or some derivative value thereof.
  • the secure process descriptor in secure process descriptor area 844a associated with page 842a containing cache line 846a has been provided to hardware compare block 814 where it is compared either with the authorization code resident in authorization code register 812 or some derivative thereof. If the secure process descriptors match the read may be allowed (step 831 ) otherwise it may be disallowed (step 833) and another action taken. Examples of such other actions may be providing a garbage or a fixed value, indicating a cache miss, etc.
  • any external data transactions between the CPU execution unit and an external memory bus may be encrypted during execution of a secure process (including, for example, page out operation or the like).
  • the secure process descriptor itself or some derivative value thereof may be used as the key and that secure process descriptor or the derivative value may itself be encrypted (e.g., using a derivative value of the target device's secret key) and stored in the main memory as a part of the data set.
  • the entire working set may be encrypted prior to the point where it is placed on a memory bus.
  • the storage to main memory may be run asynchronously in parallel with another process (e.g., a DMA unit with integrated hardware accelerated encryption) and thus, it could be designed to have a minimal impact on the performance.
  • a separate "working set encapsulation" routine (which may itself be a secure code block designed to execute in secure mode) may be used to perform the encryption prior to allowing the working set data to be written out to main memory.
  • minimal, if any, architectural changes may be required to integrate this mechanism into almost any existing CPU.
  • the key used to perform the encryption of the page(s) or cache lines being stored to main memory may be a derivative of the authorization code.
  • the authorization code for the process executing in secure mode whose pages that are being stored in main memory may be used to generate a compound key (e.g., a message authentication code) using the hardware hash block using the secret key of the device and another precursor.
  • the resulting compound key may itself be used to encrypt the authorization code to generate an ephemeral key.
  • This ephemeral key may be used to encrypt the page of data cache to be stored in main memory which is then stored in main memory with the authorization code and the precursor used to generate the compound key.
  • Almost any symmetric encryption mechanism may be utilized to encrypt the pages being stored to main memory.
  • a hardware encryption block e.g., an AES hardware block
  • this encryption may be accomplished by encryption code running in secure mode. In such cases this encryption code may need to access cache lines or pages of the data cache associated with another process that was executed in secured mode (e.g., the data in the cache that is to be encrypted).
  • the encryption process may use a derivative of a calling argument as its encryption key.
  • Such a derivative may for example be the output of the hardware hash (e.g., the message authentication code) that may have been generated by using the calling argument along with a secret key and some other datum, such as a secure process descriptor of the parent or child routine, as described above.
  • the actual key used to encrypt or decrypt the data by the encryption process may be a derivative of the passed in key, but one that can only be correctly generated by a single secure process.
  • the encrypted pages may then be stored out to main memory without exposing any of the secure process' input or output arguments to any other processes (secure or otherwise) except those directly involved in the input/output argument transaction.
  • Prior art systems utilize a few basic operational categories of digital data encryption and decryption technologies. These categories are based on the use of the security algorithms themselves and are independent of the actual mechanism for encrypting or decrypting the actual data. These well-known technologies and widely described classifications and technologies are:
  • security protocol The means by which these technologies are used in a given security system is known as a security protocol.
  • the security protocol is independent of the actual underlying mechanics of how the various functions are implemented. As such, even a perfectly secure encryption algorithm may potentially be used inside a security protocol that compromises overall security in such as way as to defeat the secure aspect of the encryption technology itself. Consequently, the overall security of any given security system is dependent not only on the relative strength of the underlying security technologies but also by the way in which these security technologies are put into use.
  • Prior attempts at implementing security system have made (artificial) distinctions between the various types of bit streams to be protected.
  • bitstream On a fundamental level, all binary digital data can be reduced to a stream of 1 's and 0's (a bitstream), which can be stored and retrieved in a manner which is completely independent of the intended purpose or interpretation of that bitstream.
  • bitstream a stream of 1 's and 0's
  • the fact that the data contained in any particular bitstream is used to convey a piece of text or a photograph or even a piece of executable object code is not relevant to the manner in which or the device where the bitstream is stored.
  • This capability means that the security protocol can be updated (to fix recently discovered security holes, for example) without requiring any changes to the hardware on which it is running, even during execution.
  • the "older” security system is "subsumed” as a part of the newer security system (i.e., you never have to strip the old protection "wrapper” away in order to add a new, potentially more secure level of protection to the entire system).
  • the entire system is encapsulated in the latest, most secure encryption and/or access control system. Not only may new keys be added, but entirely new security and/or encryption algorithms can be added on top of existing systems as well.
  • This flexibility allows the protocol to support a number of business models, including Time- limited Rental, Pay-per-View, Multiple Versioning, Machine-dependent License Revocation and Permanent Transfer of Ownership from one user to another.
  • Embodiments of the security protocol are designed to enable the author of a piece of
  • Embodiments of the security protocol depend on the ability to encrypt a digital bitstream in such a way as to only allow it to be decrypted by its intended recipient. This is a well- understood problem and is the basis of a large number of industry-standard encryption algorithms.
  • This procedure can be accomplished in one of several locations (for either of the two secret keys, but for logistical reasons, it should be the final step in the assembly process where either the serial number or the secret key can possibly be changed.
  • this procedure is most likely performed at the point of final assembly. If the serial number 106 for the unit is stored on-chip, then it would be most practical to carry out this procedure at the last point in the chip manufacturing process (i.e., after the chip has been packaged), so that any post-production or burn-in fall out has had a chance to winnow out the non-functional parts. This way, the amount of data that must be kept secure is minimized. Since the security of the entire protocol may be based on that of the unit's secret keys 104, the initialization procedure should be undertaken at a point where physical security is possible.
  • the primary secret key should be initialized (or "burned" into the device) in a different
  • this secondary key will be known at some point (since it is programmed into the unit at some point during the manufacturing process), the unit with which it is associated should not be recorded anywhere once it is stored on the target device 100.
  • the device which programs this second secret key into the unit never have any means of associating the secondary secret key to either the first secret key or to the target device serial number 106.
  • both of these secret keys should be implemented in a tamper-proof manner, for reasons, which are described later. It is not material in which order these two secret keys are initialized. Following the initialization procedure described in the exemplary embodiment, the only location (other than on the actual chip) where the target devices' serial number 106 and their associated primary secret keys are co-located should be on the secure server at the licensing authority. Secure Code Generation and Mass Distribution
  • FIGURE 21 in an example scenario, let us suppose that a developer 2120 wishes to produce an application to run under this protocol, which will be reasonably immune from disassembly and can only be executed on a specific device.
  • Each registered developer 2120 has a public key / private key pair which is used to authenticate any messages which they use to communicate with the licensing authority's server as well as to create signed Message Authentication Codes or MACs (typically referred to as digital signatures) which can be used to authenticate any published code block or other bitstream.
  • MACs typically referred to as digital signatures
  • This application- specific algorithm and key(s) can either be a symmetric (secret) key system or an asymmetric (PKI) key-based system.
  • Attached to the end of the encrypted block of code is a MAC, which is then signed by the developer 2120 using the private key of their published public key/private key pair (which thus forms an unambiguous digital signature for the encrypted code block).
  • Either the digital signature or the original MAC and the corresponding Code specific ID number may be supplied to the licensing authority.
  • the application developer 2120 may also choose to supply the appropriate decoding key(s) as well (we will discuss the tradeoffs of this decision in a later section of this document).
  • the application-specific algorithm is an asymmetric encryption system, it does not necessarily need to be encrypted using the same published PKI key pair that is used to generate the signed Message Authentication Code (the digital signature).
  • the MAC that is stored at the end of the code block should be generated using a known hashing algorithm and must also be signed using one of the developer's published public keys (thus forming the digital signature). This allows the target to verify the authenticity of the MAC using a known hashing function and a known public key.
  • all application-specific encryption key data structures 1810 may contain a number of extra fields (in addition to the decryption key itself 1820).
  • One of these fields may comprise a timestamp 1830 and an associated mask value 1840.
  • the second may contain a "countdown value" 1850.
  • the mask value 1840 is used in conjunction with the other two fields 1830, 1850 in order to determine when the key is valid. It should also be noted that it is not relevant to the protocol exactly how many bits are allocated to each of the fields.
  • the timestamp value 1830 can be used in several ways, depending on the bit pattern that is stored in the timestamp mask 1840 field.
  • the timestamp mask 1840 value allows the developer 2120 to select some subset of the timestamp figure that is ignored when performing the comparison with the target unit's 100 current time. As an example, however, if we assume that the smallest resolution which is supported by the timestamp field 1830 is one second, then by masking out the lower five bits of the timestamp data 1830, a particular key data structure 1810 can be generated which is only valid when used over the course of approximately 32 seconds starting at the time which is stored in the timestamp field 1830.
  • the overall functionality of the security protocol is not dependent on the actual resolution of the lowest order bit of the timestamp field 1830.
  • mask field 1840 There may be other bits that are associated with the mask field 1840, some of which can be used to indicate whether the key is valid before or after the value specified in the timestamp 1830. Yet another mask field 1840 bit can be used to indicate how the timestamp 1830 and the "count-down" values 1850 are associated. For example, this would be useful in the case where the intent of the application developer 2120 was to limit the use of the software to a certain number of iterations either prior to or after a certain date, rather than simply tied to a certain date and time window. Of course, any combination of these conditions can be constructed, so the protocol is quite flexible in this regard.
  • further flags can be included in this data structure to indicate other properties, such as how many legal copies of the keys may be simultaneously distributed from the original target unit 100 to others. This would be useful in the case where a multiple-copy license were desired, such as is seen in a digital library, for example.
  • FIGURE 19 Note that there is no substantive difference between the process that would be used to distribute a digital media stream or a software application (such as the decryption instructions used to interpret that media stream). In either case, there are a couple of different options for distributing the encrypted code block(s) 1910, 1920; either via an online server or on serialized discs (such as a standard DVD). In the latter case, the developer 2120 can then choose to pre-register the individual serial numbers of the mass-produced discs with the licensing authority 21 10 (or not). If so, the serial numbers could be permanently affixed to the discs either by burning them into the Burst Cutting Area (in the case of a DVD) or by ink-jet imprinting in the case of a standard CD.
  • the serial numbers could be permanently affixed to the discs either by burning them into the Burst Cutting Area (in the case of a DVD) or by ink-jet imprinting in the case of a standard CD.
  • the developer 2120 cannot embed these serial numbers into the data area of the CD or DVD, since the same serial number would be replicated on all of the mass-produced discs. If some sort of a hybrid format were used, where part of the disc could be mass-produced and another portion written once, then this would be another potential method of distributing the discs with individual serial numbers. In any case, a machine-readable serial number is certainly preferable, since it is less prone to errors during the registration process. [0222] If the developer 2120 chooses not to register the media serial number with the licensing authority, then there may be some other manner by which the proper encryption key(s) can be associated with the application or media stream files. Thus, the application developer 2120 may either register the code-specific ID or an associated media serial number. In the former case, then the application can be distributed freely (i.e., not tied to a specific release format and media).
  • the licensing authority 21 10 since the licensing authority 21 10 has no need to know (and potentially no indication of) which application (or media stream) is associated with which serial number(s). In the case where the developer 2120 registers an application ID (or a media stream ID) along with its associated key(s), then it is possible for the licensing authority 21 10 to know which application(s) or media streams are "owned” by a particular end user. On the other hand, this potential lack of privacy is counterbalanced by the additional convenience and cost savings of not requiring the developer 2120 to manufacture and distribute physical media. Note that the term "physical media” does not necessarily mean a disc. This function could be accomplished just as well by using a printed manual (or even a simple registration form) with an individual serial number sticker attached to it.
  • both the encrypted software application (or media stream) 1910 and the machine dependent decryption software 1930 are distributed using the same mechanism. It is not a requirement of the protocol that this should be the case and either or both of the encrypted code blocks 1910, 1930 can be distributed on-line or by pressing a disc. It should be noted, however, that in the case of a digital media stream, the media stream itself is most likely the larger of the two blocks 1910, 1930 by several orders of magnitude. Thus, in that case, it makes the most sense to effect the distribution of at least this block in a mass-produced disc format.
  • the consumer can purchase the disc containing the application in exactly the same manner as a traditional software purchase.
  • the end-user would not be able to run the encrypted code block unmodified on the processor of the "target" unit.
  • the CPU 120 loads the encrypted software block and uses the digital signature (the "signed" MAC) stored at the end of the code block along with the software developer's public key to verify that the code block in question is genuine. This is where the first hardware modification to an otherwise general purpose CPU 120 may come into play.
  • the process for loading and decrypting such a block of secured code is shown in FIGURE 20.
  • the CPU 120 In order to make sure that the hashing function is computed correctly (and furthermore, that the comparison between the generated message digest and the "real" message digest is valid), the CPU 120 must perform this hashing function in a secure manner.
  • the hashing function must either be generated directly by the hardware of the decoder unit or the hashing function itself must be computed using a block of "secure” code, the operation of which cannot be tampered with by an otherwise "non-secure" program.
  • this block of secure code should be considered as a part of the unit's 100 security system and, as such, may only be able to be downloaded to the player via a secure transaction between the unit 100 and the licensing authority 21 10.
  • the establishment of a "secure" hashing function can be accomplished via the same secure protocols described herein. This recursive behavior for all aspects of the security system is what enables a software-based version of this protocol to be extremely flexible (and thus, updateable) in its encryption/decryption architecture.
  • the target unit 100 can be certain that the encrypted code block 1910 is genuine (or at least that the code was distributed by the developer 2120 whose public key was used to decrypt the digital signature).
  • the target 100 then sends a secure message to the licensing authority 21 10 requesting a copy of the decryption key(s), which will be used in concert with the recently verified encrypted code block.
  • the target unit 100 As a part of setting up the secure connection with the licensing authority, the target unit 100 generates a temporary public/private key pair (the public portion of which is supplied to the licensing authority 21 10 server). The details of the key exchange procedure are well known and we need not go into the exact mechanism by which this is accomplished in this discussion.
  • the overall network traffic between the target unit 100 and the central server at the licensing authority 21 10 is limited to a reasonably small data set, since it consists of a couple of key transfers, the code-specific ID and the MAC which was stored along with it.
  • the central server transmits a copy of the target device's temporary public key (as well as the code-specific ID 260 in question) to the application developer's server.
  • the developer's server responds to the licensing authority 21 10 server with a message containing the requested decryption key(s) (encrypted with the target's temporary public key) and a message digest generated from the properly decrypted code.
  • the target device 100 can decrypt the message to obtain the application-specific decryption key(s) and the licensing authority 21 10 will not ever have access to the decryption key(s) in clear form.
  • the message digest can be pre-computed and stored on the licensing authority's server, the fact that it may be provided by the developer 2120 during the transaction is of potential use if the hashing function (which is used to generate the message digest) should ever change. If this should happen, the developer 2120 would need to provide updated versions of the decrypted code message digests to the licensing authority 21 10 either prior to or during the actual transaction with the target device 100. The developer 2120 must provide this information since the licensing authority 21 10 should never have access to the original (decrypted) code. As before, the amount of network traffic between the licensing authority's server and the developer's server is still quite small.
  • the encrypted key that was received from the developer 2120 is then encrypted yet again with the target device's primary secret key prior to transmission from the licensing authority 21 10 to the target.
  • This second encryption could actually be carried out on the developer's side as a part of the other transaction, but in that case, the developer would potentially have access to the target unit's primary key (unless both keys were somehow combined), which would pose potential loss of privacy issues for the end user.
  • FIGURE 21 The flow diagram for the whole key encryption/decryption process is outlined in FIGURE 21 .
  • the clear key would still be encrypted prior to transmission (as above) with both the target device's temporary public key and then again with the target's primary secret key.
  • the target device 100 has the proper decryption key in a doubly encrypted format.
  • the licensing authority 2110 does not have access to the application specific key 2150 information in the clear, then it should not be possible for anyone other than the intended target device 100 to be able to reproduce this key data in clear form, since the secret key for each unit 100 should only be known to the licensing authority 21 10, and the private key for the transmission is known only by the target 100.
  • the encoded decryption key(s) which the target 100 receives from the application developer 2120 cannot yet be stored safely in the open at the target 100 (e.g. in a flash ROM or backed up on a hard drive).
  • the problem is that the target device 100 would also have to store a copy of the temporary private key along with the encoded decryption key(s), which were transmitted from the licensing authority 21 10. If someone at the licensing authority 21 10 were to then gain access to these two pieces of data by some means, then they would potentially be able to reconstruct the decrypted application specific key 2150 (given that they might have access to the target device's 100 primary secret key as well).
  • the target can then use the application specific (clear) key 2150 in order to decrypt the code block (or media stream).
  • the only two places where the application code exists in clear form are at the original developer 2120 itself and inside the "secured" portion of the target device's l-Cache 1 10 (where it can only be executed and can never written back out to memory in clear form).
  • This allows privacy between the user and the licensing authority 21 10.
  • the licensing authority 21 10 does not have to know what it is that the user has a license to (an enormous privacy issue), but it is still able to act as a repository (or backup) for the user's key list in the case where their unit 100 is damaged or stolen or otherwise rendered inoperable.
  • the message digest of the properly decrypted code is then compared with the message digest generated by decrypting the digital signature, which was forwarded from the original developer 2120 through the licensing authority 21 10 to the target unit 100.
  • this digital signature is created by encrypting the message digest of the unencrypted code block with the application developer's private key.
  • this digital signature can also be encrypted again by the developer 2120 using another temporary public key 2130, which was supplied to the licensing authority 21 10 when the connection was established.
  • the correct message digest can then be decoded by the target device 100 by decrypting the digital signature with the developer's public key.
  • this message digest matches the MAC of the decrypted code block, then the code is considered to be genuine and it is allowed to run on the target 100.
  • This message digest may then be re-encrypted with the target unit's secondary key 2140 for archival along with the re-encrypted application specific key 2150.
  • the licensing authority 21 10 server for archival purposes. This transmission serves a few purposes. First, it is an acknowledgement that the target device 100 was able to properly decrypt the code block. Second, it is necessary for the licensing authority 21 10 to have a copy of this encrypted key 2160 in order to deal with the case where the end user suffers some sort of catastrophic data failure and they have neglected to make their own backup copy of their access keys. The licensing authority 21 10 can then act as a backup storage facility for any particular user. Yet another reason for this procedure is in order to deal with the case where a particular target device 100 changes ownership from one user to another or if the user wishes to upgrade their target device 100.
  • This kind of permanent transfer of ownership can involve the transferal of all of the licensed application keys for that unit 100 (in which case, there is nothing which needs to be done other than re-registering the unit under the new owner's name).
  • the user wishes to transfer permanent ownership of their key data from the first to the second device, then this may be accomplished by means of a secure transaction between the licensing authority 21 10 and both of the target device.
  • the other piece of information that the target device 100 transmits back to the licensing authority 21 10 server is the message digest of the target device's newly updated key list data structure 2210 (as depicted in FIGURE 22). This is both an acknowledgement of the newly updated key list data 2210 structure and is also used to verify the equivalence of the key list data structure 2210 associated with that particular target device 100 on the licensing authority 21 10 server and on the target device 100.
  • the exact construction of this data structure will be described in the following section. We will also discuss methods by which permanent transfer of ownership of a particular key or set of keys is accomplished in a later section.
  • the process outlined above is not the only manner in which the protocol can be used to transfer the application specific key 2150 from the developer 2120 to the target device 100.
  • the actual key transfer transaction can involve a direct connection only between the target 100 and the application developer 2120.
  • a connection must be established between the developer's server and the licensing authority's server in order to contribute the device specific encryption information to the transaction.
  • this protocol can be made to work in a secure fashion, and the example discussed above is just one of these.
  • the common thread is that all three parties must act together in order to ensure that the key data, which is transferred to the target 100, is only useable for that target device 100.
  • the structure of a key can be set up to have two pieces: a hardware-specific part as well as an application-specific part. It is not a requirement that these two pieces be completely inseparable. If they are inseparable, then we get the properties exactly as discussed earlier. If, however, there is a way to make the key pieces independently operable, then we can enable a global set of copy and use restrictions that could be independent of the actual code or of the actual target device 100. In other words, any developer 2120 could publish an application or media stream which had no restrictions on distribution, but which could not be read; only executed. This could be useful in the case where the licensing authority 21 10 wanted to send out a security system update that would run on all devices, regardless of the manufacturer.
  • Another example of this would be the broadcast of a publicly available media stream while still maintaining control over the copyrights to that stream.
  • a publisher could distribute an application, which anyone could read and/or copy, but which would only execute on one specific target device 100 or set of devices. This could be useful for sending out an "update this specific class of device" message, for example.
  • Another possible application is to send out an application, which would run everywhere and had no restrictions on distribution. This would be similar in nature to publishing the source code for a particular application (i.e. open source distribution).
  • Table 1 The different classes of security which are enabled by a separable H/W-specific and S/W-specific key structure are illustrated in Table 1 .
  • the data structure 2210 containing the list of application or media-specific keys, which are licensed to a particular target device 100 is a valuable commodity and, as such, it should be able to be backed up by the owner. Since the individual keys are encrypted with the target's secondary secret key (as described above), the list is only useful to the unit to which the keys are licensed. However, we need to be able to make sure that this data structure 2210 is secure from tampering, corruption and/or outright loss. In the case of a lost key list data structure, the entire data structure 2210 can be recovered by requesting a new copy of the key list for that particular target device 100 from the licensing authority 21 10, as was described earlier.
  • the protocol may accommodate a means for identifying such a change as being temporary.
  • the top-level encryption of the key list data structure 221 0 must be performed with the target device's primary secret key.
  • the main issue is that the licensing authority 21 10 must be able to regenerate the encrypted form of this data structure independently of the target device 100 in the case where the local copy of this data structure must be restored. If any other key is used to encrypt this data structure (such as the target's secondary secret key, for example), then when the target needs to make a change to the data structure (as is the case when a key is added to the list), the entire list must be transferred to the licensing authority 21 10 for backup purposes. This could potentially greatly increase the amount of network traffic that must be transmitted back to the licensing authority 21 10 and is not necessarily the most efficient use of the channel bandwidth.
  • this key list data structure 2210 be used for the storage of security system-related keys, in addition to being used for the storage of standard application or media stream specific license keys. Since this data structure is able to be regenerated by the licensing authority 21 10, in cases where it is desirable to update the security software which runs on the target device 100, it would be both more secure and more efficient (from the standpoint of code storage requirements on the target device 100) if the same key list data structure 2210 could be used for both functions.
  • the encrypted version of the key list data structure 2210 includes a message digest of the original key list data structure 2210. It should be noted that although each of the individual keys are encrypted, other pieces of the list itself are not separately encrypted at the point when the message digest is calculated. Following the message digest calculation, the entire key list data structure 2210 (including the message digest) is then encrypted with the key value and algorithm that are identified by the top-level (or master) key. This is done in order to prevent a malicious third party from tampering with the list, calculating a new message digest and then substituting the modified list for the genuine one.
  • this (decrypted) message digest is used to verify the authenticity and validity of the key list itself in the same manner as the way that a MAC is used for any other secure encrypted code block.
  • the fact that all of the elements other than the individual keys are only encrypted with the master key means that the list can be traversed (and the list maintained) without having to have access to any keys other than the top-level key. Also, a key list inventory can be compiled with only a single pass through the decryption block.
  • a third principle which is of interest is that the individual application code or media stream specific keys can be made large enough to accommodate individualized keys for each target device 100.
  • the key list data structure 2210 header shares the same set of characteristics as the application specific keys that make up the rest of the list.
  • the header can be thought of as a master key 2220 for the rest of the key list data structure 2210 itself.
  • the same principles of operation can be applied as far as how this key can be used to determine the management of the rest of the list.
  • This includes time-dependent management of the security system of the target device 100.
  • the target unit 100 can be forced to update its security system at pre-determined intervals, which is an extremely powerful concept all by itself.
  • the key list could contain a number of sections, each with its own master key 2220 (list header) and thus with its own independent encryption mechanism.
  • the list header contains a code specific ID field 260, which can point to an encrypted code block that is used to interpret the key list data structure 2210.
  • the whole list could then be contained within yet another master list, which includes its own master key (which is yet another list header).
  • the entire key list data structure 2210 can be recursively defined. As before, this recursive property can be used to update the security system by creating new key list data structures to address shortcomings of previous versions of the same data structure. Since the security of the whole list is contained within the "outermost" (or most recent) security layer, then the security of the entire key list data structure 2210 is always based on the latest iteration of the security software.
  • the key list 2210 may be maintained and/or updated under several common circumstances. These circumstances include (but are not limited to) the case where the status of one or more of the keys contained in the list is modified. There are a few basic mechanisms by which the ownership of a particular key 1 810 can be transferred from one unit to another and we will discuss these in later sections. In any case, however, the mechanism by which the revised key list is maintained can be split into two classes: those which require the intervention of the licensing authority 21 10 and those which can be carried out independently.
  • the target device 100 can keep track of the current state of the master key list data structure in an unambiguous manner.
  • the temporary key list can potentially be encrypted with either one of the target unit's secret keys 104. Since it is not necessary that the licensing authority 21 10 be able to reconstruct this data structure under normal circumstances, it is ostensibly not relevant which of the target unit's keys is used to encrypt it. However, it would potentially be of use to the licensing authority 21 10 if this list were also encrypted using the target unit's primary secret key. The reason for this has to do with license revocation and that situation will be discussed in a later section.
  • a second (and more important) distinction between the temporary and the permanent key lists is that a copy of the timestamp value 1830 which is associated with the most recent temporary key list data structure is also stored inside the target device 100 (i.e. on-chip).
  • This register is not software readable and is only able to be overwritten by secure code, as it is a part of the security block. The value in this register is used to determine what to do in the case where the temporary key list data structure is somehow lost and/or corrupted. We will discuss that procedure later on in this section.
  • a target unit 100 is able to (temporarily) transfer ownership of a particular key from its permanent list to another unit's 100 temporary list, but no (correctly operating) device is able to transfer ownership of a particular key from its temporary key list to any other key list.
  • This "permanent loan” feature is equivalent to the standard "Copy Once" functionality requirement that is part of most modern digital Copyright Control Information (CCI) systems.
  • CCI Copyright Control Information
  • FIGURE 23 a detailed flow diagram depicting the temporary "key checkout” procedure is shown.
  • the "key ownership" transfer procedure is somewhat similar to the procedure of checking a copy of a book out from a library.
  • the lender 2310 first generates an updated temporary key list for itself which prohibits the use of that particular key for the duration of the key checkout negotiation process. This action prohibits more than one borrower 2320 unit from requesting the same key.
  • the presence of the "checked out key" on the temporary key list of the lender unit 2310 is effectively used as a semaphore to control access to any particular key.
  • the initial amount of time that the key is placed "on restriction” should be limited to a relatively short period. This is to prevent the case where a borrower 2320 device requests access to a particular key for a long period of time and then is unable to complete the transaction for some reason from unfairly monopolizing the use of a particular key.
  • This relatively short checkout negotiation phase timeout also helps in the battle against the malicious device, which may be attempting to mount the equivalent of a "denial of service” attack against the lender unit 2310.
  • the lender unit 2310 can optionally ignore requests from devices which are not on its "approved borrower” list or if any one of those units should try to make too many requests within a certain time period.
  • the exact length of time that this temporary block is placed on the key is not important, but it should be long enough to allow any given checkout procedure to go to completion. In times of high network traffic or latency, this period could be extended.
  • the appropriate fields within the lender device's 2310 temporary key list can be used to indicate how many copies of a given key are checked out at any one point in time.
  • this list Since the temporary key list is potentially read from and updated on a much more frequent basis than the permanent key list, it is desirable that this list should be quickly accessible to the target unit, so it is recommended (although it is not an actual requirement of the protocol) that this list be stored in at least one location where the access latency is relatively short. On the other hand, it is recommended that the only place where this list is stored is some volatile storage medium (such as DRAM), since a power failure could potentially cause the loss of the unit's 100 functionality for an indeterminate amount of time. We will go into details about this issue later on in this section.
  • both the borrower 2320 and the lender 2310 devices can update their respective temporary key list databases independently. Thus, it is not a requirement that the borrower 2320 be in contact with the lender 2310 unit in order to "return a particular key to circulation". This is a major convenience factor in the case where the borrower 2320 and the lender 2310 devices are widely separated.
  • the security of this operation may depend on a very tight correlation between the on-chip clocks that are used to generate and control the key timestamp records.
  • the time/date clock must be an integral part of the security system and, as such, should be able to be overwritten by a transaction with the central server.
  • the clocks must be designed to be robust enough to resist tampering in the case where a malicious user tries to modify the internal timestamp value 1830 and also to be able to survive normally occurring system power failures. Since it is not inconceivable that this clock is battery powered and that the battery could get removed or it could go dead over time, the system should be designed in such a way that the clock could potentially be restarted and reset by an interaction with the licensing authority.
  • Another possibility for an enhancement is to store a pair of on-chip timestamp values rather than just one.
  • the additional timestamp could be used to indicate the earliest (next) time when the temporary key list must be updated. This would make it easier for the target device 100 to decide when it needs to revise its temporary key list, since it would not have to constantly check over the list (which involves going through the decryption process).
  • the reason that the permanent transfer process is simpler lies in the fact that it does not require the checkout time period negotiations that are prerequisites in the temporary key checkout procedure.
  • the reason that the permanent transfer function utilizes an interaction between the licensing authority 21 10 and the target unit 100 is due to the fact that the updated key list data structure must be able to be reconstructed at both ends of the transaction.
  • this body has the ability to revoke any or all of an individual target unit's 100 license keys in the event that it is proven that the unit 100 has somehow been compromised or if one of the keys has been identified as having been compromised. Since the potential exists to give a unique list of keys to each and every target unit 100 (as was described above), there could also provide an opportunity for the licensing authority 21 10 to track the source of any compromised keys. In such a situation, this protocol could fulfill the functionality that is normally associated with that of a "watermark" feature, but without the drawbacks of the traditional watermark process (such as the potential of the watermark to have an adverse effect on the quality of the media stream).
  • a target unit's 100 licenses may be revoked.
  • the simplest method is that of simply updating the target's 100 primary secret key. At this point, the target 100 would then be unable to access its permanent key list and thus, it would have to begin the process of creating a new one. Note that in the case where the primary secret key was not used in the encryption process for the temporary key list data structure, then this temporary key list could potentially still be accessed, even though the permanent key list might be otherwise inaccessible. This point was mentioned earlier in the description of the encryption process for the temporary key list. For this reason, it is probably the best idea to use the target unit's 100 primary secret key as the encryption key for both the permanent and the temporary key list data structures.
  • the simplest manner to effect this ownership change is to set the unit's 100 primary secret key to some new value. However, if this occurs before the original owner has the opportunity to recover all of their permanent keys from the target, then they will lose their licenses. In the case where the original owner wishes to transfer the ownership of the associated permanent key list along with the target unit, then nothing need be done to the target unit 100 except to change the ownership information that is associated with that particular device (which is stored at the licensing authority 21 10). [0280] Another manner by which license revocation can occur is if the master key for a particular target unit's 100 permanent key list "expires". Since updates to the unit's 100 security system are stored as a part of the permanent key list, this situation could potentially have disastrous repercussions.
  • Yet another manner of license revocation can occur if the licensing authority 21 10 chooses to override a particular key entry in a target unit's 100 permanent or temporary key lists. This could be used in the case where if a security system upgrade is required or in the case where a particular target unit 100 has been identified as having an unlicensed copy of a particular application or media stream. Since the target unit 100 normally maintains its own key list data structure, this procedure will involve a larger than normal amount of network traffic between the licensing authority 21 10 and the target unit. Thus, this course of action should be reserved for extreme cases.
  • the licensing authority 21 10 could, for example, limit the set of serial numbers on the "approved borrowers" list to those who have the same ownership information as the original target device 100.
  • Another possible solution to this problem is to require that any "borrower" device 2320 be validated as an "authorized” borrower by presenting credentials (such as a signed certificate) to the lender which can be verified only by decrypting the certificate with the central Licensing Authority's 21 10 public key.
  • credentials such as a signed certificate
  • This scenario would also, of course, involve the ability for the Licensing Authority 21 10 to revoke such a certificate in the case where a particular unit has been determined to be
  • both of a unit's 100 secret keys were discovered by means of such a process, however, it is possible that it would be possible to compromise the security of all of the application specific keys which were licensed to that unit, based on an examination of previously backed up copies of the encrypted key list digests. For this reason, both the primary and the secondary secret keys should be implemented on target chip in a "tamper-proof" manner such that any attempt to discover the value of these keys results in the loss of the key data.
  • any digital copyright protection scheme can possibly be defeated by the determined opponent.
  • This is even independent, of course, of the fact that access to the secret key information would definitely be a big advantage to the would-be attacker.
  • the ability to keep a unit's secret keys from being compromised is therefore an important part of this security protocol.
  • the copyright protection protocol described above is unique in several ways. First is the fact that it does not attempt to prohibit the user from having the ability to make backup copies of their legally purchased application or media specific key data. Second, this protocol does not make a distinction between any kinds of digital data and thus, allows the security protocol to be updated as easily as the data streams that it is designed to protect. Third, this protocol allows the user to temporarily transfer ownership of their application or media specific key(s) to another unit that is capable of executing the protocol. Also, this protocol also provides the ability for the licensee to effect a permanent transfer of ownership from one target unit 100 to another. This last property allows the implementation of the consumer's legal "right of first sale" under this protocol.
  • This latency between the selection of a particular code segment to be executed and the actual post-decryption execution can cause many problems including, but not limited to, processor pipeline stalls and data path inefficiencies as well as providing another avenue for potential attacks (by somehow hijacking the code in between the decryption and the execution operations).
  • Such a control mechanism may be coupled with embodiments of a data hiding system and method, based for example, on an explicitly ordered execution of a set of called code segments implemented in one embodiment via recursive execution.
  • embodiments of these systems and methods are utilized together an unencumbered generality as well as a level of protection against attack that surpasses many other security systems may be obtained.
  • FIGURE 1 gives a general overview of an architecture in which embodiments as described may be effectively utilized while FIGURE 2 depicts an architecture of one embodiment of a target unit that is capable of controlling the execution of the digital content or implementing security protocols in conjunction with received digital content.
  • FIGURE 36 one embodiment of a one-way hash function block that can use the result of a digital signature operation generated in one iteration of a recursive security protocol as a seed value for the one-way hash function in a subsequent iteration is depicted.
  • the state of the target unit as far as it pertains to whether it is operating in secured execution mode or not can be reflected by the value of a hardware bit 3670 that will be referred to herein as the "Secured Mode Enabled" bit.
  • the default state of this hardware bit may be cleared (i.e., the default state of the target processor is not to be operating in secured execution mode).
  • the interaction of this bit with the One-Way hash function hardware block 3661 in certain embodiments may be described in two parts. In the first (non-secured) case, all accesses to the Secret Hardware key 3640 are blocked, since the "Secured Mode Enabled” bit acts as a gatekeeper to only allow use of the Secret Hardware key when this hardware bit is set (for example to a "1 ", however it will also be noted that in certain architectures the bit may be considered “set” when it has a value of "0").
  • the output of the Digital Signature Register 3664 is fed back to form the input "Seed" 3610 of the One-Way Hash function 3661 .
  • the intermediate results of any of the one-way Hash function operations are fed back to form the seed for any subsequent one-way hash function operations.
  • the Secret Hardware Key is accessible (in other words, directly accessible or at least its value is able to be used in a calculation operation, even if its value is not directly accessible by the processor itself).
  • the output of the Digital Signature Register is not fed back to form the seed value for subsequent evaluations of the one-way hash function. The exact implementation of this Digital Signature generator block will be discussed in more detail at a later point.
  • the entire calling chain of a particular code block can be validated prior to its secure execution without the need to utilize measures such as system-wide software or hardware validation (or attestation) operations.
  • this "Secured Mode Enabled" bit may or may not be architecturally visible to the processor, but its state may not be explicitly set by the processor.
  • This hardware bit could be reset to a default value by calling a non-secured code segment, but in one embodiment, the only manner in which this bit can be set is through direct action on the part of the hardware.
  • the bit is architecturally visible, it can be explicitly determined whether or not the processor is operating in secured execution mode. In the case where it is not architecturally visible, then the determination can nonetheless be made implicitly by evaluating some expression whose value somehow depends on the hardware secret key.
  • the security of such a system may be based on the security of the unique attribute of each of the receiving devices.
  • This unique attribute is typically implemented using a secret key that is known only to the distributor and the authorized recipient. While, in principle, this kind of setup can be an effective security system, the requirement that the original digital content be separately encrypted for each recipient makes the actual implementation impractical for most purposes. If it is desired that the original digital content be encrypted once and identically distributed to all potentially authorized parties, the problem then reverts back to that of data hiding.
  • These types of problems are known as the field of Broadcast Encryption.
  • such desired control may be implemented, using a simple time-dependent use of an architecturally hidden secret key or an encrypted object code block that must be decrypted in real time prior to execution.
  • the code block execution can be completely transparent to the control mechanism, which means that the execution speed should be minimally affected.
  • the code block to be run may be decrypted prior to execution, so there is most likely a concurrent loss of performance due to the latency of the decryption process.
  • the object code may be relatively safe from disassembly and is thus potentially more difficult to subvert by would-be attackers.
  • Embodiments discussed herein at a later point disclose systems and methods that can be implemented in a large continuum of possible solutions, ranging from a highly secure encrypted object code method to a relatively higher-performance, but nonetheless still quite secure selectively-available, secret key method.
  • hiding the secret key from the user of such a secret key may be
  • a secret key may be used in an encryption/decryption calculation, but never actually directly read by the processor.
  • This distinction may be enforced by limiting the encryption/decryption operations to those that are either implemented in hardware or are pre-determined software macros (also known as micro code), fixed at the design time of the hardware.
  • a hardware secret key may be used by any arbitrary code, even though it may not be able to be directly read by the processor, it can nonetheless be readily determined by simple calculations.
  • processors have been widely studied for many years. Some of the earlier attempts to create secure code execution protection have included making modifications to the processor architecture in order to establish a set of "privileged" instructions. These privileged instructions were secured by designing the architecture such that these privileged instructions could only be executed when the processor was running in a particular mode, known as “supervisor” or "kernel” mode. This kind of bifurcation of the processor architecture has a number of drawbacks, including a potential loss of both processor generality as well as a potential degradation in performance. In addition to these drawbacks, such protective measures can often be bypassed by using specifically designed software calls to standard system routines in such a way as to take advantage of unexpected execution paths while the processor is executing in supervisor mode. Examples of such specifically designed malware attacks include so-called “stack overflow”, “stack overrun” and "code injection” attacks.
  • hijacked includes the use of encrypted code blocks.
  • the code segments to be executed are pre-encrypted and thus, non-readable (and perhaps even more importantly, non-alterable) prior to their loading into the processor.
  • This method also has several weaknesses.
  • the code segment itself may be protected, but the arguments are not necessarily provided with the same level of security. Thus, a completely legitimate and secure code segment can be nonetheless provided with bogus arguments from its calling routine that can cause it to behave in an unexpected fashion.
  • the execution thread is not necessarily protected against the return-based programming attacks described above.
  • processor bus can be readily observed by the attacker, then the long-term observation of both correctly-executed (even though encrypted) code segments as well as the observation of exception faults caused by improperly encrypted code segments injected into the executable stream can help to reveal the encryption key using a modified dictionary attack methodology.
  • processor performance in such a system is necessarily severely degraded over similar, but non-encrypted code systems. This performance penalty can be caused by a number of issues, the most significant of which is the latency incurred by the requisite decryption of the code block between when it is fetched from memory and when it is available to be executed.
  • Embodiments of the systems and methods described in this invention may allow the utilization of unencrypted code blocks, so the performance penalties associated with encrypted executables are thus less of an issue. However, in the case where the execution efficiency is not a substantial concern encrypted code blocks may still be utilized.
  • embodiments disclosed herein may have both the efficiency of plaintext executables as well as the added security of encrypted code segments utilizing the same or similar methods and systems.
  • embodiments of the security systems and methods described herein can be updated in-situ to address newly discovered security concerns as well as to add new functionality after an embodiment has already been deployed.
  • Embodiments of the invention may attain these advantages, among others, by ensuring that a "secured code segment" is validated prior to execution by means of a cryptographic hashing function.
  • This validation may be accomplished, for example, by authenticating a message digest or digital signature created for such a secured code segment.
  • a particular code block can be uniquely associated with a specific target unit or processor. This process will be referred to herein as "secured code binding", based on the fact that in certain embodiments this secured code block can be cryptograph ically bound to a specific target unit using the compound key based digital signature.
  • the secured code segment can be introduced into the execution pipeline prior to completing its cryptographic validation.
  • the hashing function can potentially be evaluated in parallel with the execution of the secured code segment itself (in a manner similar to speculative branch execution).
  • the results of the secured code segment may be utilized only if the resulting message digest is determined to be genuine.
  • the results of the secured code segment may be utilized in subsequent operations, but the results themselves may be different depending on whether or not the processor is operating in secured execution mode.
  • This embodiment is substantially similar to the process described earlier for the evaluation of a compound key for use in a digital signature and can be generated by use of the hardware such as that depicted in FIGURE 36.
  • Embodiments of techniques of doubly encrypting a secret may have certain issues, if it is incorrectly used.
  • this intermediate key can be used to bypass the higher level security on any and all such systems.
  • this intermediate result is actually a "global" decryption key that, if discovered, can be used to bypass the entire security system for all substantially similar endpoint devices.
  • the old (compromised) keys may still be used if the original system is either reset back to its former state or if its former state is cloned by an impostor unit.
  • the intermediate results of the security system traversal can potentially be bypassed because, as noted earlier, the attacker could simply wait for the next lower level key to be exposed in a legitimate security system traversal and then use that intercepted key to clone a counterfeit "earlier" version of the system.
  • embodiments of systems and methods are described that can not only enforce this "inside out” execution ordering, but also can protect intermediate results from being intercepted by malicious code or other well-known security system exploits.
  • embodiments may have a built-in mechanism for performing a significant amount of the system attestation function without incurring any additional performance penalties most usually associated with such functionality.
  • certain embodiments may utilize a means to keep intermediate keys from being exposed to higher-level (and thus, less secure) security system routines as well as to ensure the proper security stack traversal method.
  • One such method for achieving this is to use a recursive security structure, one embodiment of which is depicted in United States Patent Application No. 10/465,274, entitled “Method and System for a Recursive Security Protocol for Digital Copyright Control” by William V. Oxford filed June 19, 2003, which has since issued as United States Patent No. 7,203,844, on April 10, 2007, which is herby
  • the stack order traversal can be designed so that it must be evaluated from the "inside out”. This means that the most recent security system additions are executed first and the system cannot be "started in the middle” (for example, as used in "return-based” programming exploits).
  • a second advantage of a recursive system is that the addition of any updates to the security system may not change the original calling arguments at the security system itself. Accordingly, it may be more difficult to spoof the security system by using a traditional replay-based attack mechanism.
  • the compound key structure may also be protected from partial evaluation by tightly
  • the secret key is stored in an inaccessible memory location which is not architecturally visible, then it may only be accessed as a part of a particular security-related instruction or function.
  • this function or instruction is one that may not be easily reversed such as a non-trivial one-way transform. That way, even a counterfeit security system should not be able to reveal the value of the secret key.
  • the secret key may be protected as the secret key can never be used by itself as a part of a mathematical operation, but only as a part of a hashing operation either alone or along with some other datum, where only the result of the hashing function may be observable.
  • One such potential mechanism is the use of a compound key, where the target unit's secret key is tightly coupled to some other constraint or a set of additional operands.
  • secondary operand may include a separate secret key, a globally visible register (such as a timestamp or system version number), the message digest of the code that is accessing the secret key, etc.
  • this last example could ensure that the secret key may only be accessed by a segment of code that is authorized to use that very same key.
  • the message digest is encrypted to form a digital signature and if the key that is used to encrypt that message digest is the secret key itself, then a circle of dependencies can be created that can ensure that the only method to access a secret key is by using a code segment that was authored by someone who already knew what that secret key was.
  • a compound key structure allows us to validate the "authority" of a piece of code that requests use of the target unit's secret key before it is allowed to use that key.
  • the difference between a "layered key” structure and a “compound key” structure is that in certain embodiments, the latter may be evaluated in an atomic fashion, which itself can be accomplished by recursive means. If it is attempted to assemble a similar structure using an iterative approach, as opposed to a recursive structure, then there may be a risk of exposing the intermediate results of the key evaluation process (and thus, potentially exposing the secret key). This "exposure” may occur when secret keys (or their progenitors) are stored in publically available locations, such as general-purpose registers that are pushed out to main memory when an interrupt occurs (or even directly in memory itself).
  • a potential security breakdown that may be addressed in certain embodiments is the
  • the security system stack traversal may not be restarted in mid-execution (i.e., the calculation must restart from the beginning).
  • the recursive security protocol can be used in this manner to prevent any intermediate results from being stored on the system heap (and thus potentially exposed to unauthorized observers).
  • the recursion can be signaled to terminate when the message digest of a given code segment matches that supplied with the code segment itself.
  • a digital signature may also be utilized in certain embodiments.
  • a digital signature mechanism has the potential to provide at least two main attributes: 1 ) an assurance that the code segment has not been tampered with and 2) ready identification of the code segment author.
  • additional security may be desired since the digital signature itself may be modified at any time and thus may not necessarily be genuine.
  • a public-key system may be used to validate the digital signature or a compound key structure (as described above) may be used to assure that the digital signature provided with the code segment in question was created by some party who was in possession of the target unit's secret key.
  • the use of that compound key may also be limited to a single endpoint or some set of endpoints.
  • both the public-key as well as the compound key approaches may be utilized in tandem. In that manner, it can be guaranteed that both the code segment is genuine as well as that the code segment is intended for the recipient of the compound digital signature.
  • a set of conditions that must be in place before the "execution phase" of the security system stack traversal may be specified.
  • these conditions can be expressed as an "intersection set" of all of the individually required security conditions. That way, when new security risks are discovered additional conditions which account for those risks may easily be put in place. These conditions can ensure that no portion of the security system will be allowed to execute until all of the conditions, both new and old, are met.
  • This "intersection set" of the various security system conditions can be achieved through the use of a compound key structure mechanism as discussed above.
  • this secret key can be considered as one of the "Roots-of-Trust" of the entire security system.
  • a hardware-based timestamp mechanism is utilized as one of the other components of the compound key, then the system can be better protected against replay attacks.
  • Such components include using a hardware-based hash calculation of the message digest of a code block as a part of the compound key in order to prevent the key from being properly evaluated if the code has been tampered with.
  • another such component may be a digital signature of some selected subset of the calling arguments of the code block to be executed, which could protect against stack overflow style attacks.
  • a recursive system with its ability to enforce of inside-out security stack traversal and limits on the visibility of intermediate results can thus provide an enhanced robustness against external attack as well as flexibility when it is desired to add more constraints on the security system evaluation in a minimally disruptive fashion.
  • the flexibility of how the digital signature is used may be increased. For example, if a code segment is allowed to pass the digital signature through the parsing process unchanged after the first iteration, then that code segment can be validated without having to specify in advance how many times the security system cycles through that particular code block. Similarly, it could be specified that the digital signature would be reset to a known "seed" state as a particular code segment is encountered. Thus, simply by supplying a single unique number (which can be stored in the clear) a unique variation of how many times and in what order the various portions of the security system are traversed may be specified. In fact, such a code validation process can be used to implement a variety of useful functions and thus, this technique does not necessarily have to be limited to the exclusive use of the security system itself.
  • a hardware-implemented version number may be utilized as one of the compound components of the digital signature evaluation. If the hardware version number is updated each time the security system is modified (and if that update is secure), then it can be ensured that the security system is matched to the target unit on which it is executing. Note that this is distinct from the time-stamping mechanism described earlier, although the two may be used together in a compound key evaluation to protect against replay attack scenarios or other violations.
  • a simple but yet effective method for accomplishing this could be to first replace the decryption key pointer for the code block in question with a new pointer that leads to a means for replacing the old version of the code block with the updated version and then to update the target endpoint device's timestamp register.
  • the updated timestamp register value may invalidate all of the previous digital signatures that were generated using the old value and may thus entail that the entire security system be revamped (ideally in a secure manner) to bring it up to date and to replace the old digital signatures (or keys) with new key/digital signature values and updated functionality.
  • One embodiment of such a forced update scenario may be referred to as logically equivalent to adding a layer of encryption to an otherwise directly executable code block (simply by forcing a single digital signature mismatch).
  • the code that makes use of such a key must be designed in a manner such as to prevent these secret keys from being compromised.
  • a secured code binding mechanism to prevent the correct execution of an otherwise legitimate code block on a particular endpoint device when it is used in an unauthorized manner.
  • this secured code binding is based on the requirement that the result of applying a specific kind of hashing function to a candidate code segment must match a specially pre-determined message digest provided with that code segment before that code segment is allowed to execute.
  • This hashing function may be applied after a candidate code segment is called, but before it is allowed to execute. Once this hashing function has been initiated, any writes to that particular memory space comprising the candidate code segment may be either disabled or ignored. If the candidate code segment is located on the same chip as the CPU execution unit, such as in the CPU's instruction cache, then this may be easily implemented.
  • the candidate code segment is allowed to execute in what is termed "Secured Mode" or "Secured Execution Mode". As described earlier, only code that is operating in Secured Mode can utilize the architecturally invisible secret key. If a particular code segment is not operating in Secured Mode, then the secret key(s) are disabled and any reference to one of them will return some other value (such as zero).
  • the hashing function utilized used in calculating the message digest for the candidate code segment may have certain properties.
  • the first property is that the hashing function may be implemented in the hardware of the target unit. This means that this function cannot be completely replaced by some other, (perhaps subverted) version of this original hardware hashing function. It should be noted that this hashing function may be supplemented by a refined version (or even a conditioned outright replacement) of the original function when desired.
  • the method for replacing the hardware hashing function with a refined version would be substantially similar to the procedure described earlier that is used to insert new layers into the security system, through a recursive definition of the security system's structure.
  • the new hashing function could replace the original function for the purposes of all subsequent security system operations, this new hashing function itself may still rely on the original hardware hashing function as the foundation of its root of trust.
  • the use of the term "conditioned outright replacement" in one embodiment, the original hardware-based root of trust may remain constant. This may be desirable in that it can be very difficult to undermine such a hardware-based security system.
  • a shortcoming in the original hardware hashing function is found after the target device has been deployed in the field; such a shortcoming can potentially be contained by using the original hashing function in a single application, where the calling arguments can be effectively limited.
  • a second property of the hardware hashing function is that it may use the architecturally invisible secret key as its seed value.
  • the message digest result of such a hardware hashing function can differ from unit to unit. This difference can be exploited in that it could result in a unique message digest for each and every target unit.
  • This property is similar in concept to that of a digital signature, but it does not necessarily require the addition of a separate encryption/decryption block to the hardware hashing function. Since the candidate code segment is then constrained to execute (at least in Secured Mode) only on units where the hardware-produced message digest matches that which is distributed with the candidate code segment a circular dependency has been created.
  • This circular dependency means that only code whose message digest has been created with the secret key of the correct target unit can actually make use of this same secret key. This property substantially impairs the ability for a would- be attacker to create a code segment which would be allowed to execute in secured mode on a target device.
  • each target unit may have a unique set of
  • architecturally invisible secret keys In other embodiments, however, some subset of these keys may be common to a number of identical devices. Thus, a particular code segment can be bound to a particular class of endpoint devices with a common subset of keys, while still protecting this set of architecturally invisible secret keys that are held in common between such devices.
  • the combination of the hardware hashing function and one or more architecturally invisible secret keys may thus provide the basis for a chain of trust for a highly effective and robust recursive security protocol.
  • Digital Bitstream refers to a generic collection of digital data and thus, this term may be used interchangeably with the words Digital Content, Code Block or Digital Data Set.
  • Code Block the referenced data can be further assumed to represent an executable file, an executable script or even an algorithmic description or block of pseudocode.
  • FIGURE 24 depicts one embodiment of the creation of a compound key for digital content.
  • This compound key 2410 may be created by applying encryption engine 2420 to a global content key 2430 (which may be provided or determined by the owner or author of the digital content) utilizing an endpoint specific hardware key 2440, which may be an architecturally invisible secret key (as discussed above) associated with a particular endpoint device (target unit).
  • the resulting compound key which is specific both to the particular endpoint and the digital content may be transmitted and stored to, and stored in that clear, on an endpoint device to which the compound key is provided.
  • FIGURE 25A depicts one embodiment of the creation of a secured digital data block structure.
  • the digital data block 2510 may not be encrypted, but a digital signature 2520 is formed by encrypting the message digest calculated by the Hashing Function 2530 from the digital data block with one or more tokens 2540 or 2550. These tokens may be either secret keys or publicly available data, such as a timestamp. Note that the methods employed to encrypt the data passing through the encryption engine(s) 2560 and 2561 may or may not be identical. In the case where a secret key is used as one of the encryption keys, then it may be more difficult to forge the Digital Signature without knowledge of that secret key value. It is also instructive to note that the order of the encryption operations 2560 and 2561 are not relevant to the overall security of the result, but the resulting Digital Signature 2520 will be different if the order of the operations is changed.
  • FIGURE 25B depicts an alternate embodiment of the creation of a secured code block data structure.
  • a secret key 2570 is appended to a digital data block 2571 to form an overall message 2580.
  • secret key 2570 should not be published along with the original digital data set 2571 . Therefore, the published data set would be restricted to just the digital data set 2571 rather than the entire data structure 2580.
  • This entire data structure 2580 is then run through a hashing function 2530, in essentially the same manner as shown before with respect to FIGURE 25A.
  • the final output 490 has many of the characteristics of the digital signature 2520 shown in FIGURE 25A, but may not require the use of encryption engine(s) 2560 or 2561 .
  • the result 2590 of this operation will be referred to as a digital signature equivalent. It should be noted that this digital signature equivalent 2590 is unique (assuming that the hashing function 2530 is properly constructed) for each unique overall data structure 2580.
  • digital data block 2571 may be considered to be "bound" to that secret key 2570 (and thus, to the target device).
  • FIGURE 26A depicts one embodiment of how a security system such as that described herein may be used to cryptographically bind an encrypted data block 2610 to a specific decryption engine code block 2662 and then to bind that combination 2630 to a specific endpoint's hardware secret key 2623 using a digital signature 2624 that is calculated by means of hashing function 2640 and an encryption engine 2661 .
  • the Public Key 2622 (which is constructed by encrypting the message digest 2621 of the Decryption Engine Code Block 2662 with the Global Content Secret Key 2620) is publicly distributed along with the original encrypted data block 2610 as a single concatenated data set 2630.
  • the act of creating a digital signature 2624 from the message digest of the combined message 2630 ensures that only the properly authorized endpoint devices are able to decrypt the original encrypted data block 2610, and not only that, but that this decryption process can only be accomplished by using the prescribed method of Decryption Engine 2662. Note that more constraints can be easily added to the decryption authorization procedure by adding more components to the encryption engine chain 2660 (such as a multi-term compound encryption, for example).
  • FIGURE 26B depicts a variation of the embodiment shown in FIGURE 26A. In this
  • the author of a particular encrypted message 261 1 can be unambiguously authenticated, but only on a specific endpoint device.
  • the original encrypted data block 261 1 is cryptograph ically bound to a specific decryption routine 2662, as described above.
  • decryption routine 2662 is an asymmetric encryption engine, where the input may be the author's secret private key 2625, and the output would only be correctly decrypted using the author's public key.
  • the message digest 2627 of asymmetric encryption routine 2662 is appended along with digital signature 2626 to the original encrypted digital data 261 1 to form an overall data structure 2631 .
  • Data structure 2631 can then be cryptograph ically bound to a specific endpoint device by using that endpoint device's secret key 2623, hashing function 2644 and encryption engine 2661 to form digital signature 2628.
  • endpoint device's secret key 2623 hashing function 2644 and encryption engine 2661 to form digital signature 2628.
  • the encrypted message 261 1 is genuine and its author is known as well as the fact that the author is in possession of the hardware secret key 2623.
  • the term author as used herein does not necessarily mean the originator of data but may also refer to a licensor, distributor, or another type of entity which wishes to distribute or otherwise communicate such data.
  • this particular chain of trust can be of significant use is in the case where the endpoint device's security system is to be updated using a secured code block (which would be contained in encrypted form in the original data block 261 1 ).
  • FIGURE 27 depicts one embodiment of utilizing a cascaded hashing method in order to control the execution of a secured code block 2720.
  • the first code block (secured code block 2710) includes an embedded subroutine call to the second routine (secured code block 2720).
  • the message digest 2730 computed by the hashing function 2740 for secured code block 2710 is dependent on the reference to secured code block 2720 that is contained inside secured code block 2710. This message digest 2730 then links the two secured code blocks together from the perspective of secured code block 2710.
  • the message digest 2750 may be constructed for code block 2720 using hashing function 2770.
  • the original message digest 2730 may be used as a seed to the message digest 2750 that is computed by hashing function 2770. Recall that such a seed value can be implemented in many ways, but one such method is to simply concatenate the original message digest 2730 to the second digital data set (for example, in this case secured code block 2720) to form an overall message 2760.
  • Overall message 2760 is then run through hashing function 2770 (which can either be identical to hashing function 2740 or it can be some other independent hashing function) to form a second message digest 2750, which is thus dependent on both secured code block 2720 as well as the original message digest 2730 (which is itself dependent on both secured code blocks 2710 and 2720).
  • hashing function 2770 which can either be identical to hashing function 2740 or it can be some other independent hashing function
  • This second message digest 2750 can then be used in a manner substantially similar to that described above to ensure that secured code block 2720 may only be executed correctly if it is called from code block 2710.
  • code block 2720 may actually be an exact duplicate (or equivalent reference) of code block 2710, which would make this an embodiment of a recursive system.
  • the only difference between the two instantiations of the same code block may be the particular message digest that is appended to the code block in order to form the secured code block message digest.
  • FIGURE 28A depicts embodiments of the construction of a secured code block message.
  • the Encrypted Digital Data Set 281 1 has been encrypted using an encryption algorithm that is identified by pointer 2820.
  • the data structure 2830 is formed by a concatenation of Digital Data Set 281 1 and Pointer 2820.
  • the message digest 2850 of data structure 2830 is generated by hashing function 2840. This arrangement allows the cryptographic binding of an encrypted data set and its associated decryption routine.
  • an additional term is added to the concatenated data structure 2831 , namely the pointer 2821 to the decryption key 2860.
  • this key 2860 is not necessarily a hardware-based secret key as is depicted in this particular embodiment.
  • the key 2860 that is pointed to by pointer 2821 may even be itself a data structure, as will be discussed in the description of FIGURE 28C below. Otherwise, this embodiment is substantially similar to previously described embodiments.
  • Encrypted Digital Data set 281 1 is created as a result of using encryption engine 2870 and one or more keys 2860 operating on the original unencrypted data set 2810.
  • the message digest 2851 is generated using Hashing Function 2841 on the concatenated data structure 2831 .
  • FIGURE 28B depicts one possible embodiment for a basic generalized format for a Universal Cryptographic Data Structure that can thus be used in a recursive security system.
  • Embodiments of this structure may be simple and powerful, and can be implemented as a simple linked list of three basic elements; a generic data block 2812, a decryption pointer 2820 and a decryption key pointer 2821 .
  • the overall linked list is bundled together in a data structure 2832.
  • one embodiment may comprise an auxiliary data structure 2813 that includes some other independent, but perhaps related, data that is stored in conjunction with the overall data structure 2832.
  • One embodiment of this concept might be to locate the actual decryption engine code block 2871 , such as that which is pointed to by pointer 2820 inside the auxiliary data structure 2813 of FIGURE 28.
  • Another such example could be to store the actual key value that is specified by pointer 2821 inside this auxiliary data block.
  • auxiliary data blocks may be used in the process of generating a message digest or a digital signature as depicted variously in the embodiment examples presented in FIGURES 25A, 25B, 26A, 26B, 27 and 28A.
  • the ordering of the various data fields stored in a concatenated data set may have an impact on the resulting message digest (or digital signature), if the hashing function is properly designed.
  • FIGURE 28C depicts one embodiment of such a secured data block 2833 which comprises only keys.
  • a data block may comprise a list of device specific keys 2814, 2815, 2816 (or others, as desired).
  • any of these keys may have been created using (for example) a secret key of an endpoint device 2860, and an endpoint device timestamp register 2890, which were encrypted using encryption engines 2871 and 2872 respectively.
  • encryption engines 2871 and 2872 should be distinct or even different and there may no fundamental limit to a certain number of these encryption operations in the encryption chain and, while the order of these operations may matter to the resulting compound keys, there is no requirement for a particular order for the encryption operations.
  • the key list pointer element 2821 of the concatenated key list data structure 2833 may point to yet another concatenated key list data structure 2834. Since both of these data structures are of the same universal cryptograph ical format as depicted in FIGURE 28B, the key list data structure can be formed in a recursive manner.
  • the keys 2833 for use in embodiments of such in a recursive security system may be protected in the same manner and using the same structures as any other data to which embodiments of such a security protocol may be applied and similarly, these protected keys may also be decrypted and authenticated on an endpoint device in the same manner as other data secured by embodiments of the systems and methods disclosed herein.
  • FIGURE 29 one embodiment of how a compound key may be utilized to decrypt encrypted content is depicted.
  • This decryption operation may occur in "secured mode", as described above.
  • content 2910 may be provided to an endpoint device along with a compound key 2930 where the content has been initially encrypted using a global content key.
  • the compound key 2930 may be created as described above in FIGURE 24. Accordingly, when the encrypted content 2910 is received at an endpoint device it may be received with an associated compound key 2930. Executing in secured mode, such that the secret key 2940 at the device may be accessed, the compound key 2930 may be decrypted inside of secured code block 2960 to yield the global content key.
  • the global content key may be used, in turn, inside secured code block 2960 to decrypt the original encrypted content 2910 to yield decrypted content 2980.
  • FIGURE 30 depicts one embodiment of how a secret key may be utilized to verify that a code block is authorized to run on a particular endpoint device before execution.
  • Candidate code block 3010 for execution may be provided to an endpoint device or may be obtained by decrypting encrypted digital content which was received (for example, as depicted earlier in FIGURE 29). Additionally, the endpoint device may receive a corresponding digital signature 3020 corresponding to the candidate code block 3010.
  • This digital signature 3020 may comprise a message digest created from a code block (for example, by hashing that code block) which has been encrypted using the endpoint device hardware specific secret key 3030.
  • an authentication operation may be implemented in secured mode whereby the candidate code block 3010 is hashed to create a message digest (3012).
  • This message digest 3012 can then be encrypted using the endpoint device hardware specific key 3030 of the endpoint device (which may be accessible because the verification is occurring in secured mode) to create a digital signature that is compared with the originally supplied digital signature 3020 in step 3014. If this digital hardware-generated digital signature matches the received digital signature 3020 corresponding to the candidate code block 3010, then the candidate code block 3010 may be considered verified and may be deemed executable, otherwise an exception error may occur (step 3016).
  • FIGURE 31 is a block diagram of one embodiment of how a code block may be allowed to run on a particular endpoint processor (under prescribed circumstances) in "secured execution" mode.
  • the pre-computed digital signature 3130 (which can also be referred to as an endpoint-specific decryption key) of the code block 31 1 1 is constructed using the message digest of the code block and encrypting it with one or more of the following: the secret key 3140 of an authorized target endpoint device, the most recent timestamp value 3141 of the authorized target endpoint device, or one or more of any number of constraining conditions as described earlier (not shown in this particular embodiment).
  • a masking function to a subset of the term itself. For example, if a number of the least significant bits of the timestamp field are masked off (and thus may not be considered in the calculation of the digital signature), then the effective granularity of that timestamp value can be easily controlled on a code-segment by code-segment basis without any changes in the hardware. This same principle can be applied to any number of the terms that are used in the calculation of the digital signature in certain embodiments.
  • the concatenated digital data set 31 10 that contains code block 31 1 1 also includes at least one decryption pointer 31 12 and at least one decryption key or key list pointer 31 13. Also as described before, either one of these may refer to an external data structure (such as the Endpoint Specific Digital Key or Digital Signature 3130) or to an embedded data structure that is wholly contained within the concatenated data set 31 10.
  • code block 31 1 1 is not encrypted (and is thus potentially executable on the endpoint device target processor).
  • the decryption pointer may be null, since there is no further decryption required for the code block 31 1 1 prior to its use.
  • its corresponding decryption key (pointer) 31 13 may point to the associated endpoint or hardware-specific digital signature 3130.
  • embodiments of data structures and methods such as those depicted earlier in FIGURES 25A, 25B, 26A and 26B may be used to enforce a wide variety of authentication, cryptographic binding or other constraints on the use of an unencrypted data set such as depicted in block 31 1 1 .
  • the endpoint specific digital signature (or decryption key) 3130 points only to the hardware secret key 3140 or alternately, only to the hardware secret key 3140 and the endpoint device timestamp register 3141 .
  • the security system recursion has "terminated” at this point.
  • This recursion termination condition is detected by hardware block 3150, which acts as a "gatekeeper” to selectively allow or deny access to the value of the endpoint specific hardware secret key 3140, and then only as an input component to a cryptographic function that uses output of the hardware hashing function block 3161 .
  • the hardware specific secret key 3140 and the (message digest) output of hardware hashing function block 3161 are used as input arguments to encryption engines 3162 and 3163.
  • FIGURE 32 depicts one embodiment of a decryption operation which may be performed by a recursive security system.
  • This decryption operation may use a compound key to validate a secured code block that is to be used in the process of decrypting or otherwise manipulating and making use of distributed content.
  • an endpoint device may receive a data structure 3210 containing encrypted content 321 1 , a pointer 3212 to a decryption engine 3220 (or the decryption engine itself) and a pointer 3213 to an Endpoint-Specific Compound key 3230 (as discussed earlier with respect to FIGURE 30).
  • the compound decryption engine 3240 pointed to, or received will be authenticated.
  • This authentication may be accomplished by calculating the message digest 3222 of the compound decryption engine 3240 code block using the hashing function 3221 resident in the endpoint device.
  • the hashing function 3221 is depicted as being a hardware block in this example, this hashing function 3221 may be, for example, a secured software code block that can be used in place of the endpoint device's built-in hardware hashing function, as was discussed earlier. In this case, however, the software version of the hashing function may still ultimately depend on the built-in hardware hashing function for authentication or authorization purposes, so the eventual root of trust in this case still resides with the endpoint's built-in hardware hashing function block 3221 .
  • the message digest 3222 generated by this hashing block 3221 may then be compared in step 3223 against a pre-computed message digest 3250 that corresponds to the decryption engine 3240.
  • This pre-computed message digest 3250 may for example, have been provided to the endpoint device in a secure fashion, or pre-computed and stored on the endpoint device itself. If the message digests match, then the compound decryption engine 3240 may be allowed to execute on the endpoint device (step 3225). If the message digests are not substantially identical, then an invalid code exception may occur (step 3226).
  • the processor of the endpoint device may then enter secured execution mode to execute the code contained in the compound decryption engine 3240.
  • the first part of this compound decryption engine 3241 may be accomplished utilizing the endpoint device's hardware-specific secret key 1 131 to generate the global content specific key from the compound key (step 3232).
  • the second decryption operation 3242 may then use the intermediate result generated by decryption operation 3241 in order to generate the decrypted content 3252 from the encrypted content 3210, using the obtained global content specific key.
  • decryption engine 3240 is depicted as a pair of decryption algorithms (3241 and 3242), it may encompass any fewer or greater number of cascaded decryption stages such that the final result of the operation of the various individual components (3241 , 3242, etc.) of secured code block 3240 applied to the original encrypted data set 3210 will produce the desired decrypted content result 3252. It should also be noted that any two of these various individual decryption components may be either the same or different algorithms.
  • a compound key may be formed from the pre-computed message digest using an endpoint device specific hardware key and an endpoint specific timestamp value, in substantially the same manner as was depicted earlier with respect to FIGURES 25A, 28C and 31 .
  • FIGURE 33 depicts one embodiment of the implementation of a recursive security protocol at an endpoint device. Specifically, one embodiment of the use of a set of compound keys for the validation of a secured code block as well as for the actual decryption /or other use of a distributed digital bitstream is depicted. This embodiment is similar to the embodiment depicted in FIGURE 32 in many aspects so only those aspects of the embodiment that are different will be concentrated on with respect to FIGURE 33.
  • a message 3310 comprising encrypted content 331 1 may be received including a pointer 3312 to a decryption engine 3340 (or the decryption engine itself), a content specific compound key 3331 (as discussed with respect to FIGURE 29) and an endpoint and time stamp specific compound key 3332.
  • the encrypted content 331 1 can be loaded into memory at the endpoint device and the pointer 3312 to decryption engine 3340 may also be loaded into memory (for example, the instruction cache or secured portion of the instruction cache at the endpoint device).
  • the decryption engine 3340 pointed to will then be authenticated. This authentication may be accomplished by computing the message digest of the encryption engine 3340 using the hashing function 3321 that is resident in the endpoint device, in a substantially similar manner as was described with respect to FIGURE 32.
  • the hardware-generated message digest may then be encrypted using an encryption engine, which may be implemented either in hardware or in software on the endpoint device, and which comprises one or more cascaded compound encryption engine stages 3324, 3325, etc. that operate on the computed message digest and one or more of the hardware specific keys or registers, such as the endpoint device hardware specific secret key 3370 or the value of the endpoint device timestamp register 3360.
  • the resulting compound digital signature 3326 that is generated may correctly correspond to the decryption engine code block 3340 and may also thus be cryptographically bound to the specific endpoint device (by using one or more encryption stages 3324, 3325 and the various secret or public variables or constants such as 3360 and 3370).
  • this generated digital signature may optionally be further encrypted (using either the same or different encryption engines) and other constraining variables or constants in order to further limit the applicability of this compound digital signature.
  • one or more of the encryption stages may be optionally limited in order to broaden the field of potential generated compound digital signature matches.
  • the generated compound digital signature 3326 may then be compared in step 3323 against the endpoint and time stamp specific compound digital signature 3332 corresponding to that encryption engine 3340 which may have been originally provided to the endpoint device (for example, by a licensing authority as a part of the endpoint code licensing process at a prior point).
  • the data structure may be identical whether this token 3332 is a digital signature or a key, so the terms "key” and "digital signature” may possibly be used interchangeably in those cases.
  • the processor of the endpoint device may then be allowed to run the code contained in the decryption engine code block 3340 in secured execution mode.
  • the decryption engine 3340 may then make use of the endpoint device's hardware key 3370 to generate the global content-specific key from the device-specific compound key 3331 using decryption engines 3341 or 3342.
  • the global content-specific key may thus be an intermediate result and accordingly may never be cached or otherwise made visible to any software or hardware entities other than the compound decryption engine code block 3340.
  • This global content-specific key is then used, by way of decryption engine 3343 to generate the final decrypted content 3350 from the original encrypted content 331 1 .
  • the generated digital signature 3326 does not substantially match the supplied digital signature 3332, then there may be several possible reasons why the mismatch may have occurred, including the case where attempts to make use of decryption engine code block 3340 are made by unauthorized parties. However, another possible reason for a mismatch may be the case where the software for decryption engine has been updated (and the endpoint's timestamp register has likewise been incremented or otherwise changed). In this case, the two digital signatures may not match and it may be checked in step 3381 if the encryption engine code 3340 is either itself encrypted (for example) or otherwise in need of replacement.
  • the concept of adding a layer of encryption to a particular executable code block can be logically equivalent with the act of replacing an outdated version of a particular code block with a newer version of that code block. Accordingly, it can be determined if the decryption engine 3340 is itself either encrypted or otherwise in need of replacement (as indicated in step 1282), as indicated by examining one or more of the following tokens associated with that code block: the endpoint and timestamp specific compound digital signature 3332, the code block's decryption pointer (not shown) or the code block's decryption key pointer (also not shown).
  • the code block's 3340 associated decryption pointer points to a null value, it would indicate that the encryption engine 3340 is not encrypted or otherwise outdated and thus, an exception error may result (step 3383), since the generated digital signature 3326 and the supplied digital signature 3332 are not substantially identical but there may be no other recourse for replacing the code block with a different version that may possibly produce the correct digital signature. If, however, the decryption engine code block's 3340 decryption pointer points to another code block; either another (possibly updated) encryption engine (not shown) or some other code block, then this new code block may be loaded and the authentication steps above applied to this next encryption engine (in other words, another layer of recursion may be introduced).
  • This recursive execution mechanism may continue until it is determined that a match between an generated endpoint and time stamp specific compound digital signature 3326 and the supplied endpoint and time stamp specific compound digital signature 3332 occurs (at step 3327) or that it is determined that there is no match and the decryption engine 3340 itself is not encrypted, at which point an exception error may occur (step 3383).
  • each of these code blocks may not necessarily be encryption or decryption engines. In any case, each of these code blocks may be authenticated while the processor of the target endpoint device operates in secured execution mode.
  • an endpoint device may receive a message 3410 that may contain, among other things, encrypted content 3412 along with a content specific compound key 3416 (as discussed with respect to FIGURE 29), a pointer 3413 to an decryption engine data structure 3420 or the decryption engine itself, if it is embedded in the original message 3410 and a key list pointer 3414, that may point to a key or key list data structure 3418.
  • this data structure may include a key or key list 3416 or a digital signature 3417.
  • the decryption engine data structure 3420 may, in turn, contain an encrypted code block 3421 , a subsequent decryption pointer 3422 associated with the encrypted (or alternately, obsolete and in need of replacement) decryption code block 3421 and an associated decryption key list pointer 3423.
  • the subsequent decryption pointer 3422 may point to a final decryption code block data structure 3430, which has structure substantially similar to that of decryption code block data structure 3420, except that, in the case of data structure 3430, the decryption code block 3431 is not itself in encrypted form.
  • Encrypted Content data structure 3410 is loaded into the endpoint processor's memory space in anticipation of decrypting the encrypted content 3412 contained within. Since the data structure 3410 contains a decryption pointer 3413, the associated decryption engine code block data structure 3420 is located and read into memory. Since this subsequent data structure 3420 also contains a decryption pointer 3422the decryption engine code block data structure 3430 associated with pointer 3422 is then located and loaded into memory.
  • the embedded decryption pointer 3432 in this example is determined to be a null pointer, so the target endpoint device's security system is thus able to determine that the current decryption recursion chain has terminated (as discussed, for example, in FIGURE 31 ) and thus, the decryption engine 3431 that was just read into memory as a part of data structure 3430 may contain an unencrypted (and thus potentially executable) code block.
  • these key list data structures may themselves include references to further decryption or subsequent interpretation by incorporating supplementary decryption pointers and key list pointers within any or all of these key list data structures (3418, 3428 and 3438) themselves, although this particular option was not pictured in the embodiment of FIGURE 34 for the sake of simplicity.
  • At least one of the key pointers 3436 in the key list data structure 3438 corresponds to a reference to the endpoint's hardware secret key 3492.
  • This reference to the endpoint's hardware secret key 3492 may be accomplished either explicitly by pointing to an appropriately reserved memory location (a location that may be specified in the processor's architecture, even though it may never be directly read by the processor and thus, not directly architecturally visible) or implicitly, by using some specially reserved value for the pointer. In either case, this reference may implemented using various means, but an example one such embodiment may be to equate the value of "0" (as distinct from the value of "null") in the key list data structure to a reference to the endpoint's hardware secret key 3492.
  • the fact that at least one part of the key list data structure refers to the endpoint's hardware secret key 3492 may further indicate that the decryption engine code block 3431 is intended to run in secured execution mode on the target endpoint device's processor.
  • the output of hardware-based digital signature generator block 3490 is compared with the value stored in data structure 3437. In the case where the two values substantially match, then the processor is allowed to enter secured execution mode.
  • hardware-based digital signature generator block 3490 may, in one embodiment, comprise one or more software-based elements, but may also incorporate at least one hardware-based security component, either directly or indirectly, as discussed earlier. That hardware component is the hardware-based hashing function that has been referenced in many of the earlier descriptions contained herein, and which comprises the overall target endpoint unit's security system root of trust.
  • decryption engine code block 3431 is allowed to run in secured execution mode, which allows the endpoint processor to potentially make use of the endpoint's hardware device-specific secret key 3492 as a part of a security-related computation (as has been described earlier herein).
  • the value of secret key 3492 would not be available for use in such a security related computation.
  • FIGURE 34 depicted with respect to FIGURE 34 as hardware access control block 3443, which will only allow the value of secret key 3492 to pass through to subsequent use (for example in decryption engine code block 3431 ) if the processor is running in secured execution mode.
  • one of the input parameters to hardware access control block 3443 is the output of access control block 3441 .
  • the state of hardware access control block 3443 (which is effectively the "secured execution mode enabled” indicator for decryption code block 3421 ) is dependent on the fact that decryption code block 3431 was also running in secured execution mode. This may be indicated by the state of the "secured execution mode enabled" indicator for decryption code block 3431 (for example, the output of hardware access control block 3441 ).
  • This dependency constrains the ability of decryption engine code block 3421 to be able to run in secured execution mode only if decryption code block 3431 was also running in secured execution mode.
  • the output of hardware access control block 3443 is used as one of the inputs to hardware access control block 3445, which is the "secured execution mode enabled” indicator for decryption code block 341 1 .
  • the mechanism that allows the "secured execution mode enabled” bit to be propagated back up the calling chain in the reverse direction for the purposes of authorizing the preceding parent code blocks to run in secured execution mode only if they are both authenticated properly (as will be explained in more detail with respect to FIGURE 35) and if they are supplied with authentic decryption results from properly authorized portions of the security chain from lower down in the recursive calling chain.
  • any one of several conditions may cause any of the "secured execution mode enabled" bits to be reset to a "non-secured” default state (and thus, potentially require the entire security chain to be restarted).
  • Such conditions may include a processor interrupt or a subsequent digital signature comparison mismatch.
  • these hardware access control blocks 3441 , 3443 and 3445 are depicted as separate entities for purposes of clarity in FIGURE 34, it can be seen that they may, in fact, be embodied in a single hardware unit (such as that described with respect to FIGURE 36), whose output is thus fed back as one of its own input terms.
  • the output of the highest-level or final "secured execution mode enabled" bit in the overall chain may be used as part of a control mechanism to enable or disable some externally-visible output for the target device (such as an audio or video output enable, for example).
  • decryption engine code block 3431 in step 3470 is to replace or otherwise supplement the data set stored in the decryption engine code block portion 3421 of data structure 3420 with an updated and/or properly executable version of the original data. This action may be accomplished utilizing the original data that was stored in 3421 and decrypting it with one or more decryption keys that are stored in or pointed to by key list data structure 3428. Alternately, as was discussed earlier, the action 3470 of decryption engine code block 3431 may be to either replace the decryption code block 3421 with an updated version or even to execute directly in place of decryption engine code block 3421 .
  • decryption engine code block 3431 may first operate using various input data, including (in this embodiment) the value contained in the target endpoint device's timestamp register 3494, the target endpoint device's hardware-specific secret key 3492 (as modified by passage through hardware access control 3442) and endpoint and timestamp-specific compound digital key 3426.
  • decryption engine code block 3431 may then utilize a second set of input data (for example in this embodiment, the value contained in the target endpoint device's timestamp register 3494, the target endpoint device's hardware-specific secret key 3492 (as modified by passage through hardware access control 3444) and endpoint and timestamp-specific compound digital key 3416.
  • a second set of input data for example in this embodiment, the value contained in the target endpoint device's timestamp register 3494, the target endpoint device's hardware-specific secret key 3492 (as modified by passage through hardware access control 3444) and endpoint and timestamp-specific compound digital key 3416.
  • a further action of the updated decryption engine code block 3421 in step 3471 is to replace or otherwise interpret the original encrypted content data 3412 in order to produce the desired output data 3480.
  • This action may be accomplished utilizing the original data that was stored in 3412 and decrypting it with one or more decryption keys that are stored in or pointed to by key list data structure 3418. Since the actions of both decryption engine code blocks 3421 and 3431 are similar in nature, is should be evident that any of the options detailed earlier in the description of the operation of decryption engine code block 3431 are equally applicable to the operation of the updated version of decryption engine code block 3421 .
  • the associated hardware access control block 3444 is distinct from hardware access control block 3442.
  • the actions of these two hardware access control blocks 3442 and 3444 are similar in nature in that their purpose is to enable or disable the use of the target endpoint device's hardware-specific secret key 3492 by their associated decryption engines 3431 or 3421 respectively and thus in other embodiments may not be distinct.
  • the use of the target endpoint device's timestamp register 3494 is essentially similar to those examples described earlier herein for other embodiments. Thus, it follows that the value stored in register 3494 may be used as an additional element in the generation of the various compound keys and/or digital signatures that are employed in the different authorization and decryption operations described in the particular embodiment depicted in FIGURE 34.
  • FIGURE 35 depicts one embodiment of how a recursive calling chain may be traversed and terminated and how a processor may be allowed to enter into secured execution mode using a message-digest based authentication of one or more embedded code blocks.
  • the operation of two candidate code blocks 3512 and 3522 may be explained, both of which may be contained within universal cryptographic data structures (351 1 and 3521 respectively) as was discussed earlier with respect to FIGURE 28B.
  • code block data structure 3521 is represented twice in FIGURE 35. This duplication was illustrated to represent separate iterations for the sake of clarity, although it should be noted that this is exactly the same data structure in both instances.
  • key list data structures 3528 and 3538 that are pointed to by the instances of key list pointer 3521 .
  • the value of key list pointer 3521 does not vary between the two instances shown in this figure, the values contained within (or pointed to by) key list data structure 3528 may change between the two iterations, and so this detail is indicated by renumbering the data structure (and its various
  • a call to candidate code block 3512 may be initiated.
  • the code block data structure 351 1 may be read into memory and its message digest 3541 may be computed by means of hashing function 3580 (which may be realized either wholly or partially in hardware, as was described previously).
  • the hashing function may be given an initial seed value 3540 (which may, or may not, be set to all zeroes).
  • this hashing function seed value feature may be implemented using one of a number of methods, but in this embodiment the seed value 3540 is known and the method by which it affects the message digest output 3541 of hashing function block 3580 is both repeatable and deterministic.
  • code block 3512 may not be designed to run in secured execution mode and therefore does not require the use of any of the target endpoint unit's security hardware features.
  • the processor thus begins to execute the instructions contained within code block 3512 until it reaches an embedded subroutine call that points to code block 3522.
  • code block data structure 3521 is loaded into memory and the process of generating the next message digest 3542 is repeated by the hashing function block 3580.
  • the hashing function seed value may no longer be the initial seed value 3540, but rather the previously generated result 3541 .
  • the value of message digest 3542 can be seen to be deterministically dependent on the message digest of both code blocks 351 1 and 3521 .
  • the values of decryption pointer 3523 and those contained in the key list data structure 3528 pointed to by key list pointer 3524 may still be null, so the processor continues on in non-secured execution mode as before.
  • code block 3522 contains a recursive call (for example, a subroutine call to itself).
  • a recursive calling structure is illustrative only and correct operation of the target endpoint device's security system may be achieved by other means, for example, be ensuring that any calls to the security system are contained within a single layer of code.
  • the recursive calling form may be relatively more secure, as detailed earlier, and may be effectively utilized to implement a security system in conjunction with the depicted embodiment.
  • the code block data structure 3521 is once again loaded into memory (for example, in most contemporary systems, the data structure 3521 may be loaded to a different physical location the second time it is fetched) and the hashing function 3580 calculates the new message digest 3543. Notice that this new message digest 3543 is - i dependent on the initial message digest seed value 3540, message digest 3541 (of code block 3512) as well as the message digest of two separate iterations of code block 3522.
  • the key list pointer points to a new data structure 3538, that contains a non-null digital signature value 3537.
  • This non-null value is an indicator to the security system that this iteration of code block 3522 contains a reference to the target endpoint hardware specific security system.
  • the processor in order for such a reference to operate properly, the processor must enter secured execution mode at some point.
  • the digital signature 3543 generated when code block data structure 3521 was most recently loaded into memory may then be compared to the digital signature 3537 contained within key list data structure 3538. In the case where the two values are found to be substantively similar in step 3591 , then the target endpoint processor is allowed to enter secured execution mode.
  • step 3592 is to direct the processor to execute the appropriate exception error handler portion 3570 of the security system.
  • FIGURE 36 depicts one embodiment of how a digital signature generator block 3660 may be implemented in hardware in order to support the features detailed above.
  • the embodiment depicted in FIGURE 36 shows a hardware implementation of functionality similar to the functionality of the digital signature generator block depicted in FIGURE 31 and which will support the functional features that were described in operational detail, for example, with respect to FIGURES 32, 33, 34 and 35.
  • the hashing function seed register 3610 may comprise a similar functionality as that labeled as block 3540 of FIGURE 35 and it may be operable to hold the initial value that is fed to hashing function block 3661 .
  • the output of hashing function block 3661 is fed as one of the inputs to the first stage 3662 of a compound encryption engine.
  • the other input to encryption engine 3662 is the output of the target endpoint device's timestamp register 3641 .
  • the resulting output of the first stage encryption engine 3662 is then supplied as one of the inputs to the second stage encryption engine 3663.
  • the other input to second stage encryption engine 3663 is the output of secured execution mode access point 3666.
  • Access point 3666 is operable to pass through the value of the target endpoint's hardware specific secret key 3640 only when the target endpoint device is either running in secured execution mode or when the "recursion terminated" condition is detected, as was detailed earlier with respect to FIGURE 35.
  • the resulting output value from second stage encryption engine 3663 is then stored in digital signature register 3664, for use in comparing this generated digital signature with the digital signatures that are supplied with the candidate code blocks (as referenced, for example, in the descriptions of FIGURES 30, 31 , 32, 33, 34 and 35).
  • the output of digital signature register 3664 is gated by access point 3665, whose action is to pass through the value of digital signature register 3664 when the target endpoint device is not running in secured execution mode.
  • the output of access point 3665 is then fed back to the input of the hashing function seed register 3610 in order to create the cascaded message digest feature that was detailed in the description with respect to FIGURE 35.
  • the input to the hashing function seed register 3610 is not dependent on the value of digital signature register 3664 and can thus either be set to some initial value (as detailed in the description with respect to FIGURE 35) or by some other means (for example, such as a processor write to a specific memory location).
  • Embodiments described herein can be implemented in the form of control logic in software or hardware or a combination of both.
  • the control logic may be stored in an information storage medium, such as a computer-readable medium, as a plurality of instructions adapted to direct an information processing device to perform a set of steps disclosed in the various embodiments.
  • an information storage medium such as a computer-readable medium
  • a person of ordinary skill in the art will appreciate other ways and/or methods to implement the invention.
  • communication or transfer (or otherwise moving from one place to another) of data may be wired, wireless, or by any other means.
  • a "computer-readable medium” may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, system or device.
  • the computer readable medium can be, by way of example, only but not by limitation, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, system, device, propagation medium, or computer memory.
  • Such computer-readable medium shall generally be machine readable and include software programming or code that can be human readable (e.g., source code) or machine readable (e.g., object code).
  • a "processor” includes any, hardware system , mechanism or component that processes data, signals or other information.
  • a processor can include a system with a general-purpose central processing unit, multiple processing units, dedicated circuitry for achieving functionality, or other systems. Processing need not be limited to a geographic location, or have temporal limitations. For example, a processor can perform its functions in "real-time,” “offline,” in a “batch mode,” etc. Portions of processing can be performed at different times and at different locations, by different (or the same) processing systems.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Power Engineering (AREA)
  • Computing Systems (AREA)
  • Storage Device Security (AREA)

Abstract

Embodiments of systems and methods disclosed herein may isolate the working set of a process such that the data of the working set is inaccessible to other processes, even after the original process terminates. More specifically, in certain embodiments, the working set of an executing process may be stored in cache and for any of those cache lines that are written to while in secure mode those cache lines may be associated with a secure descriptor for the currently executing process. The secure descriptor may uniquely specify those cache lines as belonging to the executing secure process such that access to those cache lines can be restricted to only that process.

Description

METHOD AND SYSTEM FOR PROCESS WORKING SET ISOLATION
RELATED APPLICATIONS This application claims a benefit of priority under 35 U.S.C. § 1 19 to United States
Provisional Patent Application No. 61 /613,290 entitled "Method and System for Process Working Set Isolation" by William V. Oxford filed March 20, 2012, which is hereby fully incorporated by reference in its entirety.
TECHNICAL FIELD This disclosure relates in general to security in computer systems. More specifically, this disclosure relates to securing data (including instructions) associated with processes of a computing system. Even more particularly, this disclosure related to securing data associated with processes of a computing system that are executing in conjunction with an implementation of a recursive security protocol.
BACKGROUND
[0003] Computer viruses and other malicious software present a massive problem for the
information technology industry. Since a general purpose computer can, by definition, run arbitrary code, it can be very difficult to maintain control over exactly which software is allowed to run, either in part or in whole, on a given general purpose computer platform. For this reason, it can be difficult to prevent the execution of malware or other types of undesirable software. There are a number of methods by which this level of control is currently attempted, but most efforts to isolate the processor from attack suffer from two fundamental problems: loss of generality in the processor platform or loss of performance. These losses stem from the basic issue of how to isolate data that must be kept secure from data that can be published freely and how to quickly and unequivocally distinguish between authorized and unauthorized usage modes.
[0004] A secondary, but related problem is that of copyright control. The vast majority of written, audio and visual works of art that are created today either begin or end up in digital format. One of the characteristics of digital data is that it can easily be substantially exactly duplicated. This property facilitates a wide variety of inexpensive distribution mechanisms, most of which are not easily controlled. The inherent inability to limit the distribution of digital content has had far-reaching implications on the field of copyright law over the last couple of decades. While certain systems and methods have been developed to control the copying and distribution of such duplicated data, one problem with these systems and methods is that they may be circumvented through the execution of certain types of software in conjunction with these systems and methods, for example, code which modifies the systems and methods, or obtains data utilized by such systems and methods in an unauthorized or unintended manner.
[0005] In particular, certain techniques may be utilized to obtain data accessed (e.g., read or
written) by such security systems executing on a computer. This data may then be utilized in attempts to circumvent such security systems and thus circumvent the control over the copying and distribution of digital data.
[0006] Accordingly, there is a need to find systems and methods by which the data of such security systems may likewise be secured, where by securing such data the effectiveness of such a security system may be enhanced. SUMMARY
[0007] Embodiments of systems and methods for the isolation of the working set of a process
executing in a secure mode are disclosed. When embodiments of these systems and methods are utilized an unencumbered generality as well as a level of protection against attack that surpasses many other security systems may be obtained.
[0008] In particular, in one embodiment, systems and methods for preventing direct access to data that is used in a particular computation, while nonetheless still allowing the use of that data. In another embodiment, access to data that is used by one software process can be denied to any other software process. Embodiments of these systems and methods for data access control can be used in a large number of potential application areas, including the areas of security which may encompass, but are not limited to, the following: digital security, copyright control, conditional access, protection against undesirable computer viruses, etc. Specifically, embodiments may be utilized in conjunction with a recursive security protocol to augment such a security protocol.
[0009] Additionally, embodiments of systems are presented which embody these types of
methodologies in computer systems, hardware, and software. It should be noted that the exact same hardware implementation could potentially be used to implement any one or combination of the entire range of solutions, depending on the requirements of the software.
[0010] Moreover, embodiments present a simple and easily understood security protocol, made up of three intersecting technology components working together in a unique cooperative framework. The simplicity of the individual components, the complete architectural independence and their low implementation overhead make this system suitable for a wide variety of architectures and deployment scenarios. Embodiments can thus be deployed in simple, low power systems as well as sophisticated, complex high-throughput designs with minimal changes to any pre-existing software.
[001 1 ] If implemented as described in embodiments, embodiments of such an approach can be shown to possess "Zero-Knowledge" aspects and thus can be provably secure in the face of well-known attack strategies, such as an Adaptive Chosen-Ciphertext attack. By making the system's Secret Keys architecturally invisible (both directly as well as indirectly) and the by its ability to efficiently and definitively isolate the working set of any secure process from any other process, a correctly implemented Recursive Security system can be shown to be impervious to Replay Attacks and offer an immunity to Return-Oriented Programming exploits that cannot be matched by competing solutions. [0012] Embodiments of a recursive security protocol can also be useful in the fight against malware of all kinds. Due to its "Permission Required to Execute" approach as opposed to the more traditional "Permission to Execute Denied" method (commonly known as a "White-Listing" versus a "Black Listing" scheme) the Recursive Security protocol can be used to prevent unauthorized and/or modified software executables from running on a system of any architecture.
[0013] In one embodiment, a process may be executing on a processor in a secure mode and data stored in a line of a cache, wherein the data was stored by the process executed on the processor in the secure mode. Access to such lines of cache may be controlled using a secure descriptor associated with the process such that only the process can access the line of the cache, wherein the secure descriptor is based on a secret key stored in the hardware of the system comprising the processor and the cache. According to some embodiments then, access may be controlled even after the process has terminated.
[0014] In some embodiments, the secure mode was entered based on the secure descriptor, an entire working set of the process is stored in the cache and writes to a memory location other than the cache are disabled in the secure mode. Furthermore, the line of the cache may be associated with the secure descriptor associated with the process or a security flag associated with the line of the cache may be set when the process writes the data.
[0015] In another embodiment, controlling access to a line of cache may include determining that the line of cache is being accessed by a currently executing process, determining if a currently executing process is executing in secure mode, determining a secure descriptor associated with the currently executing process, comparing the secure descriptor and with the secure descriptor associated with the line and allowing access only if the currently executing process is executing in secure mode and the secure descriptors match.
[0016] These, and other, aspects of the invention will be better appreciated and understood when considered in conjunction with the following description and the accompanying drawings. It should be understood, however, that the following description, while indicating various embodiments of the invention and numerous specific details thereof, is given by way of illustration and not of limitation. Many substitutions, modifications, additions and/or rearrangements may be made within the scope of the invention without departing from the spirit thereof, and the invention includes all such substitutions, modifications, additions and/or rearrangements. BRIEF DESCRIPTION OF THE DRAWINGS
[0017] The drawings accompanying and forming part of this specification are included to depict certain aspects of the invention. A clearer conception of the invention, and of the components and operation of systems provided with the invention, will become more readily apparent by referring to the exemplary, and therefore nonlimiting, embodiments illustrated in the drawings, wherein identical reference numerals designate the same components. The invention may be better understood by reference to one or more of these drawings in combination with the description presented herein. It should be noted that the features illustrated in the drawings are not necessarily drawn to scale.
[0018] FIGURE 1 depicts one embodiment of an architecture for content distribution.
[0019] FIGURE 2 depicts one embodiment of a target device.
[0020] FIGURE 3 depicts one embodiment of a secure execution controller.
[0021 ] FIGURES 4A and 4B depict an embodiment of a cache used for process working set
isolation.
[0022] FIGURE 5 depicts an embodiment of secured code block execution.
[0023] FIGURE 6 depicts an embodiment of secured code block execution.
[0024] FIGURE 7 depicts an embodiment of secured code block execution.
[0025] FIGURES 8-14 depicts an embodiment of process working set isolation.
[0026] FIGURE 15 depicts an embodiment of compound key generation.
[0027] FIGURE 16 depicts an embodiment of compound key generation.
[0028] FIGURE 17 depicts an embodiment of compound key generation.
[0029] FIGURE 18 is a representation of an embodiment of a decryption key data structure.
[0030] FIGURE 19 is a diagram for an embodiment of the encryption and distribution process of a security protocol.
[0031 ] FIGURE 20 is a diagram of the decryption and loading process for an embodiment of a security protocol.
[0032] FIGURE 21 is a diagram of one embodiment of the encryption/decryption process of a security protocol. [0033] FIGURE 22 is a representation of an embodiment of a key list data structure.
[0034] FIGURE 23 is a diagram of an embodiment of the temporary key ownership transfer
procedure.
[0035] FIGURE 24 depicts one embodiment of the creation of a compound key.
[0036] FIGURES 25A and 25B depict embodiments of the creation of digital signatures or their equivalents.
[0037] FIGURES 26A and 26B depict embodiments of the use of a compound key structure with a secured code block.
[0038] FIGURE 27 depicts one embodiment of the use of a compound message digest.
[0039] FIGURE 28A, 28B and 28C depict embodiments of a secured code block message.
[0040] FIGURE 29 depicts an embodiment of a decryption operation.
[0041 ] FIGURE 30 depicts one embodiment of the use of a compound key.
[0042] FIGURE 31 depicts one embodiment of the use of a compound key in the authorization of a candidate code block.
[0043] FIGURE 32 depicts one embodiment of a decryption operation.
[0044] FIGURE 33 depicts one embodiment of the validation of a code block.
[0045] FIGURE 34 depicts one embodiment of a decryption operation performed using a recursive security protocol.
[0046] FIGURE 35 depicts one embodiment of the operation of code validation. [0047] FIGURE 36 depicts one embodiment of a digital signature function block.
DETAILED DESCRIPTION
[0048] The invention and the various features and advantageous details thereof are explained more fully with reference to the nonlimiting embodiments that are illustrated in the accompanying drawings and detailed in the following description. Descriptions of well-known starting materials, processing techniques, components and equipment are omitted so as not to unnecessarily obscure the invention in detail. It should be understood, however, that the detailed description and the specific examples, while indicating preferred embodiments of the invention, are given by way of illustration only and not by way of limitation. Various substitutions, modifications, additions and/or rearrangements within the spirit and/or scope of the underlying inventive concept will become apparent to those skilled in the art from this disclosure. Embodiments discussed herein can be implemented in suitable computer- executable instructions that may reside on a computer readable medium (e.g., a hard disk (HD)), hardware circuitry or the like, or any combination.
[0049] As used herein, the terms "comprises," "comprising," "includes," "including," "has," "having" or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, article, or apparatus. Further, unless expressly stated to the contrary, "or" refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
[0050] Additionally, any examples or illustrations given herein are not to be regarded in any way as restrictions on, limits to, or express definitions of, any term or terms with which they are utilized. Instead, these examples or illustrations are to be regarded as being described with respect to one particular embodiment and as illustrative only. For example, though embodiments as described herein have been described in conjunction with their
implementation in the context of a recursive security system, it will be noted that other embodiments may be usefully applied in other contexts to secure process working sets.
[0051 ] Those of ordinary skill in the art will appreciate that any term or terms with which these
examples or illustrations are utilized will encompass other embodiments which may or may not be given therewith or elsewhere in the specification and all such embodiments are intended to be included within the scope of that term or terms. Language designating such nonlimiting examples and illustrations includes, but is not limited to: "for example," "for instance," "e.g.," "in one embodiment." [0052] Embodiments of the present invention can be implemented in a computer communicatively coupled to a network (for example, the Internet, an intranet, an internet, a WAN, a LAN, a SAN, etc.), another computer, or in a standalone computer. As is known to those skilled in the art, the computer can include a central processing unit ("CPU") or processor, at least one read-only memory ("ROM"), at least one random access memory ("RAM"), at least one hard drive ("HD"), and one or more input/output ("I/O") device(s). The I/O devices can include a keyboard, monitor, printer, electronic pointing device (for example, mouse, trackball, stylist, etc.), or the like. In embodiments, the computer has access to at least one database over the network.
[0053] ROM, RAM, and HD are computer memories for storing computer-executable instructions executable by the CPU or capable of being complied or interpreted to be executable by the CPU. Within this disclosure, the term "computer readable medium" is not limited to ROM, RAM, and HD and can include any type of data storage medium that can be read by a processor. For example, a computer-readable medium may refer to a data cartridge, a data backup magnetic tape, a floppy diskette, a flash memory drive, an optical data storage drive, a CD-ROM, ROM, RAM, HD, or the like. The processes described herein may be implemented in suitable computer-executable instructions that may reside on a computer readable medium (for example, a disk, CD-ROM, a memory, etc.). Alternatively, the computer-executable instructions may be stored as software code components on a DASD array, magnetic tape, floppy diskette, optical storage device, or other appropriate computer- readable medium or storage device.
[0054] In one exemplary embodiment of the invention, the computer-executable instructions may be lines of C++, Java, JavaScript, or any other programming or scripting code. In an embodiment, HTML may utilize JavaScript to provide a means of automation and calculation through coding. Other software/hardware/network architectures may be used. For example, the functions of the present invention may be implemented on one computer or shared among two or more computers. In one embodiment, the functions of the present invention may be distributed in the network. Communications between computers implementing embodiments of the invention can be accomplished using any electronic, optical, radio frequency signals, or other suitable methods and tools of communication in compliance with known network protocols. In another embodiment, this communication between systems may be effected by using a printed medium, where a user can provide the communicated data to a target "endpoint" system by entering it manually.
[0055] Additionally, the functions of the disclosed embodiments may be implemented on one
computer or shared/distributed among two or more computers in or across a network. Communications between computers implementing embodiments can be accomplished using any electronic, optical, radio frequency signals, or other suitable methods and tools of communication in compliance with known network protocols. It will be understood for purposes of this disclosure that a module is one or more computer processes, computing devices or both, configured to perform one or more functions. A module may present one or more interfaces which can be utilized to access these functions. Such interfaces include APIs, web services interfaces presented for a web services, remote procedure calls, remote method invocation, etc.
[0056] As discussed above, digital distribution has completely and irrevocably changed the media business, with mixed consequences. Like any technological advance, the transition to digital formats enabled a wealth of new opportunities for the creative arts. In the process, however, this transformation challenged long-held notions of how best to distribute and monetize artistic assets.
[0057] One particular problem has to do with the ease of copying digital data. Forgeries have been a problem for as long as original art has existed, yet creating a convincing copy has historically required a talented artisan (i.e., an expert forger). The digital revolution changed the rules in two remarkable aspects. First, copies of a digital work can be exact duplicates - indistinguishable from "originals". Thus, there may be no practical way to differentiate between "authentic" and "illegitimate" copies of a digital work. The second change is that exact duplicate copies can be created virtually at will by anyone, at vanishingly low cost.
[0058] These two aspects produce unprecedented opportunity for distributing genuine as well as illicit copies of digital works. Historically, the value of works has been closely, if not inextricably, tied to physical objects. In the digital world, however, the ability to globally deliver a work with negligible cost per copy has changed the dynamic, both for copyright holders and those who would profit from the unauthorized distribution of the works.
[0059] Enter Digital Rights Management (DRM). One goal of a successful DRM system is to
prevent dissemination of copies of digital works in an "unlicensed" manner. This strategy matches the historical linkage between a physical object and a work. In the digital age, this strategy is flawed for many reasons yet this "copy control" approach remains the premise upon which the vast majority of DRM systems are built.
[0060] In the case of digital data distribution, copying the "controlled" data happens when it is
distributed. The data that originates at the distribution point may go through quite a few intermediaries before it ends up at its intended playback device(s). Each intermediate device could potentially make an exact duplicate copy of the entire data stream as it passes through. Thus, attempts to limit "copying" globally distributed digital data may be essentially meaningless. In many cases, distributed digital data can always be copied.
[0061 ] However, an encrypted version of digital data typically bears little resemblance to the
original. The ability to decrypt the data may be mediated by a single (usually global) key that according to embodiments remains secret.
[0062] In effect, possessing the global key is the equivalent of possessing the copyrighted work.
Thus, if the encryption process is performed correctly, theoretically nothing should prevent free distribution of any number of copies of the encrypted version of any given copyrighted work. In fact, the relevant problem becomes control of the decryption process itself, (and of the global encryption key), rather than copy prevention.
[0063] In this way, we can distill the problem of digital distribution down to one of control over the secret key rather than control over the (typically much larger) encrypted data set. It should be noted that, as a given data set grows in size, the more difficult it is to hide, or at least to maintain control over. Of course, as the size of the secret key decreases, then the easier it is to guess the value of that key. Thus, the correct tradeoff for a successful security system is to optimize the size of the secret key such that it is as small as possible, and yet it is not so small that it is easily guessed.
[0064] Another concern is that of whether or not to globally encrypt a distributed data set (which can then be freely shared, as we discussed earlier) or to distribute multiple individual encrypted copies of this same data set, where each of the designated authorized recipients is given an individually encrypted copy. Aside from the obvious inefficiency of such a scheme, it is in most cases actually a less secure strategy than to perform a single "global" encryption (with an associated "global" encryption key) and to just distribute the singly (and globally) encrypted data set. This is due to the fact that the encrypted data sets will all have a common plaintext source, with common statistics that can be analyzed in order to provide a wealth of additional information regarding the value of the secret keys used in the encryption process. So the correct strategy in most cases is to perform a single encryption (with a single global secret key) and to distribute only the globally encrypted data set.
[0065] Assume for the moment that it was managed to successfully and securely transmit an
"authorized" copy of a global secret key to a legitimate customer. The issue then becomes one of how to keep that customer from sharing this same global key with other, potentially unauthorized entities. Thus, it may be desired to define some way of managing the authorized global decryption keys even after they are in the possession of legitimate owners of these keys. Furthermore, once the global key has been used to decrypt a legitimate copy of the encrypted data set, one may also consider the problem of how to keep the authorized owner of a decrypted data set from re-distributing that decrypted data set to others in an unauthorized manner.
[0066] Thus, is desired that the security "envelope" should extend the boundaries of the control mechanism beyond just the decryption process. If even one correctly decrypted, but otherwise "uncontrolled" digital copy is created, that uncontrolled copy can be digitally duplicated without limit. Once the "digital genie" is freed, it can never be put back into the bottle. Thus, to truly control data (copyrighted or otherwise), entities that correctly decrypt encrypted data should be kept from redistributing decrypted versions. It is thus desirable to control both decryption as well as any potential re-distribution in order to achieve the goal of effective control of digital data (e.g., copyrighted data). Notably, in the case where the decryption of a data set and the display of that same data set do not occur in the same device, then there may be a need to protect the transmission link between the decryption device and the display device, since this transmission effectively amounts to a redistribution process. In this case, then, the transmission link should exhibit the same robustness against external observers and interference as the primary means of distribution. Otherwise, prospective attackers may simply target the weaker link.
[0067] Certain very effective techniques for effectively maintaining control of data have been
developed, including those U.S. Patent 7,203,844, entitled "Recursive Security Protocol System and Method for Digital Copyright Control," issued April 10, 2007, U.S. Patent No. 7,457,968, entitled "Method and System for a Recursive Security Protocol for Digital Copyright Control," issued November 25, 2008, U.S. Patent No. 7,747,876, entitled "Method and System for a Recursive Security Protocol for Digital Copyright Control," issued June 29, 2010, U.S. Patent Application No. 12/615,843, entitled "Method and System for Control of Code execution on a General Purpose Computing Device and Control of Code Execution in an Recursive Security Protocol," filed November 10, 2009, U.S. Patent Application No. 12/788,516, entitled "Method and System for a Recursive Security Protocol for Digital Copyright Control," filed May 27, 2010, and U.S. Patent Application No. 13/745,236, entitled "Method and System for a Recursive Security Protocol for Digital Copyright Control," filed January 18, 2013, the subject matter of which is described with respect to FIGURES 18-36 of this application. These techniques may be effectively used to maintain control over virtually any type of data in conjunction with, for example, DRM, copyright protection or other types of control.
[0068] From a review of the above applications and patents, it can be realized that embodiments of such techniques may utilize compound encryption to encode digital data. In one embodiment of compound encryption, no single key (e.g., a global key) can correctly decode an encoded data set by itself. Each key must be combined with at least one other key to construct a compound key. For convenience, the original individual keys of which a compound key is comprised are referred to as precursor keys. Although any compound key may be constructed by combining at least two precursor keys it can be seen that, given a minimally bipartite compound key, a single compound key may in fact be based on any number of precursor keys. We will discuss how this is accomplished below.
[0069] It should be noted that, in one embodiment, if at least one of the precursor keys in this entire chain is considered as "secret, then any of the other precursor keys may then potentially be public data, and may thus either be published or not, depending on the needs and architecture of the overall security system. It can be shown that, as long as there is at least one secret precursor key in a given compound key's chain of construction, then the overall security of the compound-key based system can essentially be conditioned on the security of that single secret precursor key.
[0070] There are multiple methods to create a compound key, but two such mechanisms are given by way of example: one-way and reversible. Examples of the first method is shown in FIGURE 15. In the one-way method, a compound key may be generated by a secure oneway hash function. In this example, a compound key can be generated by concatenating at least two precursor keys and passing the resultant concatenated data set through a one-way hash function. The one-way property of the hash function makes this kind of transformation irreversible. That means there is no practical way to recreate the value of any of the precursor keys from the resulting compound key. A second attribute of a one-way hash function is that it may include a built-in data compression function. Thus, no matter how long the input data set (e.g., the precursor keys may be of any arbitrary length), the resulting output (the compound key) will have a fixed length.
[0071 ] Recalling the discussion earlier that a compound key may have more than two precursors, it can thus be shown that generate a single compound key can be generated with an arbitrarily large set of precursor key input data. This can be accomplished by a "cascading" or
"chaining" process, where a first compound key is constructed and then this first compound key is used as one of the precursor keys to a second compound key.
[0072] Since the output of such a one-way compound key generation process may be of fixed
length, this property can be taken advantage of in a number of ways. First, the one-way compound key procedure can be generalized such that none of the precursor key inputs must be of a fixed length. However, in the case where the assumption is made that one of the precursor keys (for example, the secret precursor key) is of a fixed length, then one can further assign that fixed length precursor key to carry the secret key value (upon which the overall security of the system depends).
[0073] Thus, according to embodiments one can ensure the overall security of a system consisting of an arbitrarily large set of input data (e.g., precursors) simply and efficiently using a single, relatively small, fixed length register that can implemented by, for example, a simple one time-programmable register structure. As was stated earlier, this is effectively the goal of a successful security system; that of condensing the requisite secret knowledge down to a minimum size; as long as that minimum size is sufficiently large to prevent it from being easily guessed.
[0074] It should be noted that, even in the case where the secret precursor key is fixed to a
relatively small (and easily implemented) 128-bit, 256-bit, 512-bit, etc. value, for example, the time taken, on average, to correctly guess such a secret key will nonetheless still be quite long.
[0075] In some cases, however, it is desirable to be able to "reverse" the compound key in order to regenerate a precursor key value. In that situation, we can use a slightly different mechanism in order to create a "reversible compound key". One example of how we might construct such a reversible compound key is shown in FIGURE 16. Of course, it should be realized there are a number of methods by which this could be accomplished, and the example shown in FIGURE 16 is simply one such example. The common feature of such a structure, however, may be that there are at least two "precursor" inputs. Here, these are shown as the plaintext 1610 and the key 1620, which correspond to the two precursors (e.g., the secret key precursor and the public key precursor) of the one-way compound key structure that we discussed earlier. Thus, as with the one-way compound key, the reversible compound key may be created using at least two precursors. Also, as discussed, the construction can be generalized into a "cascaded" or "chained" compound key structure, where a final compound structure is dependent on any number of precursor inputs. One example of how to create such a "cascaded" reversible compound key is also shown in FIGURE 16.
[0076] Also as before, if the key precursor is kept secret, then there is no practical way to guess either of the precursors' original values from the resultant output, nor is there a practical means to correctly predict the value of the encrypted output, even if the non-secret precursor (e.g., in the example shown in FIGURE 16, plaintext 1610) input is known. Thus once again, the overall security is conditioned on the ability of the system to keep only the secret key value under control. [0077] Using a reversible method to create the compound key, the original value of a first precursor can be reconstructed by running through the symmetric encryption function again. Note that this reversal process is only possible as long as the encryption function may access the same precursor used to create the second compound key in the first place.
[0078] An interesting aspect of the compound encryption is that any numeric value can be a
precursor. This flexibility allows a recursive security system to produce single compound key values that correspond to very complex logical structures (and are therefore dependent on an arbitrarily large number of diverse components) in a simple and remarkably efficient manner. In all cases, however, the value of any a key in a given cryptographic structure is provably secure against discovery (assuming the intractability of the underlying
cryptographic function) from the resulting compound key alone.
[0079] In addition to the symmetric encryption as discussed, one could also construct a reversible compound key using an asymmetric encryption mechanism. In that case, the reversible compound key may then be used as a digital signature resulting from the "seeding" of the hash function with the secret precursor key and one of a public - private key set. Such a construction could then be used for signing digital documents in a secure manner on a given platform. In other words, one could only generate a correctly verifiable digital signature while using a specific computer platform or while in a specific geographic location -or some combination of any input parameter that may be represented in digital form.
[0080] Accordingly, in embodiments of hardware devices (e.g., target devices) that implement recursive security at least one of the precursors for any compound key operation that executes on that system should be securely stored on the actual device. Thus, according to some embodiments one precursor for compound key operation may be a secret key stored in the hardware of the target device. Such a hardware secret key may, in many cases, serve as a part of the root of a "Chain of Trust" of such a recursive security system. In other embodiments, other aspects of the system could also be a part in this hardware "Chain of Trust". Such aspects could include the secure one-way hash function, a one-time- programmable serial number register (which could be architecturally visible) or even some parametric property of the silicon die itself, such as a threshold voltage versus temperature curve or some value that is only observable when the chip in question is put into Scan / Test mode, for example. Using this mechanism, a particular chip could be distinctly and individually differentiated from an otherwise functionally identical device.
[0081 ] As is described in the above referenced patents and applications, and as will also be
described herein, such a secret key may only be accessible when a processor of a target device is operating in a secure execution mode (also referred to as secured mode). Thus, a process executing in secure mode on such a target device may have access to the secret key and may generate data based on this secret key.
[0082] In such a system, in certain embodiments it may potentially be desirable to further isolate the secret key in such a way that its value cannot be exposed, even unintentionally, even though its value may be used in an unspecified calculation. One such means of accomplishing this goal is to use the output of a one-way secure hash function on the secret key and some other datum instead of using the secret key value directly in the unspecified calculation reference earlier. If the one-way function is chosen correctly, then the output of the unspecified calculation is completely deterministic but nonetheless not practically predictable without prior knowledge of the value of the secret key. Thus, a system could be constructed that would make use of a secret key, but nonetheless be unable to expose its value computationally.
[0083] However, in some calculations, it may be desirable to use a secret key (or some derivative thereof) in a calculation that may potentially expose some other secret; either if the calculation's operation is halted prior to completion or if some intermediate result of such calculation is exposed to an outside observer. As such, in addition to controlling the execution of code on such a target device in order to maintain the security it may also be desirable to isolate the working set (e.g., the data read or written from memory such as cache, main memory, registers, etc.) of any processes executing in secure mode on the target device. More specifically, for example, if such a security system is separable from the target device itself, and intermediate results observable during a decryption process, then such a security system may be vulnerable to man in the middle attacks and differential cryptanalysis. This is due to the fact that the partial result of an otherwise invalid operation may provide a window into what would be an otherwise opaque "black-box" based system. In other words, working backwards from a working set of a process, it may be possible to discover a derivative value of the secret key that is being used by the secure process and thus compromising the chain of trust of the security system.
[0084] Thus, there is a need for methods and systems which may control the access to working set of a process on a target device and in particular that data read or written during the operation of a process executing in secure mode remain unreadable by any other code segment, either while the code segment is in the process of running or even after the original code segment has terminated. In particular, it may be desired to unambiguously isolate data that belongs to one instance of a process from any other process.
[0085] To that end, attention is now directed to embodiments of systems and methods for process working set isolation. Generally, embodiments of such systems and methods may isolate the working set of a process executing in secure mode such that the data is inaccessible to any other process, even after the original process terminates. More specifically, in one embodiment, the entire working set of a currently executing process may be stored in cache (e.g., an on-chip cache) and off-chip writes and write-through of that cache disallowed when executing in secured mode. Additionally, for any of those cache lines that are written to while in secure mode (e.g., a "dirty" cache line) those cache lines may be associated with a secure descriptor for the currently executing process. The secure descriptor may uniquely specify those associated "dirty" cache lines as belonging to the executing secure process, such that access to those cache lines can be restricted to only that process.
[0086] In one embodiment, to ensure that the secure descriptor is sufficiently unique to not only distinguish between different processes (including different instantiations of the same code segment that are called at different times), the secure descriptor may be a compound key. A compound key may be produced for use as a secure process descriptor using the target device's secret key. As discussed above a compound key may be produced without comprising the target device's secret key. As, in certain embodiments a dedicated hash functional block is provided in the target device, the output of such a hash block (or a secure execution controller comprising the hash block) may be used to create these secure process descriptors using the secret key of the target device.
[0087] Furthermore, in certain embodiments the output of this hash function may be used to
compare such a generated secure process descriptors (which may be generated automatically) with an architecturally-visible secure process descriptor in order to determine whether or not there is a match between the values without exposing the actual value of the generated secure process descriptor to an external attacker.
[0088] Also, additional values may also be used in conjunction with the target device's secret key in the evaluation of the one-way hash function in order to produce this secure descriptor. Such additional values may or may not be visible to the processor without compromising the value of the secret key. Some examples of these additional values might include a timestamp, a process ID, the previously-calculated result of the hash function or any other attribute that can be represented in digital form.
[0089] In addition, in certain embodiments, the size of these additional values can be completely arbitrary. In a system where the one-way hash function has a built-in compression attribute, then the resulting output of the hash function will be of fixed length, thus allowing the result of an arbitrarily large number of iterations through the hash function to remain fixed in size, no matter how many hash function iterations are employed. In this manner, the secure process descriptor may include information regarding the time of execution of the secure process, as well as the entire calling chain of the secure process in question. Thus, any one secure process may be efficiently and effectively isolated from any other secure process, even if the two processes are exactly the same, but simply called at different times or by different "parent" processes, for example.
[0090] In certain embodiments, in the event that the working set for a secure process overflows the on-chip cache, and portions of that cache that include those dirty lines associated with the secure process descriptor need to be written to main memory (e.g., a page swap or page out operation) external data transactions between the processor and the bus (e.g., an external memory bus) may be encrypted. The key for such an encryption may be the secure descriptor itself or some derivative value thereof, for example, the output of the hash function with the secure process descriptor and the secret key.
[0091 ] Another possibility for such an encryption key might be an encrypted version of the secure process descriptor. The encryption key used in this latter case may be the output of the hash function of the secret key concatenated with the current secure process descriptor and some other value. This latter value could then be published (e.g., written out to memory in the clear). In that case, then only the secure process that actually generated the data that was encrypted and then subsequently written out to memory in the first place could regenerate the correct decryption key and thus, restore the original data as it is read from memory back into the data cache. This is one means by which a secure process may be able to be interrupted (and have its working set swapped out of the data cache) and then resumed later in a secure manner.
[0092] A derivative of this same scheme may be used in order to pass data securely from one
secure process to another process, even if the two processes have different secure process descriptors. In that case, then there are at least two options; read-only access for the recipient secure process to the shared data or read-write access to the shared data. In either case, the two processes should communicate a shared secret decryption key between one and the each other. In the case where the shared secret decryption key is generated by a reversible compound key process, then the shared data may be writeable by the secure process that is the recipient of the shared data. In the case where the shared key is based on a one-way compound key mechanism, then the shared data may be limited to read-only access for the recipient.
[0093] To enhance performance, in certain cases where a secure process may have a large
working set or is frequently interrupted (e.g., entailing many page swaps) a subset of the processes working set that is considered "secure" may be created (e.g., only a subset of the dirty cache lines for the process may be associated with the secure descriptor) and only encrypt those cache lines or the portion of the cache containing those lines, when it is written out to external memory.
[0094] Additionally, to enhance performance, an off-chip storage mechanism (e.g., a page
swapping module) can be run asynchronously in parallel with an interrupting process (e.g., using a DMA unit with integrated AES encryption hardware acceleration) and thus, could be designed to have a minimal impact on the processor performance. In another embodiment, a separate secure "working set encapsulation" module may be used to perform the encryption prior to allowing working set data to be written out to memory.
[0095] Using embodiments presented herein, then, by making the system's secret keys
architecturally invisible (either directly or indirectly) and by virtue of the ability to efficiently and definitively isolate the working set of a secure process from any other process, recursive security devices may be made substantially impervious to replay attacks and offer an immunity to return-oriented, or other, programming exploits, that cannot be matched in competing solutions. As such, these recursive security systems may provide a number of advantages relative to the implementation of security using obfuscation alone.
[0096] Before discussing embodiments in more detail, it may helpful to give a general overview of an architecture in which embodiments of the present invention may be effectively utilized. FIGURE 1 depicts one embodiment of such a topology. Here, a content distribution system 101 may operate to distribute digital content (which may be for example, a bitstream comprising audio or video data, a software application, etc.) to one or more target units 100 (also referred to herein as target or endpoint devices) which comprise protocol engines. These target units may be part of, for example, computing devices on a wireline or wireless network or a computer device which is not networked, such computing devices including, for example, a personal computers, cellular phones, personal data assistants, media players which may play content delivered as a bitstream over a network or on a computer readable storage media that may be delivered, for example, through the mail, etc. This digital content may compose or be distributed in such a manner such that control over the execution of the digital content may be controlled and security implemented with respect to the digital content.
[0097] In certain embodiments, control over the digital content may be exercised in conjunction with a licensing authority 103. This licensing authority 103 (which may be referred to as a central licensing authority, though it will be understood that such a licensing authority need not be centralized and whose function may be distributed, or whose function may be accomplished by content distribution system 101 , manual distribution of data on a hardware device such as a memory stick, etc.) may provide a key or authorization code. This key may be a compound key (DS), that is both cryptographically dependent on the digital content distributed to the target device and bound to each target device (TDn). In one example, a target device may be attempting to execute an application in secure mode. This secure application (which may be referred to as candidate code or a candidate code block (e.g., CC)) may be used in order to access certain digital content.
[0098] Accordingly, to enable a candidate code block to run in secure mode on the processor of a particular target device 100 to which the candidate code block is distributed, the licensing authority 103 must supply a correct value of a compound key (one example of which may be referred to as an Authorization Code) to the target device on which the candidate code block is attempting to execute in secure mode (e.g., supply DS1 to TD1 ). No other target device (e.g., TDn, where TDn≠TD1 ) can run the candidate code block correctly with the compound key (e.g., DS1 ) and no other compound key (DSn assuming DSn≠DS1 ) will work correctly with that candidate code block on that target device 100 (e.g., TD1 ).
[0099] As will be described in more detail later on herein, when Target Device 100 (e.g., TD1 ) loads the candidate code block (e.g., CC1 ) into its instruction cache (and, for example, if CC1 is identified as code that is intended to be run in secure mode), the target device 100 (e.g., TD1 ) engages a hash function (which may be hardware based) that creates a message digest (e.g., MD1 ) of that candidate code block (e.g., CC1 ). The seed value for this hash function is the secret key for the target device 100 (e.g., TD1 's secret key (e.g., SK1 )).
[0100] In fact, such a message digest (e.g., MD1 ) may be a Message Authentication Code (MAC) as well as a compound key, since the hash function result depends on the seed value of the hash, the secret key of the target device 100 (e.g., SK1 ). Thus, the resulting value of the message digest (e.g., MD1 ) is cryptographically bound to both the secret key of the target device 100 and to the candidate code block. If the licensing authority distributed compound key (e.g., DS1 ) matches the value of the message digest (e.g., MD1 ) it can be assured that the candidate code block (e.g., CC1 ) is both unaltered as well as authorized to run in secure mode on the target device 100 (e.g., TD1 ). The target device 100 can then run the candidate code block in secure mode.
[0101 ] As can be seen then, in one embodiment, when secure mode execution for a target device 100 is performed the target device 100 may be executing code that has both been verified as unaltered from its original form, and is cryptographically "bound" to the target device 100 on which it is executing. This method of ensuring secure mode execution of a target device may be contrasted with other systems, where a processor enters secure mode upon hardware reset and then may execute in a hypervisor mode or the like in order to establish a root-of-trust. [0102] Accordingly, using embodiments as disclosed, any or all of these data such as the compound key from the licensing authority, the message digest, the candidate code block, etc. (e.g., DS1 , MD1 , CC1 ) may be completely public as longs as the secret key for the target device 100 (e.g. SK1 ) is not exposed. Thus, it is desired that the value of the secret key of a target device is never exposed, either directly or indirectly. Accordingly, as discussed above, embodiments of the systems and methods presented herein, may, in addition to protecting the secret key from direct exposure, protect against indirect exposure of the secret key on target devices 100 by securing the working sets of processes executing in secure mode on target devices 100.
[0103] Moving now to FIGURE 2, an architecture of one embodiment of a target device that is
capable of controlling the execution of the digital content or implementing security protocols in conjunction with received digital content. Elements of the target unit may include a set of blocks, which allow a process to execute in a secured mode on the target device such that when a process is executing in secured mode the working set of the process may be isolated. It will be noted that while these blocks are described as hardware in this embodiment, software may be utilized to accomplish similar functionality with equal efficacy. It will also be noted that while certain embodiments may include all the blocks described herein other embodiments may utilize lesser or additional blocks.
[0104] The target device 100 may comprise a CPU execution unit 120 which may be a processor core with an execution unit and instruction pipeline. Clock or date/time register 102 may be a free-running timer that is capable of being set or reset by a secure interaction with a central server. Since the time may be established by conducting a query of a secure time standard, it may be convenient to have this function be on-chip. Another example of such a date/time register may be a register whose value does not necessarily increment in a monotonic manner, but whose value does not repeat very often. Such a register could be useful in the case where a unique timestamp value might be required for a particular reason, but that timestamp value could not necessarily be predicted ahead of time. Thus, a pseudo-random number generator may be a suitable mechanism for implementing such a register. Another option for implementing such a function would be to use the output of a hardware hash function 160 to produce the current value of this register. In the case where the output of such a hash function is used as a seed or salt value for the input of the hash function, the resulting output series may resemble a random number sequence statistically, but the values may nonetheless be deterministic, and thus, potentially predictable. Target unit 100 may also contain a true random number generator 182 which may be configured to produce a sequence of sufficiently random numbers or which can then be used to supply seed values for a pseudo-random number generation system. This pseudo-random number generator can also potentially be implemented in hardware, software or in "secure" software.
[0105] One-way hash function block 160 may be operable for implementing a hashing function substantially in hardware. One-way hash function block 160 may be a part of a secure execution controller 162 that may be used to control the placement of the target device 100 in secure mode or that maybe used to control memory accesses (e.g., when the target device 100 is executing in secured mode), as will be described in more detail herein at a later point.
[0106] In one embodiment, one way has function block 160 may be implemented in a virtual
fashion, by a secure process running on the very same CPU that is used to evaluate whether a given process is secure or not. In certain embodiments two conditions may be adhered to, ensuring that such a system may resolve correctly. First, the secure mode "evaluation" operation (e.g., the hash function) proceeds independently of the execution of the secure process that it is evaluating. Second, a chain of nested evaluations may have a definitive termination point (which may be referred to as the root of the "chain of trust" or simply the "root of trust"). In such embodiments, this "root of trust" may be the minimum portion of the system that should be implemented in some non-changeable fashion (e.g., in hardware). This minimum feature may be referred to as a "hardware root of trust". For example, in such embodiments, one such hardware root of trust might be a One-Way hash function that is realized in firmware (e.g., in non-changeable software).
[0107] Another portion of the target unit 100 may be a hardware-assisted encryption/decryption block 170 (which may be referred to as the encryption system or block, the decryption system or block or the encryption/decryption block interchangeably), which may use either the target unit's 100 secret key(s) or public/private keys (described later) or a derivative thereof, as described earlier. This encryption/decryption block 170 can be implemented in a number of ways. It should also be noted that such a combination of a One-Way Hash Function and a subsequent encryption/decryption system may comprise a digital signature generator that can be used for the validation of any digital data, whether that data is distributed in encrypted or in plaintext form. The speed and the security of the entire protocol may vary depending on the construction of this block, so it may be configured to be both flexible enough to accommodate security system updates as well as fast enough to allow the system to perform real-time decryption of time-critical messages.
[0108] It is not material to embodiments exactly which encryption algorithm is used for this
hardware block 170. In order to promote the maximum flexibility, it is assumed that the actual hardware is general-purpose enough to be used in a non-algorithmically specific manner, but there are many different means by which this mechanism can be implemented. It should be noted at this point that the terms encryption and decryption will be utilized interchangeably herein when referring to engines (algorithms, hardware, software, etc.) for performing encryption/decryption. As will be realized if symmetric encryption is used in certain embodiments, the same or similar encryption or decryption engine may be utilized for both encryption and decryption. In the case of an asymmetric mechanism, the encryption and decryption functions may or may not be substantially similar, even though the keys may be different.
[0109] Target device 100 may also comprise a data cache 180, an instruction cache 1 10 where code that is to be executed can be stored, and main memory 190. Data cache 180 may be almost any type of cache desired such as a L1 or L2 cache. In one embodiment, data cache 180 may be configured to associate a secure process descriptor with one or more pages of the cache and may have one or more security flags associated with (all or some subset of the) lines of a data cache 180. For example, a secure process descriptor may be associated with a page of data cache 180.
[01 10] Generally, embodiments of target device 100 may isolate the working set of a process
executing in secure mode stored in data cache 180 such that the data is inaccessible to any other process, even after the original process terminates. More specifically, in one embodiment, the entire working set of a currently executing may be stored in data cache 180 and writes to main memory 190 and write-through of that cache (e.g., to main memory 190) disallowed (e.g., by secured execution controller 162) when executing in secured mode.
[01 1 1 ] Additionally, for any of those lines of data cache 180 that are written to while executing in secure mode (e.g., a "dirty" cache line) those cache lines (or the page that comprises those cache lines) may be associated with a secure process descriptor for the currently executing process. The secure process descriptor may uniquely specify those associated "dirty" cache lines as belonging to the executing secure process, such that access to those cache lines can be restricted to only that process (e.g. be by secured execution controller 162).
[01 12] In certain embodiments, in the event that the working set for a secure process overflows data cache 180 and portions of data cache 180 that include those dirty lines associated with the security descriptor of the currently executing process need to be written to main memory (e.g., a page swap or page out operation) external data transactions between the processor and the bus (e.g., an external memory bus) may be encrypted (e.g., using encryption block 170 or encryption software executing in secure mode). The encryption (and decryption) of data written to main memory may be controlled by secure execution controller 162. [01 13] The key for such an encryption may be the secure process descriptor itself or some derivative thereof and that secure descriptor may itself be encrypted (e.g., using the target device's 100 secret key 104 or some derivative thereof) and stored in the main memory 190 in encrypted form as a part of the data being written to main memory.
[01 14] Instruction cache 1 10 is typically known as an l-Cache. In some embodiments, a
characteristic of portions of this l-Cache 1 10 is that the data contained within certain blocks be readable only by CPU execution unit 120. In other words, this particular block of l-Cache 130 is execute-only and may not be read from, nor written to, by any executing software. This block of l-Cache 130 will also be referred to as the "secured l-Cache" 130 herein. The manner by which code to be executed is stored in this secured l-Cache block 130 may be by way of another block which may or may not be depicted. Normal l-Cache 150 may be utilized to store code that is to be executed normally as is known in the art.
[01 15] Additionally, in some embodiments, certain blocks may be used to accelerate the operation of a secure code block. Accordingly, a set of CPU registers 140 may be designated to only be accessible while the CPU 120 is executing secure code or which are cleared upon completion of execution of the secure code block (instructions in the secured l-cache block 130 executing in secured mode), or if, for some reason a jump to any section of code which is located in the non-secure or "normal" l-Cache 150 or other area occurs during the execution of code stored in the secured l-Cache 130.
[01 16] In one embodiment, CPU execution unit 120 may be configured to track which registers 140 are read from or written to while executing the code stored in secured l-cache block 130 and then automatically clear or disable access to these registers upon exiting the "secured execution" mode. This allows the secured code to quickly "clean-up" after itself such that only data that is permitted to be shared between two kinds of code blocks is kept intact. Another possibility is that an author of code to be executed in the secured code block 130 can explicitly identify which registers 140 are to be cleared or disabled. In the case where a secure code block is interrupted and then resumed, then these disabled registers may potentially be re-enabled if it can be determined that the secure code that is being resumed has not been tampered with during the time that it was suspended.
[01 17] In one embodiment, to deal with the "leaking" of data stored in registers 140 between secure and non-secure code segments a set of registers 140 which are to be used only when the CPU 120 is executing secured code may be identified. In one embodiment this may be accomplished utilizing a version of the register renaming and scoreboarding mechanism, which is practiced in many contemporary CPU designs. In some embodiments, the execution of a code block in secured mode is treated as an atomic action (e.g., it is non- interruptible) which may make this such renaming and scoreboarding easier to implement.
[01 18] Even though there may seem to be little possibility of the CPU 120 executing a mixture of "secured" code block (code from the secured l-Cache 130) and "unsecured code" (code in another location such as normal l-cache 150 or another location in memory), such a situation may arise in the process of switching contexts such as when jumping into interrupt routines, or depending on where the CPU 120 context is stored (most CPU's store the context in main memory, where it is potentially subject to discovery and manipulation by an unsecured code block).
[01 19] In order to help protect against this eventuality, in one embodiment another method which may be utilized for protecting the results obtained during the execution of a secured code block that is interrupted mid-execution from being exposed to other execution threads within a system is to disable stack pushes while a the target device 100 is operating in secured execution mode. This disabling of stack pushes will mean that a secured code block is thus not interruptible in the sense that, if the secured code block is interrupted prior to its normal completion, it cannot be resumed and therefore must be restarted from the beginning. It should be noted that in certain embodiments if the "secured execution" mode is disabled during a processor interrupt, then the secured code block may also potentially not be able to be restarted unless the entire calling chain is restarted.
[0120] Each target unit 100 may also have one or more secret key constants 104; the values of neither of which are software-readable. In one embodiment, the first of these keys (the primary secret key) may be organized as a set of secret keys, of which only one is readable at any particular time. If the "ownership" of a unit is changed (for example, the equipment containing the protocol engine is sold or its ownership is otherwise transferred), then the currently active primary secret key may be "cleared" or overwritten by a different value. This value can either be transferred to the unit in a secure manner or it can be already stored in the unit in such a manner that it is only used when this first key is cleared. In effect, this is equivalent to issuing a new primary secret key to that particular unit when its ownership is changed or if there is some other reason for such a change (such as a compromised key). A secondary secret key may be utilized with the target unit 100 itself. Since the CPU 120 of the target unit 100 cannot ever access the values of either the primary or the secondary secret keys, in some sense, the target unit 100 does not even "know" its own secret keys 104. These keys are only stored and used within the security execution controller 162 of the target unit 100 as will be described. [0121 ] In another embodiment, the two keys may be constructed as a list of "paired" keys, where one such key is implemented as a one-time-programmable register and the other key in the pair is implemented using a re-writeable register. In this embodiment, the re-writeable register may be initialized to a known value (e.g., zero) and the only option that may be available for the system to execute in secure mode in that state may be to write a value into the re-writeable portion of the register. Once the value in this re-writeable register is initialized with some value (e.g., one that may only be known by the Licensing Authority, for example), then the system may only then be able to execute more general purpose code while in secure mode. If this re-writeable value should be re-initialized for some reason, then the use of a new value each time this register is written may provide increased security in the face of potential replay attacks.
[0122] Yet another set of keys may operate as part of a temporary public/private key system (also known as an asymmetric key system or a PKI system). The keys in this pair may be generated on the fly and may be used for establishing a secure communications link between similar units, without the intervention of a central server. As the security of such a system is typically lower than that of an equivalent key length symmetric key encryption system, these keys may be larger in size than those of the set of secret keys mentioned above. These keys may be used in conjunction with the value that is present in the on-chip timer block in order to guard against "replay attacks", among other things. Since these keys may be generated on the fly, the manner by which they are generated may be dependent on the random number generation system 180 in order to increase the overall system security.
[0123] In one embodiment, one method that can be used to affect a change in "ownership" of a particular target unit is to always use the primary secret key as a compound key in conjunction with another key 107, which we will refer to as a timestamp or timestamp value, as the value of this key may be changed (in other words may have different values at different times), and may not necessarily reflect the current time of day. This timestamp value itself may or may not be itself architecturally visible (e.g., it may not necessarily be a secret key), but nonetheless it will not be able to be modified unless the target unit 100 is operating in secured execution mode. In such a case, the consistent use of the timestamp value as a component of a compound key whenever the primary secret is used can produce essentially the same effect as if the primary secret key had been switched to a separate value, thus effectively allowing a "change of ownership" of a particular target endpoint unit without having to modify the primary secret key itself.
[0124] As may be understood then, target device may use secure execution controller 162 and data cache 180 to isolate the working sets of processes executing in secure mode such that the data is inaccessible to any other process, even after the original process terminates. This working set isolation may be accomplished in certain embodiments by disabling off-chip writes and write-through of data cache when executing in secured mode, associating lines of the data cache written by the executing process with a secure descriptor (that may be uniquely associated with the executing process) and restricting access to those cache lines to only that process using the secure process descriptor. Such a secure process descriptor may be a compound key such as an authorization code or some derivative value thereof.
[0125] When it is desired to access data in the data cache by the process the secure descriptor associated with the currently executing process may be compared with the secure descriptor associated with the requested line of the data cache. If the secure descriptors match, the data of that cache line may be provided to the executing process while if the secure descriptors do not match the data may not be provide and another action may be taken.
[0126] Moreover, in certain embodiments, in the event that the working set for a secure process overflows the on-chip cache, and portions of cache that include those dirty lines associated with the secure process descriptor need to be written to main memory (e.g., a page swap or page out operation) external data transactions between the processor and the bus (e.g., an external memory bus) may be encrypted. The key for such an encryption may be the secure process descriptor itself or some derivative thereof and that secure process descriptor may be encrypted (e.g., using the target device's secret key or some derivative thereof) prior to being written out to the main memory. Again, this encryption processes may be accomplished substantially using the hashing block of the target device or by use of an software encryption process running in secure mode on the processor itself or some other on-chip processing resource, or by use of a encryption function that is implemented in hardware.
[0127] To enhance performance, in certain cases where a secure process may have a large
working set or is frequently interrupted (e.g., entailing many page swaps) a subset of the processes working set that is considered "secure" may be created (e.g., only a subset of the dirty cache lines for the process may be associated with the secure descriptor) and only encrypt those cache lines or the portion of the cache containing those lines, when it is written out to external memory.
[0128] Additionally, to enhance performance, an off-chip storage mechanism (e.g., a page
swapping module) can be run asynchronously in parallel with an interrupting process (e.g., using a DMA unit with integrated AES encryption hardware acceleration) and thus, could be designed to have a minimal impact on the main processor performance. In another embodiment, a separate secure "working set encapsulation" software module may be used to perform the encryption prior to allowing working set data to be written out to memory.
[0129] At this point in the discussion, it may be helpful to show an example of how a One-Way Compound Key may be constructed in general terms, prior to discussing a more specific example. Referring now to FIGURE 15, a general structure consisting of a first One-Way Hash function 1510, its associated input data set 1520 and its resultant output 1523. In this example, the input data set 1520 can be further broken down into three components, Secret Key 1521 , Precursor Key 1522 and Payload Data 1 1523.
[0130] Note that the names and formats of these input data elements 1521 , 1522 and 1523 as well as that of the resultant output 1532 (which we call Compound Key 1 ) are specified in this example simply as a convenience of reference. In fact, the format for any of these input data set elements may not be fixed. One-Way Hash function 1510 may have no knowledge of the structure of its input data set 1520, nor does it matter how large the input data 1520 set may be.
[0131 ] In most cases, the size of the resultant output 1532 of the first One-Way Hash function 1510 is typically constant in size, no matter how large the input data set 1520 may be. This feature is typically referred to as the built-in "data compression" functionality of any One-Way Hash function. Although the built-in data compression property may be utilized the following examples, the overall structure of embodiments of the systems depicted herein do not depend on this data compression function.
[0132] Looking still at FIGURE 15 the resultant output 1532 of first application of One-Way Hash function 1510 can also then be used in conjunction with the Secret Key 1521 that was used earlier and a corresponding Payload Data 2 1533 to form the input data set 1530 for second application of One-Way Hash function 1540. Note that for ease of implementation, first One- Way Hash function 1510 and second One-Way Hash function 1540 may, in fact, be identical in operation, but may also be different. Also, for this example, the same Secret Key 1521 is used as a part of the input data set to both first One-Way Hash functions 1510 and second One-Way Hash function 1540, but these keys may also be different. The resulting output 1550 of second One-Way Hash function 1540 is then referred to as Compound Key 2.
[0133] It can be seen that this structure could easily be extended indefinitely by taking the value of output 1550 of second One-Way Hash function 1540 and inserting it into the Precursor Key position 1522 of the input data structure 1520 of first One-Way Hash function 1510.
Similarly, the Payload Data 1 portion 1523 of the input data set 1520 of first One-Way Hash function 1510 may also be replaced with a different Payload Data set. As such, this concatenated structure produces a "key-chaining" mechanism whereby the eventual result may be a single, fixed-length compound key with an arbitrarily large set of dependencies. In other words, the compound encryption mechanism may be chained to allow the production of a single compound key value that is cryptograph ically dependent on an arbitrary number of arbitrarily large precursors using simple aggregation.
[0134] It should be further noted that, due to the One-Way nature of the hash function, then it is computationally impractical to reverse the Hash function, that is, to compute the value of the input data set 1520, given the resultant output 1532. A second useful property of a One-Way Hash function is that it is also computationally impractical to compute the value of any one of the individual input data elements (for example 1521 , 1522 or 1523), even if the values of the other input data elements and the resultant output value 1532 are all known.
[0135] Similar in principle to the "chained" or "cascaded" One-Way Compound Key structure
described above, it can be seen that a logically equivalent structure can be constructed using an encryption function instead of a One-Way hash function. This encryption function may be a symmetric encryption function or an asymmetric encryption function without affecting the operating principal. For purposes of this example, we will show a structure that is based on a symmetric encryption mechanism.
[0136] In contrast to the One-Way Compound key example described above, the encryption chain may be executed in either forward or reversed input/output order in order to recreate a particular intermediate key value. For this reason, the structure, which is shown in Figure 16, is referred to as a "reversible" Compound Key construction. As with the One-Way Compound Key mechanism, the specific encryption functions performed at any of the stages in the forward or reverse process may or may not be the same. Similarly, the number of iterations through the various encryption stages can accumulate indefinitely without affecting the overall functionality of the "chained" Reversible Compound Key mechanism. It should be noted that if each of the stages in the Reversible Compound Key mechanism are implemented in software, then the overall security of the "chained" Compound Key structure may depend on the ability of the system to keep the intermediate keys secret (e.g., isolated) from other processes that are not part of the "chain". In fact, it may be desirable to keep at least some of these intermediate values isolated from any other process, whether that process is a part of the "chain" or not. Embodiments which allow such an isolation mechanism are discussed below.
[0137] It should also be noted that a "hybrid" Compound Key mechanism can be constructed, including both One-Way and Reversible Compound Key elements. An example of such a structure is shown in FIGURE 17. This kind of mechanism can be useful in order to ensure security of a chain of secure processes as well as the input data that is supplied to those secure processes.
[0138] It may now be helpful now to discuss a specific example of how the embodiments of
compound key generation shown in FIGURE 15 can be utilized in the architecture of embodiments of a secured execution controller and a data cache. Referring to FIGURE 3, one embodiment of the architecture of a secure execution controller is depicted. In this embodiment, secure execution controller 362 is associated with a CPU of a system in which it is included and is intended to support the running of a candidate code block in secure mode on the main CPU. As such, secure execution controller 362 may comprise one or more of registers, including a secret hardware key 310 which is not visible to the CPU, secure mode control register 350, authorization code register 360, secure mode status register 352, hash seed register 312 and hardware generated compound key register 314. Of these registers, all but secret hardware key 310 may be readable by a CPU without affecting the overall security of the system, although any of these other registers may or may not be visible.
[0139] Secure mode control register 350 may be a register that may be written to in order to attempt to place the target device in a secure mode. The secure mode control register 350 may have a register into which a memory location (e.g. in an l-cache or main memory) corresponding to the beginning address of a candidate code block (e.g., a code block to be executed in secured mode) may be written and a separate register into which the length of such a candidate code block may be written. Authorization code register 360 may be a location into which an authorization code or another type of key or data may be written. Secure mode status register 352 may be a memory-mapped location comprising one or more bits that may only be set by hardware comparison block 340 and which can indicate whether or not the target device 100 is operating in secure mode.
[0140] Hardware hash function block 320 may be operable for implementing a hash function
substantially in hardware to generate a compound key 314. Hardware hash function block 320 may, for example, implement a SHA 256 or some similar one-way hash function.
However, this hash function may also be implemented in software or in firmware running on either a separate processor from the CPU of the system, or even a process that is run on the CPU in secure mode, using a virtual hardware hash function methodology as described earlier.
[0141 ] Hardware hash function block 320 may take as input one or more of the values stored in the hash seed register 312, secret hardware key 310 or data from another location, concatenate these inputs (e.g., prepend or append one input to another) and hash the resulting data set to generate a message authentication code, which we have referred to earlier as a one-way compound key.
[0142] In certain embodiments, almost any numeric value can be provided as an input (precursor) for hardware hash function block 320. Referring briefly to FIGURE 6, for example, the input data for the hardware hash function 510 may be constructed by a concatenation of the secret hardware key 514, the hash seed precursor key 516 and the secure code block candidate 532. There may be no fundamental difference in the operation of the hash function 510, almost no matter what the input data 514, 516 and 532 represent or how large any of these data sets may be. It should also be noted here, that the other inputs to the hardware hash function 510 that are shown coming from the secure mode controller state machine 580 represent control inputs as opposed to input data to the hash function.
[0143] Referring briefly to FIGURE 7 now, the same structure that was seen in FIGURE 6 is
depicted, but in this case, the resulting output of the hash function 524 is now shown. This value 524 is typically referred to as a Message Authentication Code (or MAC) in modern cryptographic literature, and this result 524 has also been referred to herein as a compound key (e.g., hardware-generated). Due to the inherent compression function of (almost all) secure one-way hash mechanisms, the resulting compound key 524 will be of constant size, almost no matter how large the input data sets that were used or even how many times the data has been iterated through the hash function 510.
[0144] Looking back now at FIGURE 3, hardware generated compound key register 314 is
configured to store the output of the hardware hash function block 320. Hardware comparison block 340 may be configured to compare the data in hardware generated compound key register 314 with the data in authorization code register 360. If the two values are identical the hardware comparison block 340 is configured to set the one or more bits in secure mode status register 352 that place the target device in secure mode.
[0145] Secure mode controller state machine 370 may be logic (e.g., hardware, software or some combination) that may operate based on the state of bits of secure mode control register 350 or secure mode status register 352. Secure mode controller state machine 370 is configured for controlling inputs to hardware hash function block 320, such that the precursors may be utilized in the correct manner to generate the desired output 314 of hardware hash function block 320. For example, secure mode controller state machine 370 may be configured to cause the resulting output to be loaded into hardware generated compound key register 314 at the proper time. Additionally, secure mode controller state machine 370 may be configured to cause the correct data to be written to secure mode status register 352. [0146] Secure mode controller state machine 370 may also be configured for controlling memory access when the target device is executing in secure mode. In one embodiment, when the bits in secure mode status register 352 that indicate that the target device is now operating in secure mode, then secure mode controller state machine 370 may be configured to determine which of the pages of the data cache have been assigned to that process and store a secure descriptor for that process in the data cache in association with the one or more of the pages of the data cache. These secure process descriptors may thus be used to associate a particular set of data that is being stored in the data cache with a specific process that is executing in secured mode. Such a secure process descriptor may, for example, be the value that is based on the data that is located in authorization code register 360 or the hardware-generated compound key register 314.
[0147] Additionally, when the bits in secure mode status register 352 that place the target device in secure mode are set, secure mode controller state machine 370 may be able to receive memory accesses by the process executing in secure mode and determine if the memory access is a read or a write access.
[0148] If the data access consists of a write operation, the secured mode controller state machine 370 may be configured to determine the cache line of the data cache corresponding to the address where the data is to be written and then set a security flag associated with that cache line to indicate that the data contained in that cache line is secure. In certain embodiments, secured mode controller state machine 370 is also configured to prevent any writes to any memory location which is not in the data cache, for example by disabling write- through, write-back or other operations of the data cache or memory controllers of the target device.
[0149] If the access is a read access the secured mode controller state machine 370 may be
configured to determine if a cache miss has occurred and if the requested address was not previously stored in the data cache the secured mode controller state machine 370 may be configured to allow the requested data to be read from main memory and placed in the data cache in a page associated with the process. If a cache hit occurs the secured mode controller state machine 370 may be configured to the determine the cache line
corresponding to the address of the memory access and check the security flag associated with that cache line to determine if it is set. If the security flag is not set the memory access may be allowed to proceed (e.g., the data read from the cache line).
[0150] Alternatively, if a security flag associated with the cache line in the data cache corresponding to the address from which data is to be read is set secured mode controller state machine 370 may be configured to obtain the secure process descriptor associated with the page in the data cache containing that cache line and compare it with a secure process descriptor associated with the currently executing. If the secure process descriptors match, then the memory access may be allowed to proceed. If the secure descriptors do not match, another action may be taken such as either returning a garbage or preset value in response to the memory access or alternately returning a "no-valid data" at that address message to the CPU, whereupon the CPU memory management unit may then request a replacement cache line to read in from system memory.
[0151 ] In one embodiment, only the data cache is used to store the entire working set of a process executing in secure mode and any writes to memory other than to the data cache by the process may be disabled. Additionally, any lines of the data cache that are written to (e.g., so-called "dirty" cache lines) while in secure mode are associated with a secure process descriptor that may uniquely and precisely specify which process to whom the "dirty" cache line belongs. Access to these cache lines may only be allowed to the owner of the particular "dirty" cache line such that any cache line modified during the operation of a secure process is unreadable by any other process, even after the original process has terminated. Thus, data that belongs to one instance of a process is unambiguously isolated from any other process.
[0152] Moving now to FIGURES 4A and 4B, one embodiment of the architecture of a data cache that may be utilized to effectuate isolation of working sets of processes according to certain embodiments as presented herein is depicted. Referring first to FIGURE 4A, data cache 400 may be almost any type of cache, including a L1 cache a L2 cache, a direct mapped cache, a 2-way set associative cache, a 4-way set associative, a 2-way skewed associative cache, etc. that may be implemented in conjunction with almost any management or write policies desired. The cache 400 may comprise a set of pages 410. When used when referring to the cache herein, a page may be understood to mean cache block or a cache set. The data cache 400 is configured to store a secure descriptor associated with one or more pages 410 of the cache.
[0153] FIGURE 4B depicts a view of one embodiment of a page 410a of cache 400. Here, the cache comprises logic 412 designed to store a secure process descriptor in association with the page 410a and to provide the secure process descriptor in response to a request for the secure process descriptor for page 410a or in conjunction with a read to a cache line 402 of page 410a. Each cache line 402 of the page 410a includes bits for the data, address tags and flags 420. The flags 420 may include bits such as a valid bit or dirty bit. In addition, flags 420 may include a secure bit 422. Cache 400 may be configured such that a secure bit 422 for a cache line 402 may be set (e.g., when a process executing in secure mode writes to that cache line 402).
[0154] It will now be useful to explain how embodiments of such a target device may be place in secured mode. Again, a better understanding of certain embodiments may be gleaned from a review of U.S. Patent Application No. 12/615,843, entitled "Method and System for Control of Code execution on a General Purpose Computing Device and Control of Code Execution in an Recursive Security Protocol," filed November 10, 2009, the subject matter of which is described with respect to FIGURES 18-36 of this application.
[0155] It should be noted that, in one embodiment, the procedure by which any generic (or
otherwise) block of code (which will be referred to as a "secure work function") may be executed in secure mode on embodiments of a system such as those described herein is to execute a pair of extra functions, one on either side (e.g., before or after) of the secure work function. A function (or set of functions) that is executed immediately prior to a secure work function will be referred to as the "prologue" and a function (or set of functions) which is executed immediately after the secure work function will be referred to as the "epilogue".
[0156] Thus, in one embodiment, in order to execute a secure work function on a CPU, then that secure work function should be preceded by a prologue and followed by an epilogue. In certain embodiments, the purpose of the prologue is at least threefold. First, the prologue should prepare the input arguments that are passed to the secure work function for use by the secure work function. This preparation may involve, for example, a decryption process, which may be required for those input arguments that may not be passed to the secure work function in the clear. A second function of the prologue may be to construct a compound key whose value is dependent on a number of data elements. Such data elements may include the hardware secret key of the target device, the Authorization Code of the parent (e.g., calling) function, a list of one or more input arguments to the secure work function (either in encrypted or non-encrypted form), the executable image of the secure work function itself, or some other information that may be used in determining whether or not the secure work function should be allowed to execute on the target device in secure mode. A third function of the prologue could be to initiate a request that the CPU begin executing the secure work function in secure mode.
[0157] The purpose of the epilogue may be to "clean up" after the execution of the secure work function is complete. One function the epilogue may be to prepare any designated output parameters for use by subsequent code blocks (e.g., to be executed after the secure work function), be they secure or not. For example, this preparation may involve encrypting of the designated output (or returned data) from the secure work function so that any observing process other than the intended recipient of such output arguments, including either hardware or software-based observers, may be precluded from effectively intercepting that data. In such a case, the encryption key that may be used may be a reversible compound key that is passed to the secure routine as one of its calling arguments.
[0158] A second function of the epilogue may be to either programmatically or automatically
invalidate those portions of a data cache that have been written to while the secure work function (e.g., by the secure work function) was executing. Thus, in the case where a secure work function may have had its operation suspended and then resumed, the data values that were written to a secure portion of the data cache prior to the process being suspended may thus be available to the resumed secure process without having to page these secure data locations out to memory (which may involve an intervening encryption process). Then, once the secure function had been resumed, these same data cache locations may then be made available to the secure function, since the secure process descriptor may match the currently executing authorization code, or some derivative thereof (or another value being used as a secure process descriptor).
[0159] However, once a secure process had terminated (for example, using an epilogue function), then these same secure data cache locations may be marked as invalid during the epilogue function. This invalidation process would prevent any unintended potential "leakage" of data that may still be resident in the secure portion of the data cache from being accessed after the secure work function has terminated properly.
[0160] In this manner, even if a secure work function is repeated and if it is given the same secure process descriptor twice in a row, the second iteration of this secure work function will nonetheless be unable to access the working set data from the first iteration of that same secure work function, despite the fact that they might have the same secure process descriptor for both iterations. It will be noted that the descriptions of the prologue and epilogue are provided by way of example and that more or fewer functions may be accomplished by the prologue of the epilogue and that additionally, these function (or additional or fewer function) may be accomplished in another manner without departing from the scope of embodiments as described.
[0161 ] FIGURES 5-7 depict a block diagram of one embodiment of a flow for placing a target device in secure mode. Referring first to FIGURE 5, initially, a code block 531 may be configured to execute in secured mode. Such a code block may be received, for example, from a content distribution system or loaded from a computer readable medium, etc. Additionally, an authorization code may be received, for example, from a licensing authority, read from a computer readable medium, input by a user, etc. Both the code block (referred to as a candidate code block at some locations herein, as it is a "candidate" to execute in secure mode) and the authorization code 520 may be stored in the main memory 530 of the target device.
[0162] Note that, in this embodiment, the candidate code block is comprised of a prologue function, a secure work function and an epilogue function, in that order. In such an embodiment, then, the Authorization Code that would be associated with the secure work function may include dependencies on all three functional sections of the candidate code block. However, in some embodiments, the prologue and epilogue functions may be implemented substantially in a fixed manner (in other words, in hardware or firmware). In that case, then it is possible that the Authorization Code for the candidate code block may have more limited dependencies on the prologue and epilogue functions.
[0163] Accordingly, when the candidate code block 510 is loaded into l-cache 540 and begins to be executed by CPU execution unit 550, CPU execution unit 550 may access secure mode control register 560 of secure execution controller 570 and set the bits of secure mode control register 560 to initiate the placement of the target device in secure mode.
Additionally, the memory location (e.g., the location in l-cache to which the code block 531 is being transferred or the location in main memory 530) of the candidate code block 531 along with the length of the candidate code block 531 may be written into the secure mode control register 560. Based upon the setting of bits in secure mode control register 560, secure mode controller state machine 580 may perform one or more functions.
[0164] Moving on to FIGURE 6, secure mode controller state machine 580 may then configure the target device such that the candidate code block 531 is provided to the hardware hash block 510 of the secure execution controller 570. This configuration may be done, for example, based on the location in memory of the candidate code block written into secure mode control register 560.
[0165] In one embodiment, the secure mode controller state machine 580 may go out to main
memory 530 and fetch the candidate code block 531 in order to explicitly load the candidate code block into the l-cache 540. In another embodiment, the secure mode controller state machine 580 may observe the data bus transactions as some other portion of the target device loads the candidate code block 531 from main memory 530 into the l-cache 540, confirming that the candidate code block 510 has been loaded in its entirety into the l-cache 540.
[0166] In another embodiment, the secure mode controller state machine 580 may cause another portion of the target device to perform this transfer from main memory 530 into the l-cache 540. In yet another embodiment, the secure mode controller state machine 580 may observe the data transferred from main memory 530 and keep track of the data as it is transferred into the l-cache 540.
[0167] In one embodiment, the bits comprising the candidate code block 531 may be provided to the hardware hash function block 510 as they are transferred across a bus from the main memory 530 to the l-cache 540. Using the received candidate code block 531 the hardware hash block 512 may create a compound key from the candidate code block 531 , secret hardware key 514 and optionally one or more other precursor values stored in hash seed register 516.
[0168] Turning to FIGURE 7, at some point, in order to begin secure execution of the candidate code block, CPU execution unit may write authorization code 520 associated with candidate code block 531 into authorization code register 522 of secure execution controller 570. When the compound key is generated by the hardware hash block 512 it is written to hardware generated compound key register 524. Secured mode controller state machine 580 is then configured to initiate a comparison between the value in hardware generated compound key register 524 and the value in authorization code register 522. If these values match, hardware comparison block 532 may write the bits in secure mode status register 534 that place the target device in secure mode. The code block 510 can then be executed by the CPU execution unit 550 in secured mode. If the values do not match, the target device will not be placed in secure mode, however, the code block 510 may (or may not) be still allowed to execute (although not in secured mode).
[0169] As can be seen then, execution of code in secured mode can be controlled through the use of a provided authorization code. This authorization code may be a compound key (DS), that is both cryptographically dependent on the candidate code block distributed to the target device and bound to each target device (e.g., using the secret key of that target device).
[0170] Accordingly, to enable a candidate code block to run in secure mode on a particular target device the correct authorization code (e.g., constructed using both the candidate code block and the secret key of the target device) must be provided. No other target device can run the candidate code block correctly with that authorization code and no other compound key works with that candidate code block on that target device.
[0171 ] Consequently, as the secret key of a target device can only be accessed when the target device is executing in secure mode (or, for example, in certain other instances such as when determining if the target device should be placed in secured mode) a dependency similar to a circular dependency has been created. Only some entity (e.g., a licensing authority) in possession of a device's secret key in the first place can generate a compound key to allow a particular code block to run in secure mode on that target device. Thus, an entity may need a-priori knowledge of a device's secret key before they can authorize a piece of code to access that key. If an entity does not have access to the correct value of the secret key it cannot generate a valid compound key to authorize that code to execute in secure mode.
[0172] Furthermore, because the compound key provided by the licensing authority was created using the original code block and the secret key, it can be assured that the candidate code block on the target device has not been modified or tampered with before placing the device in secure mode, as if the candidate code block has been modified in any way the compound key generated at the target device will not match the compound key received (e.g., from the licensing authority) and thus the target device will not be placed in secured mode.
[0173] In this manner, then, the use of the hash function on the target device validates that the candidate code block has not been tampered with and (e.g., by use of the compound key "chaining" method described earlier) ensures the order of execution of processes, as well as verifies that the candidate code block is authorized to run in secure mode on the target device. In order to maintain overall operational security of the system it is then further desired, in one embodiment, to ensure that, when executing a code block as a process in secure mode: calling arguments have not been modified (maliciously or otherwise); a process is executed to completion (e.g., with or without interruption) and the working set of the process remains isolated from external observation.
[0174] In one embodiment, the first of these three desired (ensuring calling arguments have not been modified) is achievable if the calling arguments (or an appropriate subset thereof) are included with the rest of a candidate code block to be secured by the hash function. This concept was discussed above with respect to embodiments of the contents of a candidate code block.
[0175] The latter two desires (referred to respectively as execution-to-completion and working-set- isolation) can also be addressed in certain embodiments using the compound key or the recursive execution components described herein. As mentioned above, embodiments of ensuring execution to completion are disclosed and discussed in U.S. Patent Application No. 12/615,843, entitled "Method and System for Control of Code execution on a General Purpose Computing Device and Control of Code Execution in an Recursive Security Protocol," filed November 10, 2009, the subject matter of which is described with respect to FIGURES 18-36 of this application. [0176] Turning then to working set isolation, it may be desired that any data that is modified or generated during the execution of a process in secure mode (other than possibly returned arguments) remain unreadable by any other process, even after the original process has terminated. Working set isolation may be more complicated than just ensuring that any of the system memory (e.g., data cache or main memory) that is used when executing a process in secure mode is isolated from external observation as there are a number of well- known side-channel or indirect methods for attacking an otherwise closed security system, of which timing attacks and Differential Power Analysis (DPA) are a couple of the more powerful of such widely-practiced schemes.
[0177] To ensure working set isolation then, in certain embodiments when the target device is
executing secured mode (e.g., when the bit of secure mode status register used to place the target device in secure mode is set) the data cache of the processor may be used to store the entire working set of the currently executing secure code segment and writes by the process to any other part of memory may be disallowed and write-through or write-back of the lines of the data cache (or any other type of memory synchronization between the data cache and main memory) may also be disallowed. Additionally, any lines of the data cache that are written to by the secure process while in secure mode may be tagged with a unique secure process descriptor that uniquely and precisely specifies the process to which that data cache line belongs. Access to those data cache lines (or pages) may then be restricted to only the process associated with that secure descriptor.
[0178] Accordingly, in certain embodiments, the secure process descriptor is sufficiently unique to be able to not only distinguish between different processes from different code blocks, but also between different processes resulting from executing the same code block at different times. Accordingly, a secure descriptor can be a compound key. Just as with our previous examples discussed herein, the compound key mechanism can be utilized to produce this secure descriptor without compromising the target device's secret key. In such cases, an added advantage is that the existing hardware based hash bock and hardware compare block described earlier can be used to create or compare these secure process descriptors without exposing any intermediate data to an external attacker.
[0179] In fact, in one embodiment, a simple and effective secure process descriptor that may be utilized is the authorization code associated with, and used to verify, the code block being executed in secured mode. Example precursors that may be utilized to create other examples of secure process descriptors are, for example, the target device's secret key, the message digest (e.g., authorization code) of the code block executing in secure mode, the secure process descriptor of the parent process (e.g., the calling function of the currently executing process) or the calling arguments of the currently executing process.
[0180] Of course, many other possible combinations could be used as the precursor values for this compound key-based secure process descriptor, including such variables as geographic location or time of day. The ability to dynamically limit a secure process' accessibility to even its own working set, based on such a set of variables can have a profound impact on the overall operation of the entire system. The functional implications for a secure block of code with this kind of external data dependency are enormous and this capability can be added to any code block executing in secured mode in a simple and highly efficient mechanism. Just as an example, a secure code block could be created that would only produce a correct result when the target device on which it was executing was located within a certain three- block area in midtown Manhattan between the times of 2:00PM and 2:25PM EST on March 19th 2014.
[0181 ] Also, it should be noted that, in certain embodiments, if a secure code block is interrupted prior to completion, then its working set cannot be accessed by any other secure code block (potentially not even if it calls itself). As for the ability to return the result (and only the result) of a secure code segment back to its parent, the returned value(s) from the secure code block can have similarly restricted access, as was described earlier. In this case, the secure process descriptor cache tags for the child routine's return arguments would be based on the parent routine's secure process descriptor (which could itself be an argument that is passed in a similarly "secured" manner to the "child" routine). The choice can be made of whether a particular argument passed between parent and child processes is defined as a "read-only" or "read / write" data type, by using either a One-Way or Reversible Compound key construction. Once the child process secure work function terminates, then the "dirty" cache lines (e.g., those that contained data that had been written to them by the child process' secure work function) may be invalidated by the epilogue function and thus may not be able to be accessed by any process, secure or otherwise. In effect, once the secure child process terminates normally, by way of a properly constructed epilogue function, these data would logically "evaporate", since they could no longer be read by any process -even the same process that written to them in the first. Note that the affected cache lines would not have to be explicitly cleared, they would simply no longer be accessible; a highly effective and efficient means for denying access to this data.
[0182] Also, once the secure process terminates, its final act would be to pass the specific returned results back to the parent routine, potentially in encrypted form. In this case, the encryption key used would be based on the calling (parent) routine's secure process descriptor. If the secure child process is terminated prior to this final act, then the returned values will not be able to be accessed by the parent routine. This particular mechanism prevents a partial result from ever being accessed by any other process; secure or otherwise. It can easily be seen that this Working Set Isolation mechanism is both much more secure and much more granular than a simple address space bifurcation into "secure" and "not secure" memory banks, for example. Also, this functionality can be implemented with minimal overhead.
[0183] Thus, we have described a method for not only preventing "leaks" from the working set of a secure code segment, but also a method for efficiently and securely passing results back and forth between a parent code segment and its "children", based on the Compound Encryption and Attributive Authentication mechanisms. Of course, this mechanism can be implemented in a variety of methods, but this particular implementation is quite easily integrated into any existing CPU architecture with a minimal silicon area impact, absolutely no architectural dependencies and with virtually no loss in overall performance.
[0184] It will now be useful to illustrate a flow of one embodiment of securing the working set of a process executing in secured mode. To illustrate this embodiment, attention is directed to FIGURES 8- 14. Referring first to FIGURE 8, it will be recalled from the discussion above that when a code block is verified the authorization code for the code block is placed in authorization code register 812 of secure execution controller 820 and when the code block is verified the bit in secure mode status register 810 placing the target device in secure mode are set and the code block 852 executed in secured mode on CPU execution unit 850. During execution of this code block 852 then, a memory access to an address may be made. Such a memory access may be received by secure mode controller state machine 880. It will be noted that the memory access may be received in a number of ways, for example, from the memory controller of the target device, from a "snoop" of the system bus, from a translation lookaside buffer or other cache management device, or in a wide variety of other manners.
[0185] When secure mode controller state machine 880 receives such a memory access, it may determine if the memory access is read access or a write access (step 803) and if it is determined that the memory access is a read access it can then be determined if the address corresponding to the memory access has been previously stored in thee data cache 840 (step 805). This determination may be made, for example, based on whether a cache hit or a cache miss occurs. Again, this data may be obtained in a number of ways, such as from a memory controller, a translation lookaside buffer or other address resolution mechanism, etc. [0186] Moving to FIGURE 9, if the memory access is to an address that is not been previously placed in the data cache 840 (e.g., a cache miss), the read may be allowed (step 807). The data at the desired address can then be read in from main memory 890 and placed in a line 846 in data cache 840 of a page 842 used by the currently executing process. As illustrated in the depicted example, the data associated with the requested address is read from main memory 890 and placed in cache line 846a of page 842a.
[0187] Referring to FIGURE 10, if the memory access is a write (step 803), it can be determined if the write is to an address that is located within data cache 840 (step 813). If the address is not within the data cache 840 the write may be disallowed (step 815) or the write may be allowed, but to the data cache only (e.g., any data cache write-through options may be disabled). Now looking at FIGURE 1 1 , if the write is to an address that is located within data cache 840 (step 813), the write may be allowed to the appropriate cache line 846 in the page 842 containing that cache line 846. For purposes of this example, assume that the memory access is a write to the data in cache line 846a of page 842a. The secure mode controller state machine 880 may also set the security bit of the cache line 846 which was written (step 817) (in the example illustrated security bit 848a of cache line 846a of page 842a has been set).
[0188] Moving to FIGURE 12, if the write is to an address that that is located within data cache 840 (step 813), it can be determined if a secure process descriptor associated with the executing process may be generated (step 819) and stored (step 821 ) in the data cache 840 in association with the page 842 containing the cache line 846 to which the write was made. It should be noted, that these steps may only occur if such a secure process descriptor was not previously associated with the page (step 823).
[0189] In one embodiment, the secure descriptor for the executing process may be the
authorization code used to verify the code block that is being executed by the current process. This authorization code may be resident in authorization code register 812 of secure execution controller 820. Thus, the authorization code in authorization code register 812 may be stored in the secure descriptor area 844 of data cache 840 associated with the page 842 containing the cache line 846 to which the write was made. In the example illustrated the authorization code in authorization code register 812 is stored in secure descriptor area 844a associated with page 842a containing cache line 846a.
[0190] Looking at FIGURE 13, if a memory access received by the secure mode controller state machine is a read (step 803) of a datum that was previously stored in data cache 840 (step 805) (e.g., a cache hit) it can be determined if the security bit 848 associated with the cache line 846 being accessed has been set (step 823). If the security bit has not been set (step 823) the read from data cache 840 may be allowed (step 825).
[0191 ] Moving on to FIGURE 14, if the security bit 848 associated with the cache line 846 being accessed has been set (step 823) the secure process descriptor associated with the page 842 of the cache line 846 being accessed may be obtained (step 825) from the secure process descriptor area 844 associated with the page 842 containing the accessed cache line 846. The secure process descriptor associated with the process can then be obtained (step 827) and can then be determined if these secure descriptors are the same (step 829).
[0192] As discussed the secure process descriptor for the executing process may either be the authorization code resident in authorization code register 812 of secure execution controller 820 or some derivative value thereof. Thus, the secure process descriptor obtained from secure process descriptor area 844 associated with the page 842 containing the accessed cache line 846 may be provided to hardware compare block 814 of secure execution controller 820 where it is compared either with the authorization code resident in
authorization code register 812 or some derivative value thereof. In the illustrated example, the secure process descriptor in secure process descriptor area 844a associated with page 842a containing cache line 846a has been provided to hardware compare block 814 where it is compared either with the authorization code resident in authorization code register 812 or some derivative thereof. If the secure process descriptors match the read may be allowed (step 831 ) otherwise it may be disallowed (step 833) and another action taken. Examples of such other actions may be providing a garbage or a fixed value, indicating a cache miss, etc.
[0193] While embodiments have been illustrated in conjunction with using an authorization code as a secure process descriptor for process executing in secure mode, as discussed above, almost any type of compound key generated from almost any desired precursors (e.g., using the secret key of the target) may be used. In such cases, other blocks of secure execution controller may be involved in the generation or comparison of such a secure process descriptor, including for example a hardware hash block of secure execution controller 820.
[0194] In certain cases, while writes outside the data cache may be disabled, the working set of a secure process may overflow the data cache. In one embodiment, any external data transactions between the CPU execution unit and an external memory bus may be encrypted during execution of a secure process (including, for example, page out operation or the like). For such an encryption process, the secure process descriptor itself or some derivative value thereof may be used as the key and that secure process descriptor or the derivative value may itself be encrypted (e.g., using a derivative value of the target device's secret key) and stored in the main memory as a part of the data set. As an advantage, there may be substantially no significant architectural changes required to implement this mechanism. The most important implications are those regarding performance in the case where the secure process has a large working set and it is frequently interrupted. In such embodiments, a subset of the working setoff the process that is considered "secure" may be created and only that portion of the cache corresponding to that "secure" working set encrypted when it is written out to main memory.
[0195] However, in a system where security is a paramount concern and where the working sets of a secure code blocks may be large, the entire working set may be encrypted prior to the point where it is placed on a memory bus. In such cases, the storage to main memory may be run asynchronously in parallel with another process (e.g., a DMA unit with integrated hardware accelerated encryption) and thus, it could be designed to have a minimal impact on the performance. In some embodiments, a separate "working set encapsulation" routine (which may itself be a secure code block designed to execute in secure mode) may be used to perform the encryption prior to allowing the working set data to be written out to main memory. Again, minimal, if any, architectural changes may be required to integrate this mechanism into almost any existing CPU.
[0196] In some embodiments, the key used to perform the encryption of the page(s) or cache lines being stored to main memory may be a derivative of the authorization code. Specifically, in one embodiment, the authorization code for the process executing in secure mode whose pages that are being stored in main memory may be used to generate a compound key (e.g., a message authentication code) using the hardware hash block using the secret key of the device and another precursor. The resulting compound key may itself be used to encrypt the authorization code to generate an ephemeral key. This ephemeral key may be used to encrypt the page of data cache to be stored in main memory which is then stored in main memory with the authorization code and the precursor used to generate the compound key.
[0197] Almost any symmetric encryption mechanism may be utilized to encrypt the pages being stored to main memory. For example, a hardware encryption block (e.g., an AES hardware block) may be utilized. Additionally, this encryption may be accomplished by encryption code running in secure mode. In such cases this encryption code may need to access cache lines or pages of the data cache associated with another process that was executed in secured mode (e.g., the data in the cache that is to be encrypted). To allow this access by such an encryption process in order to effectuate encryption of those cache lines, in one embodiment, the encryption process may use a derivative of a calling argument as its encryption key. Such a derivative may for example be the output of the hardware hash (e.g., the message authentication code) that may have been generated by using the calling argument along with a secret key and some other datum, such as a secure process descriptor of the parent or child routine, as described above. Thus, the actual key used to encrypt or decrypt the data by the encryption process may be a derivative of the passed in key, but one that can only be correctly generated by a single secure process. The encrypted pages may then be stored out to main memory without exposing any of the secure process' input or output arguments to any other processes (secure or otherwise) except those directly involved in the input/output argument transaction.
[0198] It may now be helpful to discuss certain aspects of digital security. The current state of the public art in digital security algorithms can be readily gleaned through a perusal of online information or via the various publications and patents which examine this subject, some of the more recent of which include U.S. Patent No. 6,327,652; U.S. Patent No. 6,1930,670; U.S. Patent No. 6,412,070; U.S. Patent Publication No. 20020013772; U.S. Patent No. 6,226,742; U.S. Patent No. 6,101 ,605; and "Architectural Support for Copy and Tamper- Resistant Software, by David Lie, et al. (Proceedings of the 9th Annual Conference on Architectural Support for Programming Languages and Operating Systems aka ASPLOS-IX, Cambridge, MA. 2000) all of which are fully incorporated fully herein by reference.
[0199] Prior art systems utilize a few basic operational categories of digital data encryption and decryption technologies. These categories are based on the use of the security algorithms themselves and are independent of the actual mechanism for encrypting or decrypting the actual data. These well-known technologies and widely described classifications and technologies are:
One-Way Hashing mechanisms and/or Message Digests.
Message Authentication Systems
Digital Signatures
Secret Key Encryption Systems
Public Key Encryption Systems
[0200] The means by which these technologies are used in a given security system is known as a security protocol. Note that the security protocol is independent of the actual underlying mechanics of how the various functions are implemented. As such, even a perfectly secure encryption algorithm may potentially be used inside a security protocol that compromises overall security in such as way as to defeat the secure aspect of the encryption technology itself. Consequently, the overall security of any given security system is dependent not only on the relative strength of the underlying security technologies but also by the way in which these security technologies are put into use. Prior attempts at implementing security system have made (artificial) distinctions between the various types of bit streams to be protected. On a fundamental level, all binary digital data can be reduced to a stream of 1 's and 0's (a bitstream), which can be stored and retrieved in a manner which is completely independent of the intended purpose or interpretation of that bitstream. The fact that the data contained in any particular bitstream is used to convey a piece of text or a photograph or even a piece of executable object code is not relevant to the manner in which or the device where the bitstream is stored.
[0201 ] Thus, there is a need for security protocols which do not depend on an arbitrary distinction between digital data types. These protocols, which may utilize industry standard security technologies and other types of security standards to better and more efficiently protect digital content, may themselves be expressed in terms of a digital bitstream. Thus, such a protocol would be equally capable of securing itself. This self-referencing behavior is known as the property of "recursion" and such a security protocol may be termed a "Recursive Security Protocol".
[0202] Attention is now directed to systems and methods for security protocols intended to protect digital content. These security protocols are useable for any digital content, and can also support the concept of identity tracing that is normally associated with a traditional watermarking scheme without requiring that the actual digital content be altered. Since these protocols are based on the premise that all digital bit streams are equal, it can even be used in a recursive fashion in order to control access to updates to the protocol itself. In other words, the protocol makes no distinction between types of digital data, whether the data be media streams to be protected, the executable code required to play those streams, the encrypted executable code required to play those streams, the executable code required to decrypt the encrypted code required to play those streams, the keys to be used along with the decryption code, etc., etc. The digital nature of these data is all that is important to the protocol. Thus, since the nature and/or use of the digital data are of no concern to the security protocol, the protocol is capable of protecting itself.
[0203] This capability means that the security protocol can be updated (to fix recently discovered security holes, for example) without requiring any changes to the hardware on which it is running, even during execution. The "older" security system is "subsumed" as a part of the newer security system (i.e., you never have to strip the old protection "wrapper" away in order to add a new, potentially more secure level of protection to the entire system). Thus, the entire system is encapsulated in the latest, most secure encryption and/or access control system. Not only may new keys be added, but entirely new security and/or encryption algorithms can be added on top of existing systems as well. [0204] This flexibility allows the protocol to support a number of business models, including Time- limited Rental, Pay-per-View, Multiple Versioning, Machine-dependent License Revocation and Permanent Transfer of Ownership from one user to another.
[0205] Though a copyrighted software application is utilized in an exemplary embodiment, it will be understood by those skilled in the art that the same methods and systems can be used to provide security to any bit stream whatsoever, including text, video and audio data, source and object code, etc.
[0206] The basic functions which embodiments of the security protocol are designed to provide include (but are not limited to) the following:
Fair Use ("Time shifting", "Space Shifting" and archival backups)
Incremental Upgrades
Temporary Transfer of Ownership
Permanent Transfer of Ownership
Time-Limited Access
Usage-limited Access (Number of Times used)
Device-specific License Revocation
Data or Stream-specific License Revocation
[0207] For many security systems, one of the primary mechanisms for protection of the intellectual property contained in a copyrighted work is simple access control. However, if such a mechanism is ever bypassed, then the protection afforded by even the most sophisticated access control mechanism is of very little value. This is not to say that access control is a useless mechanism, but simply that it is not a total security system in and of itself. The fact that a number of copyrighted media streams are freely available for public consumption on the internet is testimony to the fact that such security systems can almost always be bypassed. This kind of access control also makes it more difficult to establish a mechanism to make backup copies of legally purchased copyrighted works, which is a necessity if the original is ever in danger of being destroyed. Thus, the security protocol described herein does not require any sort of access control system in order to make it useful.
[0208] The security protocols described concentrate on controlling the expression of the
copyrighted work, not on the digital data that make up the work itself. As such, the protocol makes no distinction between digital data that is used to encapsulate a copyrighted work or other digital data that is used to describe how that work is to be interpreted. As a result, the protocol can even be used to encapsulate other security protocols. Basic Operational Description:
[0209] Embodiments of the security protocol are designed to enable the author of a piece of
software to have a high degree of confidence that their code is protected from disassembly by those who would like to copy or otherwise misappropriate its algorithm. They are also designed to protect this code from modification by those who would attempt to alter its functionality. One of the methods by which these primary characteristics can be
implemented in an otherwise general purpose computing system is discussed in a following section. An additional property, which occurs as a byproduct of these two primary functions, is the ability to control the conditions under which the software can be run (i.e., when and how and on which machine or machines the code is allowed to be executed). The first of these functions may be accomplished by adding a tamper-resistant timer element to the system. Others are accomplished by means of implementing a secure data structure, which is used to indicate the desired conditions, which must be met in order to execute the code block in question. Since this data structure is not hardware specific, it can be used in a variety of ways and is able to be modified by updating the software that is used to interpret it. Hardware specific features utilized to implement the protocol more efficiently are discussed, and examples of how these features can be put to use in order to support the protocol are given. Finally, we will show how the protocol can be used to protect a copyrighted work.
[0210] Embodiments of the security protocol depend on the ability to encrypt a digital bitstream in such a way as to only allow it to be decrypted by its intended recipient. This is a well- understood problem and is the basis of a large number of industry-standard encryption algorithms. However, there are two additional factors which should be considered for use with embodiments of the security protocol: the fact that it is helpful if the core of the protocol is able to be fit in the (relatively) small confines of a typical on-chip Instruction Cache (I- Cache) and the fact that it be capable of running in a semi-autonomous manner. In other words, it is useful if the protocol is small and does not require the use of a central security server for normal day-to-day operation.
Hardware:
[021 1 ] An example overall block diagram of a device that is capable of executing this security
protocol is shown in FIGURE 2 above.
Operational Details:
[0212] The manner in which embodiments of the security protocol operate can be broken down into several discrete processes: System Initialization, Secure Code Generation and Mass Distribution, Secure Code Loading and Execution, Key list data structure Construction, Temporary License Transfer, Permanent License Transfer, System Ownership Transfer, License Revocation and Security System Updates. Each of these is discussed in turn. It should be noted, however, that the examples described below are chosen for the purposes of simplicity of discussion and are not necessarily the most efficient (nor are they the only) manner in which this protocol can be implemented.
System Initialization
[0213] This is the step in which the target unit's secret keys 104 are set to some initial value. This procedure can be accomplished in one of several locations (for either of the two secret keys, but for logistical reasons, it should be the final step in the assembly process where either the serial number or the secret key can possibly be changed. In the case where the unit's 100 serial number is stored off-chip, then this procedure is most likely performed at the point of final assembly. If the serial number 106 for the unit is stored on-chip, then it would be most practical to carry out this procedure at the last point in the chip manufacturing process (i.e., after the chip has been packaged), so that any post-production or burn-in fall out has had a chance to winnow out the non-functional parts. This way, the amount of data that must be kept secure is minimized. Since the security of the entire protocol may be based on that of the unit's secret keys 104, the initialization procedure should be undertaken at a point where physical security is possible.
[0214] The primary secret key should be initialized (or "burned" into the device) in a different
procedure than the one that is used to supply the secondary secret key. Although, in practice, this secondary key will be known at some point (since it is programmed into the unit at some point during the manufacturing process), the unit with which it is associated should not be recorded anywhere once it is stored on the target device 100. For auditing purposes, it may potentially be desirable for the total set of secondary secret key values to be examined independent of knowing which parts hold which keys (to test for randomness of the distribution, or for some other reason). In order to maintain the secure nature of the system, however, it is desirable that the device which programs this second secret key into the unit never have any means of associating the secondary secret key to either the first secret key or to the target device serial number 106. Also, both of these secret keys should be implemented in a tamper-proof manner, for reasons, which are described later. It is not material in which order these two secret keys are initialized. Following the initialization procedure described in the exemplary embodiment, the only location (other than on the actual chip) where the target devices' serial number 106 and their associated primary secret keys are co-located should be on the secure server at the licensing authority. Secure Code Generation and Mass Distribution
[0215] Referring briefly to FIGURE 21 , in an example scenario, let us suppose that a developer 2120 wishes to produce an application to run under this protocol, which will be reasonably immune from disassembly and can only be executed on a specific device. Each registered developer 2120 has a public key / private key pair which is used to authenticate any messages which they use to communicate with the licensing authority's server as well as to create signed Message Authentication Codes or MACs (typically referred to as digital signatures) which can be used to authenticate any published code block or other bitstream.
[0216] After an application is debugged, it is encoded using an application-specific encryption
algorithm and key(s), which are known only to the original developer. This application- specific algorithm and key(s) can either be a symmetric (secret) key system or an asymmetric (PKI) key-based system. Attached to the end of the encrypted block of code is a MAC, which is then signed by the developer 2120 using the private key of their published public key/private key pair (which thus forms an unambiguous digital signature for the encrypted code block). Either the digital signature or the original MAC and the corresponding Code specific ID number may be supplied to the licensing authority. The application developer 2120 may also choose to supply the appropriate decoding key(s) as well (we will discuss the tradeoffs of this decision in a later section of this document).
[0217] Note that if the application-specific algorithm is an asymmetric encryption system, it does not necessarily need to be encrypted using the same published PKI key pair that is used to generate the signed Message Authentication Code (the digital signature). However, the MAC that is stored at the end of the code block should be generated using a known hashing algorithm and must also be signed using one of the developer's published public keys (thus forming the digital signature). This allows the target to verify the authenticity of the MAC using a known hashing function and a known public key.
[0218] Moving now to FIGURE 18, all application-specific encryption key data structures 1810 may contain a number of extra fields (in addition to the decryption key itself 1820). One of these fields may comprise a timestamp 1830 and an associated mask value 1840. The second may contain a "countdown value" 1850. The mask value 1840 is used in conjunction with the other two fields 1830, 1850 in order to determine when the key is valid. It should also be noted that it is not relevant to the protocol exactly how many bits are allocated to each of the fields.
[0219] Note that the timestamp value 1830 can be used in several ways, depending on the bit pattern that is stored in the timestamp mask 1840 field. The timestamp mask 1840 value allows the developer 2120 to select some subset of the timestamp figure that is ignored when performing the comparison with the target unit's 100 current time. As an example, however, if we assume that the smallest resolution which is supported by the timestamp field 1830 is one second, then by masking out the lower five bits of the timestamp data 1830, a particular key data structure 1810 can be generated which is only valid when used over the course of approximately 32 seconds starting at the time which is stored in the timestamp field 1830. The overall functionality of the security protocol is not dependent on the actual resolution of the lowest order bit of the timestamp field 1830.
[0220] There may be other bits that are associated with the mask field 1840, some of which can be used to indicate whether the key is valid before or after the value specified in the timestamp 1830. Yet another mask field 1840 bit can be used to indicate how the timestamp 1830 and the "count-down" values 1850 are associated. For example, this would be useful in the case where the intent of the application developer 2120 was to limit the use of the software to a certain number of iterations either prior to or after a certain date, rather than simply tied to a certain date and time window. Of course, any combination of these conditions can be constructed, so the protocol is quite flexible in this regard. In addition, further flags can be included in this data structure to indicate other properties, such as how many legal copies of the keys may be simultaneously distributed from the original target unit 100 to others. This would be useful in the case where a multiple-copy license were desired, such as is seen in a digital library, for example.
[0221 ] A flow diagram representing one embodiment of the encryption process can be seen in
FIGURE 19. Note that there is no substantive difference between the process that would be used to distribute a digital media stream or a software application (such as the decryption instructions used to interpret that media stream). In either case, there are a couple of different options for distributing the encrypted code block(s) 1910, 1920; either via an online server or on serialized discs (such as a standard DVD). In the latter case, the developer 2120 can then choose to pre-register the individual serial numbers of the mass-produced discs with the licensing authority 21 10 (or not). If so, the serial numbers could be permanently affixed to the discs either by burning them into the Burst Cutting Area (in the case of a DVD) or by ink-jet imprinting in the case of a standard CD. Note that the developer 2120 cannot embed these serial numbers into the data area of the CD or DVD, since the same serial number would be replicated on all of the mass-produced discs. If some sort of a hybrid format were used, where part of the disc could be mass-produced and another portion written once, then this would be another potential method of distributing the discs with individual serial numbers. In any case, a machine-readable serial number is certainly preferable, since it is less prone to errors during the registration process. [0222] If the developer 2120 chooses not to register the media serial number with the licensing authority, then there may be some other manner by which the proper encryption key(s) can be associated with the application or media stream files. Thus, the application developer 2120 may either register the code-specific ID or an associated media serial number. In the former case, then the application can be distributed freely (i.e., not tied to a specific release format and media).
[0223] In the case of the individual serial number mechanism, the privacy of the end user is
maintained, since the licensing authority 21 10 has no need to know (and potentially no indication of) which application (or media stream) is associated with which serial number(s). In the case where the developer 2120 registers an application ID (or a media stream ID) along with its associated key(s), then it is possible for the licensing authority 21 10 to know which application(s) or media streams are "owned" by a particular end user. On the other hand, this potential lack of privacy is counterbalanced by the additional convenience and cost savings of not requiring the developer 2120 to manufacture and distribute physical media. Note that the term "physical media" does not necessarily mean a disc. This function could be accomplished just as well by using a printed manual (or even a simple registration form) with an individual serial number sticker attached to it. All that is required is that the developer 2120 must produce some object with a unique serial number, which is supplied to the end user. The purpose of this serial number is to act as a bitstream registration number. We will discuss how this serial number is used in the protocol in a following section.
[0224] For the example shown in FIGURE 19, both the encrypted software application (or media stream) 1910 and the machine dependent decryption software 1930 are distributed using the same mechanism. It is not a requirement of the protocol that this should be the case and either or both of the encrypted code blocks 1910, 1930 can be distributed on-line or by pressing a disc. It should be noted, however, that in the case of a digital media stream, the media stream itself is most likely the larger of the two blocks 1910, 1930 by several orders of magnitude. Thus, in that case, it makes the most sense to effect the distribution of at least this block in a mass-produced disc format. In many cases, there may be enough room on such a disc to fit the companion encrypted code block (the one which contains the instructions of how to decode the first block) as well as the primary encrypted code block. It should also be noted that neither of the two data sets would be likely to undergo any changes after publication, so there is no fundamental requirement that they must be distributed online. As such, they are both well-suited to a mass-produced disc based distribution mechanism. Having both of them on the same disc also makes it easier to associate one with the other in an unambiguous fashion. Secure Code Loading and Execution
[0225] In the case where the distribution mechanism is accomplished via an actual disc, the
consumer can purchase the disc containing the application in exactly the same manner as a traditional software purchase. Of course, the end-user would not be able to run the encrypted code block unmodified on the processor of the "target" unit. When the user attempts to run the application on their machine, the CPU 120 loads the encrypted software block and uses the digital signature (the "signed" MAC) stored at the end of the code block along with the software developer's public key to verify that the code block in question is genuine. This is where the first hardware modification to an otherwise general purpose CPU 120 may come into play. The process for loading and decrypting such a block of secured code is shown in FIGURE 20.
[0226] In order to make sure that the hashing function is computed correctly (and furthermore, that the comparison between the generated message digest and the "real" message digest is valid), the CPU 120 must perform this hashing function in a secure manner. Thus, the hashing function must either be generated directly by the hardware of the decoder unit or the hashing function itself must be computed using a block of "secure" code, the operation of which cannot be tampered with by an otherwise "non-secure" program.
[0227] Note that in the software-based hash case, this block of secure code should be considered as a part of the unit's 100 security system and, as such, may only be able to be downloaded to the player via a secure transaction between the unit 100 and the licensing authority 21 10. Interestingly enough, the establishment of a "secure" hashing function can be accomplished via the same secure protocols described herein. This recursive behavior for all aspects of the security system is what enables a software-based version of this protocol to be extremely flexible (and thus, updateable) in its encryption/decryption architecture.
[0228] If the message digest calculation is fixed in hardware, we can potentially gain some degree of security, but this comes at the expense of flexibility. If a dedicated hardware block is used to generate the hash value, and then some weakness in the hashing algorithm is discovered at some point after the chip is manufactured (or if there is some bug in its implementation), then there is no opportunity to address the problem after the fact. That is not to say that we cannot use some kind of hardware acceleration of the software-based hashing function (such as a programmable S-Box structure) in order to speed up the process. However, in that case, the hardware should ideally be sufficiently general purpose to support a large variety of one-way hashing functions. [0229] It should be noted, however, that the security of this protocol is ultimately dependent on the lowest-level function that is provided as a part of this secure code loading procedure. The low level features (such as a secret key or a primitive operation which is used in a hashing function) are combined together in different ways to produce higher level functionality, such as a signed message digest. In turn, these higher level functional blocks are used to provide even higher level utilities, such as identity verification. This process of building higher-level functions on top of more primitive layers is known as building a "Chain of Trust". The flexibility of the system lies in placing the point at which the security related functions can be modified as low as possible within this hierarchy. However, at some point, the fundamental primitive operation(s) upon which this chain is based must be atomic in nature (i.e., this is the minimum level of functionality which must be implemented in hardware). The exact choice of this point of hardware granularity is, for the most part, an implementation detail, and the overall operation of this protocol is not dependent on this aspect, given the conditions above.
[0230] Once the encrypted code block 1910 is loaded into the target's memory space 1 10, and the message digest is calculated, the result is then compared with a message digest which is calculated by decrypting the digital signature 1940 which was stored along with the encrypted code 1910 with the developer's public key. If the two are a match, then the target unit 100 can be certain that the encrypted code block 1910 is genuine (or at least that the code was distributed by the developer 2120 whose public key was used to decrypt the digital signature).
[0231 ] At this point, the target 100 then sends a secure message to the licensing authority 21 10 requesting a copy of the decryption key(s), which will be used in concert with the recently verified encrypted code block. As a part of setting up the secure connection with the licensing authority, the target unit 100 generates a temporary public/private key pair (the public portion of which is supplied to the licensing authority 21 10 server). The details of the key exchange procedure are well known and we need not go into the exact mechanism by which this is accomplished in this discussion. In any case, it should be noted that the overall network traffic between the target unit 100 and the central server at the licensing authority 21 10 is limited to a reasonably small data set, since it consists of a couple of key transfers, the code-specific ID and the MAC which was stored along with it.
[0232] Assuming that the code-specific ID 260 is one that the licensing authority 21 10 recognizes, there may be two possible courses of action, depending on whether or not the application author has already provided the licensing authority 21 10 with a "clear" copy of the requested decryption key(s). In the case where the developer 2120 has not provided the licensing authority 21 10 with such information, then the central server transmits a copy of the target device's temporary public key (as well as the code-specific ID 260 in question) to the application developer's server. At that point, the developer's server responds to the licensing authority 21 10 server with a message containing the requested decryption key(s) (encrypted with the target's temporary public key) and a message digest generated from the properly decrypted code. In this manner, only the target device 100 can decrypt the message to obtain the application-specific decryption key(s) and the licensing authority 21 10 will not ever have access to the decryption key(s) in clear form.
[0233] Although the message digest can be pre-computed and stored on the licensing authority's server, the fact that it may be provided by the developer 2120 during the transaction is of potential use if the hashing function (which is used to generate the message digest) should ever change. If this should happen, the developer 2120 would need to provide updated versions of the decrypted code message digests to the licensing authority 21 10 either prior to or during the actual transaction with the target device 100. The developer 2120 must provide this information since the licensing authority 21 10 should never have access to the original (decrypted) code. As before, the amount of network traffic between the licensing authority's server and the developer's server is still quite small. The encrypted key that was received from the developer 2120 is then encrypted yet again with the target device's primary secret key prior to transmission from the licensing authority 21 10 to the target. This second encryption could actually be carried out on the developer's side as a part of the other transaction, but in that case, the developer would potentially have access to the target unit's primary key (unless both keys were somehow combined), which would pose potential loss of privacy issues for the end user.
[0234] Note that in the case where the application developer 2120 wishes to stay "out of the loop" for transactions between the licensing authority 21 10 and the target device 100, they can simply provide the licensing authority 21 10 with a copy of the relevant decryption key(s) in clear (unencrypted) form and the associated MAC for the decrypted code block (the value of which must be updated each time the hashing algorithm is changed). Thus, the central server at the licensing authority 21 10 would be able to act autonomously and would not be required to establish a communications link to the developer's server in order to fulfill a key request from a target unit 100. However, this poses a potential security risk to the developer, should this "clear key" information ever be compromised, either intentionally or
unintentionally by the Licensing Authority.
[0235] The flow diagram for the whole key encryption/decryption process is outlined in FIGURE 21 .
In this case, the clear key would still be encrypted prior to transmission (as above) with both the target device's temporary public key and then again with the target's primary secret key. At this point, the target device 100 has the proper decryption key in a doubly encrypted format. In the case where the licensing authority 2110 does not have access to the application specific key 2150 information in the clear, then it should not be possible for anyone other than the intended target device 100 to be able to reproduce this key data in clear form, since the secret key for each unit 100 should only be known to the licensing authority 21 10, and the private key for the transmission is known only by the target 100.
[0236] At this point, however, the encoded decryption key(s) which the target 100 receives from the application developer 2120 cannot yet be stored safely in the open at the target 100 (e.g. in a flash ROM or backed up on a hard drive). The problem is that the target device 100 would also have to store a copy of the temporary private key along with the encoded decryption key(s), which were transmitted from the licensing authority 21 10. If someone at the licensing authority 21 10 were to then gain access to these two pieces of data by some means, then they would potentially be able to reconstruct the decrypted application specific key 2150 (given that they might have access to the target device's 100 primary secret key as well).
[0237] This is the point where the target device's secondary secret key comes into use. Recall that this secondary secret key is not known to anyone other than the decryption unit of the target unit. Thus, once the temporary private key is used to decrypt the key, which was supplied to the target 100 from the licensing authority, the secondary secret key is used to re-encrypt the application-specific key prior to its use (and/or archival).
[0238] The target can then use the application specific (clear) key 2150 in order to decrypt the code block (or media stream). Thus, the only two places where the application code exists in clear form are at the original developer 2120 itself and inside the "secured" portion of the target device's l-Cache 1 10 (where it can only be executed and can never written back out to memory in clear form). This allows privacy between the user and the licensing authority 21 10. In other words, the licensing authority 21 10 does not have to know what it is that the user has a license to (an enormous privacy issue), but it is still able to act as a repository (or backup) for the user's key list in the case where their unit 100 is damaged or stolen or otherwise rendered inoperable.
[0239] As a check to verify that the decryption process has been performed correctly, the message digest of the properly decrypted code is then compared with the message digest generated by decrypting the digital signature, which was forwarded from the original developer 2120 through the licensing authority 21 10 to the target unit 100. As was mentioned earlier, this digital signature is created by encrypting the message digest of the unencrypted code block with the application developer's private key. Alternately, this digital signature can also be encrypted again by the developer 2120 using another temporary public key 2130, which was supplied to the licensing authority 21 10 when the connection was established. In any case, the correct message digest can then be decoded by the target device 100 by decrypting the digital signature with the developer's public key. If this message digest matches the MAC of the decrypted code block, then the code is considered to be genuine and it is allowed to run on the target 100. This message digest may then be re-encrypted with the target unit's secondary key 2140 for archival along with the re-encrypted application specific key 2150.
[0240] The final step in this procedure is that the newly encrypted (with the target device's
secondary key 2140) version of the application specific key 2160 is retransmitted back to the licensing authority 21 10 server for archival purposes. This transmission serves a few purposes. First, it is an acknowledgement that the target device 100 was able to properly decrypt the code block. Second, it is necessary for the licensing authority 21 10 to have a copy of this encrypted key 2160 in order to deal with the case where the end user suffers some sort of catastrophic data failure and they have neglected to make their own backup copy of their access keys. The licensing authority 21 10 can then act as a backup storage facility for any particular user. Yet another reason for this procedure is in order to deal with the case where a particular target device 100 changes ownership from one user to another or if the user wishes to upgrade their target device 100. This kind of permanent transfer of ownership can involve the transferal of all of the licensed application keys for that unit 100 (in which case, there is nothing which needs to be done other than re-registering the unit under the new owner's name). However, if the user wishes to transfer permanent ownership of their key data from the first to the second device, then this may be accomplished by means of a secure transaction between the licensing authority 21 10 and both of the target device.
[0241 ] The other piece of information that the target device 100 transmits back to the licensing authority 21 10 server is the message digest of the target device's newly updated key list data structure 2210 (as depicted in FIGURE 22). This is both an acknowledgement of the newly updated key list data 2210 structure and is also used to verify the equivalence of the key list data structure 2210 associated with that particular target device 100 on the licensing authority 21 10 server and on the target device 100. The exact construction of this data structure will be described in the following section. We will also discuss methods by which permanent transfer of ownership of a particular key or set of keys is accomplished in a later section.
[0242] It should be noted at this point that the process outlined above is not the only manner in which the protocol can be used to transfer the application specific key 2150 from the developer 2120 to the target device 100. For example, the actual key transfer transaction can involve a direct connection only between the target 100 and the application developer 2120. However, in that case, a connection must be established between the developer's server and the licensing authority's server in order to contribute the device specific encryption information to the transaction. There are a number of mechanisms by which this protocol can be made to work in a secure fashion, and the example discussed above is just one of these. However, the common thread is that all three parties must act together in order to ensure that the key data, which is transferred to the target 100, is only useable for that target device 100. Note that the structure of a key can be set up to have two pieces: a hardware-specific part as well as an application-specific part. It is not a requirement that these two pieces be completely inseparable. If they are inseparable, then we get the properties exactly as discussed earlier. If, however, there is a way to make the key pieces independently operable, then we can enable a global set of copy and use restrictions that could be independent of the actual code or of the actual target device 100. In other words, any developer 2120 could publish an application or media stream which had no restrictions on distribution, but which could not be read; only executed. This could be useful in the case where the licensing authority 21 10 wanted to send out a security system update that would run on all devices, regardless of the manufacturer. Another example of this would be the broadcast of a publicly available media stream while still maintaining control over the copyrights to that stream. Similarly, a publisher could distribute an application, which anyone could read and/or copy, but which would only execute on one specific target device 100 or set of devices. This could be useful for sending out an "update this specific class of device" message, for example. Another possible application is to send out an application, which would run everywhere and had no restrictions on distribution. This would be similar in nature to publishing the source code for a particular application (i.e. open source distribution). The different classes of security which are enabled by a separable H/W-specific and S/W-specific key structure are illustrated in Table 1 .
-Specific key segmen
Hardware-Specific
key segment
Figure imgf000060_0001
* i.e., Locked to a specific serial number " i.e., will work anywhere
(or to a range of numbers)
Table 1 . Separable hardware-specific and application-specific key structure
Key list data structure Construction
[0244] Looking now at FIGURE 22, the data structure 2210 containing the list of application or media-specific keys, which are licensed to a particular target device 100 is a valuable commodity and, as such, it should be able to be backed up by the owner. Since the individual keys are encrypted with the target's secondary secret key (as described above), the list is only useful to the unit to which the keys are licensed. However, we need to be able to make sure that this data structure 2210 is secure from tampering, corruption and/or outright loss. In the case of a lost key list data structure, the entire data structure 2210 can be recovered by requesting a new copy of the key list for that particular target device 100 from the licensing authority 21 10, as was described earlier. In the case where a temporary change has been made to the key list data structure (we will discuss the reason for such a scenario in the section following this one), then the protocol may accommodate a means for identifying such a change as being temporary. Finally, we include some tamper-resistant mechanism for validating the authenticity, timeliness, and validity of the key list data structure 2210.
[0245] With these requirements in mind, we can construct a secure key list data structure 2210 that exhibits all of these qualities in a manner like that which is shown in FIGURE 22. As always, the example shown is not the only method by which all of the desired properties can be included in such a data structure. Nonetheless, the particular data structure illustrated in FIGURE 22 does, in fact, fulfill all of the basic requirements of the protocol.
[0246] There are a few basic precepts that should be noted in the diagram above. The first is that the top-level encryption of the key list data structure 221 0 must be performed with the target device's primary secret key. There are a couple of reasons for using this particular key, but the main issue is that the licensing authority 21 10 must be able to regenerate the encrypted form of this data structure independently of the target device 100 in the case where the local copy of this data structure must be restored. If any other key is used to encrypt this data structure (such as the target's secondary secret key, for example), then when the target needs to make a change to the data structure (as is the case when a key is added to the list), the entire list must be transferred to the licensing authority 21 10 for backup purposes. This could potentially greatly increase the amount of network traffic that must be transmitted back to the licensing authority 21 10 and is not necessarily the most efficient use of the channel bandwidth.
[0247] Also, it is desirable that this key list data structure 2210 be used for the storage of security system-related keys, in addition to being used for the storage of standard application or media stream specific license keys. Since this data structure is able to be regenerated by the licensing authority 21 10, in cases where it is desirable to update the security software which runs on the target device 100, it would be both more secure and more efficient (from the standpoint of code storage requirements on the target device 100) if the same key list data structure 2210 could be used for both functions.
[0248] The second issue is that the encrypted version of the key list data structure 2210 includes a message digest of the original key list data structure 2210. It should be noted that although each of the individual keys are encrypted, other pieces of the list itself are not separately encrypted at the point when the message digest is calculated. Following the message digest calculation, the entire key list data structure 2210 (including the message digest) is then encrypted with the key value and algorithm that are identified by the top-level (or master) key. This is done in order to prevent a malicious third party from tampering with the list, calculating a new message digest and then substituting the modified list for the genuine one. When the key list data structure 2210 is read into the memory space of the target unit 100, this (decrypted) message digest is used to verify the authenticity and validity of the key list itself in the same manner as the way that a MAC is used for any other secure encrypted code block. The fact that all of the elements other than the individual keys are only encrypted with the master key means that the list can be traversed (and the list maintained) without having to have access to any keys other than the top-level key. Also, a key list inventory can be compiled with only a single pass through the decryption block.
[0249] A third principle which is of interest is that the individual application code or media stream specific keys can be made large enough to accommodate individualized keys for each target device 100. In the case where the code or the media stream is distributed by way of a mass- produced disc, this would mean that the application developer 2120 would need to issue a new code-specific ID along with the individual decryption key(s). Although this may be less efficient from the standpoint of trying to minimize the amount of data which must be transferred between all of the parties involved in the licensing process, it does add functionality to the protocol, including (but not limited to) the ability to track compromised decryption keys. We will also discuss this in a later section dealing with key revocation.
[0250] The next issue of note is that the key list data structure 2210 header shares the same set of characteristics as the application specific keys that make up the rest of the list. In fact, the header can be thought of as a master key 2220 for the rest of the key list data structure 2210 itself. Thus, the same principles of operation can be applied as far as how this key can be used to determine the management of the rest of the list. This includes time-dependent management of the security system of the target device 100. Thus, the target unit 100 can be forced to update its security system at pre-determined intervals, which is an extremely powerful concept all by itself.
[0251 ] The possibility also exists that the key list could contain a number of sections, each with its own master key 2220 (list header) and thus with its own independent encryption mechanism. As with any other key, the list header contains a code specific ID field 260, which can point to an encrypted code block that is used to interpret the key list data structure 2210. The whole list could then be contained within yet another master list, which includes its own master key (which is yet another list header). Thus, the entire key list data structure 2210 can be recursively defined. As before, this recursive property can be used to update the security system by creating new key list data structures to address shortcomings of previous versions of the same data structure. Since the security of the whole list is contained within the "outermost" (or most recent) security layer, then the security of the entire key list data structure 2210 is always based on the latest iteration of the security software.
[0252] Thus, the recursive property of the key list data structure 2210 is a compelling feature. It is also the reason that the exact implementation of the data structure, which was discussed in an earlier section, is not of great significance. The description provided above was simply an example that included the features that are the minimal subset of functionality required to make the recursive nature of the protocol work.
[0253] Independently of how it is structured, the key list 2210 may be maintained and/or updated under several common circumstances. These circumstances include (but are not limited to) the case where the status of one or more of the keys contained in the list is modified. There are a few basic mechanisms by which the ownership of a particular key 1 810 can be transferred from one unit to another and we will discuss these in later sections. In any case, however, the mechanism by which the revised key list is maintained can be split into two classes: those which require the intervention of the licensing authority 21 10 and those which can be carried out independently.
[0254] One of the primary operating concepts upon which this protocol is based is one of reducing to a minimum the amount of required network traffic between the central server of the licensing authority 21 10 and the individual target units. Thus, any temporary changes to the key list data structure 2210 (the reasons for which we will describe below) should be able to be maintained independently by the target unit 100. The main reason for this is that these changes would ostensibly occur more frequently than permanent changes to the device's security system (which should always only be accomplished by an interaction between the target device 100 and the licensing authority).
[0255] In any case, there must be some mechanism by which the target device 100 can keep track of the current state of the master key list data structure in an unambiguous manner. This can be accomplished by having two "master" lists. The first of these two lists (which we will call the permanent key list) is maintained by the licensing authority 21 10. This list is concerned with the "permanent" ownership of the application specific keys that are associated with the target unit 100 in question. The second list is of equal importance, but it is that which is concerned with temporary modifications to the "permanent" key list data structure. Note that these modifications can either be additions to the list or they can be deletions from the list. There are no necessary differences in the implementation of the data structures of the two lists themselves; the main differences occur in how they are maintained. It is desirable that there should be some way for the target unit 100 to recover from the event where the data from one or the other of these lists is either lost. This loss can be due to some catastrophic failure or due to the case where the information contained within one of the lists is somehow corrupted (either innocently or maliciously). We will discuss the implications of such "key list corruption" events in a later section. Although it is necessary that the permanent list can be restored by a connection with the licensing authority, it is not necessary (or even desirable) for the licensing authority 21 10 to be able to recover a particular target device's temporary key list. There are many reasons for this position, but the main reason is that the temporary key list is most likely updated much more frequently than the permanent key list and we wish to keep the amount of required network traffic between the central licensing authority 21 10 and the target units to an absolute minimum. Nonetheless, it may be potentially desirable for the licensing authority 21 10 to be able to make modifications to a particular target's temporary key list for several reasons (some of which we will discuss later). In this case, it would be desirable to have this list encrypted using the target device's primary secret key (which is known to the licensing authority 21 10). [0256] As mentioned earlier, the integrity of both of the key list data structures can be verified by using the signed message digest (the digital signature), which is stored along with the list itself. The implementation of the secure code mechanism, which is used to generate this message digest, was described in an earlier section and we do not need to go over the procedure again. We have also already described the procedure for recovering the permanent key list data structure 2210 in the case of loss and/or corruption. The only remaining issues that must be addressed are how to interpret the time-dependent portion of the temporary key list data structure and how to deal with the case where a temporary key list is somehow rendered unusable.
Temporary License Transfer
[0257] This is one of the sections of the security protocol where the use of the timestamp field 1830 is of prime importance. As discussed earlier, the temporary key list data structure is constructed in exactly the same manner as is the target device's permanent key list.
However, there are a couple of differences between the two. The first difference is that the temporary key list can potentially be encrypted with either one of the target unit's secret keys 104. Since it is not necessary that the licensing authority 21 10 be able to reconstruct this data structure under normal circumstances, it is ostensibly not relevant which of the target unit's keys is used to encrypt it. However, it would potentially be of use to the licensing authority 21 10 if this list were also encrypted using the target unit's primary secret key. The reason for this has to do with license revocation and that situation will be discussed in a later section.
[0258] A second (and more important) distinction between the temporary and the permanent key lists is that a copy of the timestamp value 1830 which is associated with the most recent temporary key list data structure is also stored inside the target device 100 (i.e. on-chip). This register is not software readable and is only able to be overwritten by secure code, as it is a part of the security block. The value in this register is used to determine what to do in the case where the temporary key list data structure is somehow lost and/or corrupted. We will discuss that procedure later on in this section.
[0259] Yet another distinction between a temporary key list and a permanent key list is that a target unit 100 is able to (temporarily) transfer ownership of a particular key from its permanent list to another unit's 100 temporary list, but no (correctly operating) device is able to transfer ownership of a particular key from its temporary key list to any other key list. This includes, of course, not only other units' temporary key lists, but also the target's 100 own permanent key list as well. This means that only the permanent owner can decide which devices are allowed (and when they are allowed to) "borrow" any particular key. Note, however, that this "loan" period can be made indefinite (and this transaction can be carried out without the necessity of contacting the licensing authority). This "permanent loan" feature is equivalent to the standard "Copy Once" functionality requirement that is part of most modern digital Copyright Control Information (CCI) systems.
[0260] Turning now to FIGURE 23, a detailed flow diagram depicting the temporary "key checkout" procedure is shown. The "key ownership" transfer procedure is somewhat similar to the procedure of checking a copy of a book out from a library. When the "borrower 2320" requests the temporary use of a particular application specific key 2150 from the permanent owner (the "lender 2310"), then the lender 2310 first generates an updated temporary key list for itself which prohibits the use of that particular key for the duration of the key checkout negotiation process. This action prohibits more than one borrower 2320 unit from requesting the same key. The presence of the "checked out key" on the temporary key list of the lender unit 2310 is effectively used as a semaphore to control access to any particular key.
However, the initial amount of time that the key is placed "on restriction" should be limited to a relatively short period. This is to prevent the case where a borrower 2320 device requests access to a particular key for a long period of time and then is unable to complete the transaction for some reason from unfairly monopolizing the use of a particular key. This relatively short checkout negotiation phase timeout also helps in the battle against the malicious device, which may be attempting to mount the equivalent of a "denial of service" attack against the lender unit 2310. In fact, the lender unit 2310 can optionally ignore requests from devices which are not on its "approved borrower" list or if any one of those units should try to make too many requests within a certain time period. The exact length of time that this temporary block is placed on the key is not important, but it should be long enough to allow any given checkout procedure to go to completion. In times of high network traffic or latency, this period could be extended.
[0261 ] Note that in the case where more than one copy of a given key is allowed to be
simultaneously checked out, the appropriate fields within the lender device's 2310 temporary key list can be used to indicate how many copies of a given key are checked out at any one point in time. Once the borrower 2320 and the lender 2310 have negotiated a specific checkout period for a given key, then the lender 2310 sends an encrypted copy of the key 2340 to the borrower 2320. This encryption is carried out using a temporary secret key 2330, which is known only to the lender device 2310. When the borrower 2320 then acknowledges the accurate receipt of the encrypted key (by means of a message digest which is calculated from the encrypted message), then the lender 2310 extends the "loan period" of the checked out key and then sends the temporary secret key 2330 to the borrower device 2320. The maximum duration of this loan process is not important to the operation of the protocol and there are some tradeoffs that must be made in the choice of this value. We will go over those particular issues later on in this section. In the example discussed above, we assume that the "borrower 2320" and the "lender 2310" devices are able to negotiate the actual length of the checkout period on a key-by-key basis, although this is certainly not a requirement of the protocol.
[0262] Just prior to the point where the temporary key list of either the borrower 2320 or the lender 2310 is updated, a copy of the timestamp value 1830 associated with this new temporary list is stored in a non-volatile fashion on the target 100. At that point, an encrypted version of the temporary key list data structure can be safely written out to memory (or stored in some other, more permanent location, such as on-board NVRAM, Flash ROM or even out to a backup file on some hard disk 2350. Since the temporary key list is potentially read from and updated on a much more frequent basis than the permanent key list, it is desirable that this list should be quickly accessible to the target unit, so it is recommended (although it is not an actual requirement of the protocol) that this list be stored in at least one location where the access latency is relatively short. On the other hand, it is recommended that the only place where this list is stored is some volatile storage medium (such as DRAM), since a power failure could potentially cause the loss of the unit's 100 functionality for an indeterminate amount of time. We will go into details about this issue later on in this section.
[0263] When the checkout period time for a particular key has expired, both the borrower 2320 and the lender 2310 devices can update their respective temporary key list databases independently. Thus, it is not a requirement that the borrower 2320 be in contact with the lender 2310 unit in order to "return a particular key to circulation". This is a major convenience factor in the case where the borrower 2320 and the lender 2310 devices are widely separated. Of course, the security of this operation may depend on a very tight correlation between the on-chip clocks that are used to generate and control the key timestamp records. Thus, the time/date clock must be an integral part of the security system and, as such, should be able to be overwritten by a transaction with the central server. Also, the clocks must be designed to be robust enough to resist tampering in the case where a malicious user tries to modify the internal timestamp value 1830 and also to be able to survive normally occurring system power failures. Since it is not inconceivable that this clock is battery powered and that the battery could get removed or it could go dead over time, the system should be designed in such a way that the clock could potentially be restarted and reset by an interaction with the licensing authority.
[0264] Thus, we have described a situation where the ownership of a particular application specific key 2150 can be temporarily transferred from one unit to another. At the end of the "loan period", both the "borrower 2320" and the "lender 2310" units can update their temporary key list data structures to reflect the "return" of the key to its original owner. Note that this procedure can be carried out independently on both units and thus does not require any interaction between the two devices.
[0265] We now must deal with the case where one or the other of the temporary key list data
structures is corrupted and/or lost while one or more keys are "checked" out or "on loan". On the side of the "lender 2310" unit, when any keys are checked out, the first thing that it does is to determine the end of the "loan" period. This value is obviously constructed by adding the duration of the loan period to the value of the current time/day field. This time/date value is then compared with the value that is stored on chip as a result of the last time the device's temporary key list was updated. If the new value is greater (later) than the old value, then the new value is overwritten in place of the old one. On the "borrower 2320" side, this same process is used, so that the result is that in any given target unit, the temporary key list timestamp is always the latest of any of the timestamps which are stored as a part of that particular unit's 100 temporary key list.
[0266] If a unit's 100 temporary key list is lost or otherwise improperly modified, then both the
temporary key list and the permanent list are disabled until the point where this "latest timestamp" value has expired (effectively, a "timeout" period). At that point, then the unit can go back to using the permanent key list and can begin the process of reconstructing a new temporary key list.
[0267] Thus, if a device's temporary list is ever tampered with or deleted, then the unit is effectively rendered inoperative until the timeout period has expired. While this timeout procedure may seem unnecessarily restrictive, it avoids the potential problem of multiple copies of any particular application specific keys ever existing as a result of some malicious act or because of some glitch (such as a power outage or a network connection going down) which may occur during the transfer of a key from one unit to another. Also, the potential for such severe repercussions as a result of tampering with the temporary key list data structure should help to discourage the practice by all but the more sophisticated attackers.
[0268] There are a number of optional additional features, which could be used to enhance the operation of the protocol in this regard. One such possible option is to add a signed message digest (digital signature) generated from either (or both) of the encrypted key list data structures to the values that are stored in the target units' on-chip security section. The MAC value resulting from the decryption of the digital signature could be used to quickly verify the validity of any particular key list without having to go through the entire decryption process. However, the issue of multiply nested key lists means that it is entirely likely that this decryption procedure must be performed multiple times at some point in order to finally produce an unencrypted key, so it is not critical to the operation of the protocol that these digital signatures be stored on-chip.
[0269] Another possibility for an enhancement is to store a pair of on-chip timestamp values rather than just one. The additional timestamp could be used to indicate the earliest (next) time when the temporary key list must be updated. This would make it easier for the target device 100 to decide when it needs to revise its temporary key list, since it would not have to constantly check over the list (which involves going through the decryption process).
Although this feature would be very useful, again, it is not a fundamental requirement in order for a unit to be able to execute this protocol. If a system that contains this second timestamp is implemented, however, it does bring up a potential for confusion in the case where the two timestamps get "out of sync" for some reason. One such example, which comes to mind, is the case where there is a power glitch that occurs at the point immediately after one such timestamp is written, but before the second one is updated.
[0270] The final issue that should be addressed is the matter of what the minimum and maximum limits are for the values of these temporary key list timestamps. On one hand, a larger limit for the maximum "temporary loan period" could allow the user to transfer the use of a particular data application (or media stream) from one unit to another unit for a reasonably long period. This would potentially be of use in the case where a user wished to transfer ownership of a media stream from their "home unit" to a portable unit. Having a long "checkout period" would allow the user to take the portable unit with them (along with its associated temporary keys) on a lengthy trip without requiring that they be in contact with the original "lender" unit 2310. The downside of a long "checkout" period is that if anything should ever happen to the temporary key list data structure on the original unit, then that unit would be potentially disabled for a long time.
[0271 ] This last issue also points out a potential danger for the target unit 100 in the case where a piece of malicious code is able to set the value of the on-chip timestamp register to some indeterminate value. This could potentially be tantamount to disabling the target of the attack, and thus, the value of this timestamp register should only be able to be written by a "secure" code block. Again, since each unit will have a distinct set of secret keys, the discovery of one particular unit's 100 secret key 104 data should not be a cause for concern for any other unit, except in the case where a malicious device is able to effectively masquerade as a legitimate unit. This mode of attack is discussed in a later section, which deals with issues related to Identity Verification.
Permanent License Transfer [0272] Many of the elements of this procedure have been discussed in earlier sections of this document. The basic process by which a specific key is permanently transferred from one unit to another was shown earlier in FIGURE 21 . In many ways, this procedure is essentially similar to that of the temporary transfer of key ownership as described in the section immediately preceding this one.
[0273] The main differences between the two procedures are that the permanent transfer is a
simpler process than the temporary transfer and that the permanent key ownership transfer procedure should utilize an interaction between the licensing authority 21 10 and the target unit 100. The reason that the permanent transfer process is simpler lies in the fact that it does not require the checkout time period negotiations that are prerequisites in the temporary key checkout procedure. The reason that the permanent transfer function utilizes an interaction between the licensing authority 21 10 and the target unit 100 is due to the fact that the updated key list data structure must be able to be reconstructed at both ends of the transaction.
[0274] Since a permanent license transfer usually occurs by means of an interaction with the
licensing authority 21 10, there is a record of which application or media stream specific keys belong to which target units. As was described earlier, this is necessary in the case where the target unit's 100 key list must be restored after some catastrophic data loss situation or in the case where the ownership of a particular target unit 100 is transferred to a different entity. This intervention on the part of the licensing authority 21 10 is also necessary in the case where the permanent ownership of a specific key is transferred from one target unit 100 to another. This ability of the owner to re-sell an asset, which was originally purchased from another entity, is known as the "right of first sale" and the ability for the protocol described herein to support this particular functionality is of importance.
[0275] Another important aspect of the fact that the target unit's 100 permanent key list is
maintained by the licensing authority 21 10 is that this body has the ability to revoke any or all of an individual target unit's 100 license keys in the event that it is proven that the unit 100 has somehow been compromised or if one of the keys has been identified as having been compromised. Since the potential exists to give a unique list of keys to each and every target unit 100 (as was described above), there could also provide an opportunity for the licensing authority 21 10 to track the source of any compromised keys. In such a situation, this protocol could fulfill the functionality that is normally associated with that of a "watermark" feature, but without the drawbacks of the traditional watermark process (such as the potential of the watermark to have an adverse effect on the quality of the media stream). [0276] Even though it may not seem to be the case, the digital content owner's privacy is still maintained by this process, since the application code or media stream specific ID information originates with the application developer 2120 and the licensing authority 21 10 does not necessarily have enough information to be able to make the association between any particular application or media stream and its licensed owner. This ability to protect the users' privacy is also an important aspect of this protocol.
[0277] The final issue that should be noted about the permanent key transfer process is that it is, in fact, possible to accomplish all of the same functions that the permanent key transfer performs with a temporary key license transfer. However, the maintenance of the target units' security system is a function which should ideally be controlled by a central secure server, so it is necessary to have such a mechanism in place somewhere in the chain. Also, in the case where the user is concerned about maintaining their privacy, the fact that the central server can act as a buffer between the copyright holder and the target unit 100 is of great utility. Finally, there is also the appeal that the licensing authority 21 10 is able to act as a central backup storage mechanism for a particular target unit's 100 permanent key list that sets this functionality aside from the temporary key transfer mechanism.
System Ownership Transfer, License Revocation and Security System Updates
[0278] There are several different means by which one or more of a target unit's 100 licenses (or keys) may be revoked. The simplest method is that of simply updating the target's 100 primary secret key. At this point, the target 100 would then be unable to access its permanent key list and thus, it would have to begin the process of creating a new one. Note that in the case where the primary secret key was not used in the encryption process for the temporary key list data structure, then this temporary key list could potentially still be accessed, even though the permanent key list might be otherwise inaccessible. This point was mentioned earlier in the description of the encryption process for the temporary key list. For this reason, it is probably the best idea to use the target unit's 100 primary secret key as the encryption key for both the permanent and the temporary key list data structures.
[0279] In the case where the ownership of the target unit 100 changes from one individual to
another, then the simplest manner to effect this ownership change is to set the unit's 100 primary secret key to some new value. However, if this occurs before the original owner has the opportunity to recover all of their permanent keys from the target, then they will lose their licenses. In the case where the original owner wishes to transfer the ownership of the associated permanent key list along with the target unit, then nothing need be done to the target unit 100 except to change the ownership information that is associated with that particular device (which is stored at the licensing authority 21 10). [0280] Another manner by which license revocation can occur is if the master key for a particular target unit's 100 permanent key list "expires". Since updates to the unit's 100 security system are stored as a part of the permanent key list, this situation could potentially have disastrous repercussions.
[0281 ] Although it would potentially be possible to recover from this predicament, it would require that the target 100 would need to have an entirely new "chain of trust", built from the ground up. In this situation, the core of the newly initialized security system would have to be based only on those computations that can be verified as being able to run atomically on some part of the target 100. Thus, this would preclude the use of any hashing function that required even the smallest amount of otherwise general-purpose code (which could potentially be suspect). Fortunately, this situation can be avoided by the simple matter of always keeping a permanent core of verifiably secure code fragments as a part of the permanent key list data structure which does not expire. This is, itself a security risk, however, for reasons discussed above, so the contents of this permanent code core should be limited as much as possible.
[0282] Yet another manner of license revocation can occur if the licensing authority 21 10 chooses to override a particular key entry in a target unit's 100 permanent or temporary key lists. This could be used in the case where if a security system upgrade is required or in the case where a particular target unit 100 has been identified as having an unlicensed copy of a particular application or media stream. Since the target unit 100 normally maintains its own key list data structure, this procedure will involve a larger than normal amount of network traffic between the licensing authority 21 10 and the target unit. Thus, this course of action should be reserved for extreme cases.
[0283] Nonetheless, such a procedure can be accomplished by forcing the target device 100 in question to revise its security system software with a target-specific custom version that is designed to search for and disable the disputed key and/or then replace the older software with an updated version. Of course, this procedure can only be set in motion at the point when the target device 100 initiates a connection with the licensing authority's central server. Under normal circumstances, it cannot be guaranteed that any particular target unit 100 will initiate contact with the licensing authority 21 10 on any particular schedule. Fortunately, the target device 100 in question must connect with the licensing authority 21 10 (either directly or indirectly) in order to authorize any new additions to its permanent key list, so any key revocation actions can be accomplished as a part of the new key licensing procedure. It is also possible that the "security system timeout" mechanism mentioned earlier could be used to support this "list policing" action. However, it is not a requirement for this protocol that this is the case and it is likely that such a system would result in an erosion of the users' privacy rights.
Other Concerns:
[0284] There are a number of issues, which are not necessarily part of the protocol itself, but
nonetheless must be addressed in the process of creating a practical system that is able to properly execute the protocol described herein. Some of these issues are dependent on the implementation of the actual processor device and others are mostly specific to the application. Since this information is germane to the proper construction of a suitable target device 100, we will discuss some of these issues in the following section.
Limits on the number of units which can interoperate
[0285] In the case where the copyright holder wishes to limit the total number of devices to which the primary target is able to temporarily transfer ownership, this may be accomplished by means of establishing a limited number of public/private key pairs that may be active at any one time. Note that this is different than the case where multiple copies of the same application specific key(s) were simultaneously "on loan", which was described in an earlier section. Other scenarios are possible, where the list of devices which are able to "check out" any of the application specific keys from a particular target device 100 can be limited to a certain set of serial numbers. The licensing authority 21 10 can administer such an "approved borrower" list in exactly the same manner that the target unit's 100 security system is managed. Thus, the licensing authority 21 10 could, for example, limit the set of serial numbers on the "approved borrowers" list to those who have the same ownership information as the original target device 100. Another possible solution to this problem is to require that any "borrower" device 2320 be validated as an "authorized" borrower by presenting credentials (such as a signed certificate) to the lender which can be verified only by decrypting the certificate with the central Licensing Authority's 21 10 public key. This scenario would also, of course, involve the ability for the Licensing Authority 21 10 to revoke such a certificate in the case where a particular unit has been determined to be
compromised. One well-understood method by which this certificate revocation process can be accomplished is via a regularly-published "revocation list".
Secret Key Discovery and Identity Verification Issues
[0286] If the primary secret key for a particular player is discovered by means of physical
disassembly and chip die examination, then this should not compromise the security of any other device, since each device will have a distinct set of secret keys 104. However, if the primary key for a particular player were somehow compromised then it is potentially possible for an unlicensed device to masquerade as a legitimate target unit. In the case where this problem went undetected, the possibility exists that an unlicensed device armed with this knowledge could compromise any of the application specific decryption keys that were issued to that particular target unit. Since the target unit's 100 serial number 106 would have to have been registered in order for the licensing authority 21 10 to issue decryption keys to the device in the first place, the problem on this end would ostensibly be limited to the imitation of an otherwise legitimate target unit 100 by an unlicensed device.
[0287] If both of a unit's 100 secret keys were discovered by means of such a process, however, it is possible that it would be possible to compromise the security of all of the application specific keys which were licensed to that unit, based on an examination of previously backed up copies of the encrypted key list digests. For this reason, both the primary and the secondary secret keys should be implemented on target chip in a "tamper-proof" manner such that any attempt to discover the value of these keys results in the loss of the key data.
[0288] There are a number of means by which this tamper-proof feature could be implemented on the target device 100, but the exact implementation of such is not of consequence to the protocol described in this document. If a "secret key loss" situation were to occur through some innocent act of negligence (or abuse) on the part of the user, the legitimate user should be able to return their damaged unit to the licensing authority 21 10 who could arrange to have the damaged unit's application specific keys transferred to a new device. It should be noted, however, that in the case where the original target device 100 is nonfunctional, the transfer of the keys to a new target device 100 must involve a transaction with the application developer 2120 (at least for those keys which were not supplied to the licensing authority 21 10 in the clear in the first place).
[0289] It should be noted, however, that a device which was able to impersonate an otherwise genuine target unit 100 could ostensibly be able to trick an unsuspecting legitimately licensed device into temporarily relinquishing ownership of one or more of its application- specific keys or into suspending operation (as was discussed earlier). If the latter were to occur, then the possibility exists of having a "rogue unit" which could disable all of the units that attempted to borrow a key from it. If the former were to occur, then any number of application or media specific keys could potentially be compromised.
[0290] Thus, the concept discussed earlier of limiting the number of potential "licensed borrowers" for a particular target unit 100 to a list which was only able to be supplied to the legitimate unit by means of a secure update from the licensing authority 21 10 server is a prudent one. In the former case, this will prevent the owners of otherwise unsuspecting units from having their legitimate devices disabled by a hacker who takes apart a functional unit to gain access to its secret keys unless that unit actually belonged to them in the first place. In the latter case, this will limit the transfer of application or media specific keys to only those devices that were at one point licensed devices that were properly registered with the licensing authority. Nonetheless, the determined hacker could still purchase a legitimate unit, crack it open and somehow gain access to its secret key data and then use this information to masquerade as a legitimate device.
[0291 ] So, the issue remains of how to try to detect this kind of an impersonation event. The only successful strategy to defeat an extremely well financed opponent of this nature is to design the system such that the potential gain is not worth the effort required, at least from a cost- tradeoff standpoint.
[0292] There are several means of attempting to prove the authenticity of an otherwise unknown device with which one is communicating. However, the most successful method for proving that a device is, in fact, what it claims to be is to focus on the characteristics that make this device unique from other devices. In the case of a special purpose apparatus, such as a digital decryption mechanism, such as that described by this document, it would be the ability for the device to properly execute the security protocol and to calculate the correct result based on a given set of input variables. Since the security protocol described herein is based on publicly known algorithms, however, this could ostensibly be accomplished by any general purpose computing device, given that is has enough time to complete the computation. In fact, this issue will be a potential problem for any device that is based on publicly available technology, if the secret key information that makes the device unique is somehow compromised. Thus, we must ultimately rely on the precept that the secret key information which is stored on-chip for all of the legitimate target devices must remain secret, even in the face of disassembly and chip die inspection.
[0293] We can certainly add requirements to the target identification and verification process such as the ability to correctly come up with a verifiable MAC value within a certain amount of time. We could make the procedure even harder by requiring that the final MAC value be encrypted multiple times. Thus, we could potentially limit the ability of the attacker to imitate a legitimate device in that they would be required to have access to (more general) computational resources that would normally be much more expensive than the cost of simply purchasing legitimate copies of the licenses themselves. In the case of a media stream player, we could also include the ability to correctly decode a portion of one or more of the media streams which the player is ostensibly designed to accommodate. [0294] In any case, however, the whole process of digital copyright protection is a Turing problem. Thus, given sufficient time and resources, any digital copyright protection scheme can possibly be defeated by the determined opponent. This is even independent, of course, of the fact that access to the secret key information would definitely be a big advantage to the would-be attacker. The ability to keep a unit's secret keys from being compromised is therefore an important part of this security protocol.
Conclusions:
[0295] The copyright protection protocol described above is unique in several ways. First is the fact that it does not attempt to prohibit the user from having the ability to make backup copies of their legally purchased application or media specific key data. Second, this protocol does not make a distinction between any kinds of digital data and thus, allows the security protocol to be updated as easily as the data streams that it is designed to protect. Third, this protocol allows the user to temporarily transfer ownership of their application or media specific key(s) to another unit that is capable of executing the protocol. Also, this protocol also provides the ability for the licensee to effect a permanent transfer of ownership from one target unit 100 to another. This last property allows the implementation of the consumer's legal "right of first sale" under this protocol.
[0296] In fact, one of the fundamental differences between the protocol described in this document and other copy protection schemes is that the security of this system depends not on controlling the ability to access a particular data set, but rather on the ability to control the act of expressing the ideas contained within that data set.
[0297] As discussed above it is desired to allow a processor to execute an arbitrary segment of code in a prescribed manner. Solution which address this desire, among others, will now be discussed. The problem of control is compounded by the many varied methods by which even legitimate software can be manipulated to produce unintended or even malicious results. These methods of attack may include exploiting poorly written, but otherwise valid code by feeding bogus arguments as input to the routine in order to exploit input data corner cases or even other algorithmic deficiencies. Other possible avenues of attack include independently modifying the data that are stored in various processor registers (such as the stack pointer) or external memory locations that are referenced by otherwise legitimate code in a manner to produce improper or intentionally erroneous results.
[0298] There are a number of mechanisms by which this kind of control can be affected. These systems include both simple as well as complex schemes that attempt to protect the processor from this kind of unintended usage. One reasonably secure, but complex mechanism includes pre-encryption of a code segment prior to its execution. Once the code segment is loaded into the processor from memory, it must be decrypted under carefully controlled circumstances and then executed in a secure fashion (in other words, it must not be modified or tampered with between the decryption operation and the subsequent execution). This mechanism suffers from a performance inefficiency that can be incurred because the processor must wait until the code segment in question is decrypted prior to being able to begin execution. This latency between the selection of a particular code segment to be executed and the actual post-decryption execution can cause many problems including, but not limited to, processor pipeline stalls and data path inefficiencies as well as providing another avenue for potential attacks (by somehow hijacking the code in between the decryption and the execution operations).
[0299] This encrypted code mechanism also does nothing to protect the processor from the
eventuality of a hacker who manages to properly decrypt (or who obtains a decrypted copy of) the ostensibly protected encrypted code segment. In that case, they could then run that unprotected code in a non-controlled manner, either on the target processor or on some other non-authorized processor. Thus, it is preferable to find a way to exercise control over exactly which code segments can be run on a particular processor or processors, irrespective of whether the code is distributed in the clear (i.e., in plaintext form) or in encrypted form. On the other hand, if the code that can be run on a particular processor is limited to some pre-selected subset, then the general-purpose nature of the processor itself may be violated. This could possibly have the effect of constraining the architecture in such a way that the processor becomes less general purpose and thus, much less flexible in its potential application space. There will always be a strong desire for maximally flexible general-purpose processor architectures, but it is exactly those processors that are most vulnerable to malware attacks.
[0300] Thus, there is a need for a method for control of code execution that is general-purpose enough to not depend on any particular processor architecture. It would also be useful if such a method would also not adversely impact either the object code density or the execution pipeline of the target processor. At the same time, is desirable that such systems and methods provide protection against unlicensed use of otherwise legitimate code segments on either an original target processor or some other non-intended target processor. Such a method would be a valuable tool in the battle for control over software viruses and malware as well as a uniquely powerful mechanism for protecting copyright in a world of digital content. [0301 ] To that end, attention is now directed to embodiments of systems and methods which provide highly specific control over the execution of general-purpose code block, in turn, allowing a programmer to determine the exact circumstances under which a given code block is allowed to execute. These conditions may include (but are not limited to) such constraints as the individual device on which the code block is attempting to execute, the environment in which the code block is called, the time of execution, the order of execution as well as the number of times the code block has been called in a particular execution thread.
[0302] Such a control mechanism may be coupled with embodiments of a data hiding system and method, based for example, on an explicitly ordered execution of a set of called code segments implemented in one embodiment via recursive execution. When embodiments of these systems and methods are utilized together an unencumbered generality as well as a level of protection against attack that surpasses many other security systems may be obtained.
[0303] FIGURE 1 gives a general overview of an architecture in which embodiments as described may be effectively utilized while FIGURE 2 depicts an architecture of one embodiment of a target unit that is capable of controlling the execution of the digital content or implementing security protocols in conjunction with received digital content.
[0304] It may now be useful to go into more detail regarding the one-way hash function hardware of a target unit. Referring now to FIGURE 36, one embodiment of a one-way hash function block that can use the result of a digital signature operation generated in one iteration of a recursive security protocol as a seed value for the one-way hash function in a subsequent iteration is depicted. In one embodiment, the state of the target unit as far as it pertains to whether it is operating in secured execution mode or not can be reflected by the value of a hardware bit 3670 that will be referred to herein as the "Secured Mode Enabled" bit.
[0305] Here, the default state of this hardware bit may be cleared (i.e., the default state of the target processor is not to be operating in secured execution mode). The interaction of this bit with the One-Way hash function hardware block 3661 in certain embodiments may be described in two parts. In the first (non-secured) case, all accesses to the Secret Hardware key 3640 are blocked, since the "Secured Mode Enabled" bit acts as a gatekeeper to only allow use of the Secret Hardware key when this hardware bit is set (for example to a "1 ", however it will also be noted that in certain architectures the bit may be considered "set" when it has a value of "0"). Also in this case, the output of the Digital Signature Register 3664 is fed back to form the input "Seed" 3610 of the One-Way Hash function 3661 . Thus, while the processor is operating in this "non-secured execution" mode, the intermediate results of any of the one-way Hash function operations are fed back to form the seed for any subsequent one-way hash function operations. This allows a running checksum equivalent of the entire calling chain of a set of nested or concatenated functions to be kept. In the case where each code block that is attempted to be executed is first evaluated with this one-way hash function prior to it being allowed to execute it the entire calling chain of any given code block can be substantially unambiguously determined with this single mechanism.
[0306] Likewise, in the case where the "Secured Mode Enabled" bit is set (i.e., where the processor is operating in "Secured Execution mode"), the Secret Hardware Key is accessible (in other words, directly accessible or at least its value is able to be used in a calculation operation, even if its value is not directly accessible by the processor itself). Additionally, when operating in Secured Execution Mode the output of the Digital Signature Register is not fed back to form the seed value for subsequent evaluations of the one-way hash function. The exact implementation of this Digital Signature generator block will be discussed in more detail at a later point. As can be seen then, in certain embodiments the entire calling chain of a particular code block can be validated prior to its secure execution without the need to utilize measures such as system-wide software or hardware validation (or attestation) operations. Note that, as in the case described earlier for the Timestamp Register, in certain embodiments this "Secured Mode Enabled" bit may or may not be architecturally visible to the processor, but its state may not be explicitly set by the processor. This hardware bit could be reset to a default value by calling a non-secured code segment, but in one embodiment, the only manner in which this bit can be set is through direct action on the part of the hardware. In the case where the bit is architecturally visible, it can be explicitly determined whether or not the processor is operating in secured execution mode. In the case where it is not architecturally visible, then the determination can nonetheless be made implicitly by evaluating some expression whose value somehow depends on the hardware secret key.
[0307] It may now be useful to describe basic problems underlying subjects that may be germane to the control of code execution and the implementation of security protocols in more detail. Then it can be shown how to implement control over the execution of arbitrary-code on an arbitrary general purpose processor using embodiments of the hardware described above and how embodiments of these systems and methods may be effectively utilized with security protocols and system to construct an effective overall security system.
Secret Key hiding
[0308] The majority of commercial digital content delivery systems include some form of encryption or data hiding to try to protect the digital media data from being duplicated and distributed freely. In the vast majority of cases, the data hiding strategy is eventually proven to be a completely ineffective means of content protection. One of the main reasons that this hiding has proven unsuccessful is that the exact data that is to be protected from exposure must nonetheless be freely available for use by any authorized party. Thus, a set of seemingly contradictory requirements exists for the distribution of digital content.
[0309] In the case where the original digital content can be separately encrypted for all intended recipients and where only the intended recipient may actually make use of the distributed digital content then the security of the system can potentially be quite good. However, unless a number of specific conditions are met, the security of this kind of system can be shown to be deficient in several respects. First, such a system is less efficient in that it requires that the entire distributed data set must be re-encrypted separately for each intended recipient. Second, the distributor may need to ensure that no unauthorized decryption is possible on a general-purpose processor. Third, each individual receiving device must be unique in the sense that it must possess some attribute that cannot be easily duplicated on some other endpoint device (or emulated on a general-purpose processor). If either of these last two conditions is violated, then this system is vulnerable to attack simply by intercepting both the individually encrypted data as well as the device-specific key that is associated with that data.
[0310] In fact, it can be shown that the security of such a system may be based on the security of the unique attribute of each of the receiving devices. This unique attribute is typically implemented using a secret key that is known only to the distributor and the authorized recipient. While, in principle, this kind of setup can be an effective security system, the requirement that the original digital content be separately encrypted for each recipient makes the actual implementation impractical for most purposes. If it is desired that the original digital content be encrypted once and identically distributed to all potentially authorized parties, the problem then reverts back to that of data hiding. These types of problems are known as the field of Broadcast Encryption.
[031 1 ] One of the fundamental problems with a distributed secret data system of almost any kind is that, in the majority of cases, all of the messages and data that flow back and forth between the separate entities of the security system are usually transmitted in the open and are thus observable by eavesdroppers. Thus, any messages or data that are transmitted between the individual components of such a system should be encrypted to protect against interception by unauthorized parties. Another problem that must be addressed in such a system is the verification of the identity of both the transmitter as well as the receiver in any such secret data transmission. In the case where the two parties are not known to each other, a mutually trusted intermediary strategy is typically employed.
[0312] Additionally, however, once the secret data has arrived at its destination, an equally difficult problem that must be addressed is how to securely use that secret data in such a manner that it is not compromised. This precaution is usually necessary as it is also possible that even a legitimate endpoint may have its security compromised by providing it with false information. So, in addition to protecting against unauthorized discovery during distribution it is sometimes desired to protect the secret data from discovery by an otherwise authorized user of that secret data.
[0313] In one embodiment, such desired control may be implemented, using a simple time- dependent use of an architecturally hidden secret key or an encrypted object code block that must be decrypted in real time prior to execution. In the first case, the code block execution can be completely transparent to the control mechanism, which means that the execution speed should be minimally affected. In the latter case the code block to be run may be decrypted prior to execution, so there is most likely a concurrent loss of performance due to the latency of the decryption process. In this latter case, however, the object code may be relatively safe from disassembly and is thus potentially more difficult to subvert by would-be attackers. Embodiments discussed herein at a later point disclose systems and methods that can be implemented in a large continuum of possible solutions, ranging from a highly secure encrypted object code method to a relatively higher-performance, but nonetheless still quite secure selectively-available, secret key method.
[0314] In one embodiment, hiding the secret key from the user of such a secret key may be
accomplished in a method similar to the Harvard Architecture memory space bifurcation. In this embodiment, however, the distinction may be made that a secret key may be used in an encryption/decryption calculation, but never actually directly read by the processor. This distinction may be enforced by limiting the encryption/decryption operations to those that are either implemented in hardware or are pre-determined software macros (also known as micro code), fixed at the design time of the hardware. For example, in the case where a hardware secret key may be used by any arbitrary code, even though it may not be able to be directly read by the processor, it can nonetheless be readily determined by simple calculations. Thus, it may be desired to specify that only security-related calculations may access the hardware secret key to differentiate such code segments from more general purpose, but less secure code blocks.
[0315] This distinction may be accomplished, in certain embodiments, utilizing validation methods substantially similar those described herein. If embodiments of the adaptive digital signature methods described earlier are utilized to determine whether or not the hardware secret key may be accessed, then it can be readily and reliably determined if the target processor is executing security-related calculations (i.e., calculations performed when the target processor is operating in "Secured Execution" mode) and those that are not secured. In addition, recursive methods substantially similar to those outlined earlier may be utilized to keep any intermediate key results hidden from discovery until the final calculations are completed and the fully decoded result is reported. Thus, embodiments described herein may have the ability to decode an encrypted digital bitstream without ever exposing the secret global key that is used to generate that same bitstream.
Code execution control
[0316] Methods for ensuring that a particular code segment is executed securely on a given
processor have been widely studied for many years. Some of the earlier attempts to create secure code execution protection have included making modifications to the processor architecture in order to establish a set of "privileged" instructions. These privileged instructions were secured by designing the architecture such that these privileged instructions could only be executed when the processor was running in a particular mode, known as "supervisor" or "kernel" mode. This kind of bifurcation of the processor architecture has a number of drawbacks, including a potential loss of both processor generality as well as a potential degradation in performance. In addition to these drawbacks, such protective measures can often be bypassed by using specifically designed software calls to standard system routines in such a way as to take advantage of unexpected execution paths while the processor is executing in supervisor mode. Examples of such specifically designed malware attacks include so-called "stack overflow", "stack overrun" and "code injection" attacks.
[0317] A number of strategies have been devised in an attempt to help protect against these kinds of exploits, mostly based on various means of checksum verification or argument bounds checking. In the face of these kinds of protective measures, a variety of counter-counter- measures have evolved, including polymorphic viruses (i.e., self-modifying code). Other strategies for exploiting processor weaknesses in the face of bounds-checking include simply bypassing the bounds-checking "supervisor" routine itself. This kind of exploit is also used quite often in circumventing various copy-protection systems. As it turns out, the strategy of hijacking the supervisor routine is not unique to the world of computer security and is not at all a new concept. In fact, this exact problem has analogs in a variety of applications and has been referenced as far back as Plato in his work "The Republic". The basic problem is that, in any given system, one can always identify some sort of a global supervisor, with whom the ultimate security or stability of a structure is entrusted. Such a concept of a global foundation for all subsequent security functionality is known in the contemporary study of security systems as the "Root-of-Trust".
[0318] More recently, there have been some attempts to protect a processor against supervisor routine attacks by limiting the memory segments out of which the processor is fetching instructions to be read-only in nature (this includes the so-called WAX or "write-XOR- execute" approach). The concept of splitting an otherwise general-purpose computer's memory space into data-based and code-based partitions can be shown to be a variation of the so-called "Harvard Architecture." This method has a certain performance penalty associated with the protection mechanism as well as a concurrent increase in memory utilization. Finally, it has also been shown recently that even these kinds of defenses can be circumvented by the use of so-called "return-based" programming exploits or even by simple memory-aliasing exploits, where two separate execution threads can reference the same block of memory in different modes (one in "data mode" and the other in "execution mode").
[0319] Another proposed means of protecting the execution thread of a processor from being
hijacked includes the use of encrypted code blocks. In this method, the code segments to be executed are pre-encrypted and thus, non-readable (and perhaps even more importantly, non-alterable) prior to their loading into the processor. This method also has several weaknesses. First, the code segment itself may be protected, but the arguments are not necessarily provided with the same level of security. Thus, a completely legitimate and secure code segment can be nonetheless provided with bogus arguments from its calling routine that can cause it to behave in an unexpected fashion. Second, in some cases, the execution thread is not necessarily protected against the return-based programming attacks described above. Also, if the processor bus can be readily observed by the attacker, then the long-term observation of both correctly-executed (even though encrypted) code segments as well as the observation of exception faults caused by improperly encrypted code segments injected into the executable stream can help to reveal the encryption key using a modified dictionary attack methodology. Finally, the processor performance in such a system is necessarily severely degraded over similar, but non-encrypted code systems. This performance penalty can be caused by a number of issues, the most significant of which is the latency incurred by the requisite decryption of the code block between when it is fetched from memory and when it is available to be executed. Although most modern processors use a pipelining mechanism to attempt to increase the number of instructions that can be executed in parallel (by various means), a block of encrypted code cannot be read into such a pipeline until it has first been decrypted. In the case where the code branches frequently, the decryption process can potentially take much longer than the code execution itself, even with a hardware-assisted decryption. [0320] Embodiments of the systems and methods described in this invention may allow the utilization of unencrypted code blocks, so the performance penalties associated with encrypted executables are thus less of an issue. However, in the case where the execution efficiency is not a substantial concern encrypted code blocks may still be utilized. Thus, embodiments disclosed herein may have both the efficiency of plaintext executables as well as the added security of encrypted code segments utilizing the same or similar methods and systems. In addition, embodiments of the security systems and methods described herein can be updated in-situ to address newly discovered security concerns as well as to add new functionality after an embodiment has already been deployed.
[0321 ] Embodiments of the invention may attain these advantages, among others, by ensuring that a "secured code segment" is validated prior to execution by means of a cryptographic hashing function. This validation may be accomplished, for example, by authenticating a message digest or digital signature created for such a secured code segment. In the case where the evaluation of this cryptographic hashing function occurs in conjunction with the encryption of the resulting message digest using a compound key structure as described earlier to form a digital signature, a particular code block can be uniquely associated with a specific target unit or processor. This process will be referred to herein as "secured code binding", based on the fact that in certain embodiments this secured code block can be cryptograph ically bound to a specific target unit using the compound key based digital signature.
[0322] Although executing such a hashing function may not be resource free, an advantage of this approach is that the secured code segment can be introduced into the execution pipeline prior to completing its cryptographic validation. Thus, the hashing function can potentially be evaluated in parallel with the execution of the secured code segment itself (in a manner similar to speculative branch execution). In this embodiment, the results of the secured code segment may be utilized only if the resulting message digest is determined to be genuine. However, in another embodiment, the results of the secured code segment may be utilized in subsequent operations, but the results themselves may be different depending on whether or not the processor is operating in secured execution mode. This embodiment is substantially similar to the process described earlier for the evaluation of a compound key for use in a digital signature and can be generated by use of the hardware such as that depicted in FIGURE 36.
[0323] The use of cryptographic validation does not, however, preclude the use of encrypted code segments. In fact, the use of a message digest or digital signature of the correctly decrypted code (the secured code segment in its original state before applying any type of encryption) may provide an additional level of protection. This is due to the fact that the prospective attacker would have to have a-priori knowledge of the correctly decrypted code block in order to create a counterfeit message digest. Thus, if both the code segment validation as well as the encrypted code methods can be used at the same time, higher robustness against attack may be realized.
[0324] As may be also be realized, however, there are several methods by which such hashing validation could be bypassed, the simplest of which would be to subvert the hashing function itself. Even if it is assumed that this strategy is not possible with certain embodiments (by utilizing a hardware hashing function, for example) it still could be possible to attack the security of such an embodiment by providing an impostor code segment along with a properly validated message digest. Since many message digests are actually encrypted to form a digital signature, then on the surface, this attack strategy would seemingly prove difficult. However, even a digital signature mechanism could potentially be attacked, either by spoofing the public key lookup portion of the digital signature, and thus providing an artificial validation of the impostor digital signature or alternately, by a malicious subversion of the signature validation routine itself.
[0325] These limitations are overcome in embodiments of the systems and methods disclosed
herein by doubly encrypting the message digest associated with the secured code segment; once with the (global) "author's" secret key and then once again with a secret key known only to the endpoint "manufacturer" (which may not actually be the original chip
manufacturer, but may be a secondary level distributor, system integrator, service provider, etc.) and the particular endpoint device on which the code segment in question is to execute. The advantage of this embodiment is that, even if the aforementioned digital signature is shared between similar endpoint devices, it will only function correctly on its intended target unit since the secret keys of different target units will differ. Thus, any such digital signature can be transmitted and stored in the clear.
[0326] Embodiments of techniques of doubly encrypting a secret (which may be used in so-called "layered key" systems as well as in a recursive security system) may have certain issues, if it is incorrectly used. First, if the intermediate result of such a layered encryption process is intercepted, then this intermediate key can be used to bypass the higher level security on any and all such systems. Also, note that, in the "lowest layer" of such a layered system, this intermediate result is actually a "global" decryption key that, if discovered, can be used to bypass the entire security system for all substantially similar endpoint devices. This kind of "intercept" attack has occurred more than once by simply watching for any memory transactions during the decryption process and then examining all such memory locations for a potential global decryption key. The process of watching for all memory accesses during a decryption process may seem cumbersome at first, but it is almost certainly a more efficient attack strategy than the brute-force guessing of the value of such a secret key. A second potential weakness in a layered key system can be exploited by a variant of the replay attack. In the case where a layered key system's security is compromised and its keys must be updated, then the old (compromised) keys may still be used if the original system is either reset back to its former state or if its former state is cloned by an impostor unit.
[0327] These weaknesses may be addressed in embodiments discussed herein using what we will refer to as a "compound key", as opposed to a "layered key" structure. One of the main differences between a compound key and a layered key is that all segments of the former may be evaluated in a single monolithic pass. By contrast, in a layered key system, the "outermost" layer key can be evaluated first, returning the next innermost key (which is then used to as an argument to produce the next layer's key, and so on, until the entire key stack has been traversed). The problem with this system is that the lower level keys can be intercepted and used later, effectively bypassing the outermost security layers. Thus, in such layered key embodiments the most important (in this case global) keys are those that are created and used last in the chain, where any additional (or more recent) layers of security are completely absent.
[0328] For this reason, a more robust manner to traverse such a security stack may be utilized such that the stack is traversed from the "inside out". This means that the most recent additions to the security chain are those that are executed first in sequence but are, in fact, located at the innermost layer of the security system. Accordingly, embodiments may be used to enforce such an "inside out" execution ordering. This particular ordering of code stack traversal can be accomplished by using a simple iterative approach, where the code loop first evaluates the current security level and then branches accordingly. However, in the iterative method, the intermediate results of the security system traversal can potentially be bypassed because, as noted earlier, the attacker could simply wait for the next lower level key to be exposed in a legitimate security system traversal and then use that intercepted key to clone a counterfeit "earlier" version of the system. Thus, embodiments of systems and methods are described that can not only enforce this "inside out" execution ordering, but also can protect intermediate results from being intercepted by malicious code or other well-known security system exploits.
[0329] Another major advantage when using such an "inside-out" security approach is that the
entire sequence of calling arguments may be visible to the innermost layer (and thus, most recent version) of the security system. If this "inside out" execution sequence is implemented properly, then it can be seen that a correctly constructed bounds-checking mechanisms employed in such a system can have visibility over the entire calling chain. Thus, embodiments may have a built-in mechanism for performing a significant amount of the system attestation function without incurring any additional performance penalties most usually associated with such functionality.
[0330] Accordingly, certain embodiments may utilize a means to keep intermediate keys from being exposed to higher-level (and thus, less secure) security system routines as well as to ensure the proper security stack traversal method. One such method for achieving this is to use a recursive security structure, one embodiment of which is depicted in United States Patent Application No. 10/465,274, entitled "Method and System for a Recursive Security Protocol for Digital Copyright Control" by William V. Oxford filed June 19, 2003, which has since issued as United States Patent No. 7,203,844, on April 10, 2007, which is herby
incorporated by reference for all purposes.
[0331 ] If embodiments of such recursive security protocols are utilized, certain advantages may be realized. First, the stack order traversal can be designed so that it must be evaluated from the "inside out". This means that the most recent security system additions are executed first and the system cannot be "started in the middle" (for example, as used in "return-based" programming exploits). A second advantage of a recursive system is that the addition of any updates to the security system may not change the original calling arguments at the security system itself. Accordingly, it may be more difficult to spoof the security system by using a traditional replay-based attack mechanism. While it is certainly possible for embodiments disclosed herein to employ inline execution stack with reverse ordering in an iterative fashion, the iterative mechanism may be subject to interruption and thus, it may also be possible to create a situation where a partial evaluation of the security stack is performed. This would potentially allow for one or more intermediate results to be intercepted by outside observers. In an inside-out security system implemented through recursion as may be utilized by embodiments herein, intermediate results cannot be passed as an argument to the next level routine at any point; only the final results of the security system layer being currently executed are available to the next level up in the security system stack.
[0332] The compound key structure may also be protected from partial evaluation by tightly
controlling accesses to a target unit's secret key in certain embodiments. For example, if the secret key is stored in an inaccessible memory location which is not architecturally visible, then it may only be accessed as a part of a particular security-related instruction or function. In certain embodiments this function or instruction is one that may not be easily reversed such as a non-trivial one-way transform. That way, even a counterfeit security system should not be able to reveal the value of the secret key. Consequently, by only letting the secret key be referenced indirectly as a part of a one-way function the secret key may be protected as the secret key can never be used by itself as a part of a mathematical operation, but only as a part of a hashing operation either alone or along with some other datum, where only the result of the hashing function may be observable.
[0333] Additional mechanisms to protect the secret key may also prove useful in certain
embodiments. One such potential mechanism is the use of a compound key, where the target unit's secret key is tightly coupled to some other constraint or a set of additional operands. Examples of such secondary operand may include a separate secret key, a globally visible register (such as a timestamp or system version number), the message digest of the code that is accessing the secret key, etc. In embodiments of such a system, this last example could ensure that the secret key may only be accessed by a segment of code that is authorized to use that very same key. Furthermore, if the message digest is encrypted to form a digital signature and if the key that is used to encrypt that message digest is the secret key itself, then a circle of dependencies can be created that can ensure that the only method to access a secret key is by using a code segment that was authored by someone who already knew what that secret key was.
[0334] In this case, the use of a compound key structure allows us to validate the "authority" of a piece of code that requests use of the target unit's secret key before it is allowed to use that key. Recall that the difference between a "layered key" structure and a "compound key" structure is that in certain embodiments, the latter may be evaluated in an atomic fashion, which itself can be accomplished by recursive means. If it is attempted to assemble a similar structure using an iterative approach, as opposed to a recursive structure, then there may be a risk of exposing the intermediate results of the key evaluation process (and thus, potentially exposing the secret key). This "exposure" may occur when secret keys (or their progenitors) are stored in publically available locations, such as general-purpose registers that are pushed out to main memory when an interrupt occurs (or even directly in memory itself).
[0335] A potential security breakdown that may be addressed in certain embodiments is the
protection of partial results when a security stack operation is interrupted in mid-evaluation and the state of the target unit's processor is then written out to main memory, where it is open to examination by outside observers. In one embodiment, to prevent this memory "exposure" heap pushes are disallowed while the processor is in secured execution mode. If that condition is enforced, then the recursive security protocol cannot be interrupted without losing its current state (since there are no intermediate arguments). It should be noted that, in embodiments of a recursive security protocol, the entire security protocol has been traversed when the recursion has terminated and the processor is running in secured execution mode, so there may be no more pushes of any arguments onto the heap in any case other than an interruption. Thus, if a compound key evaluation is interrupted at any point, and if heap pushes are disallowed in secured execution mode, then the security system stack traversal may not be restarted in mid-execution (i.e., the calculation must restart from the beginning). Thus, the recursive security protocol can be used in this manner to prevent any intermediate results from being stored on the system heap (and thus potentially exposed to unauthorized observers). Of course, in certain embodiments it is possible to disable heap operations during an iterative security system evaluation and thus, effectively requiring that such an interrupted security system operation must be restarted from the beginning. However, such an iterative approach may not enforce all of the conditions that the recursive structure provides, such as the "inside out" execution ordering the protection against "return-based" programming exploits, the ability to add subsequent security layers in a manner that does not alter the calling arguments to the original function as well as the isolation of the intermediate results and the final function output results. The mechanism by which the security system recursion terminates and the processor is allowed to enter secured execution mode will be described in more detail.
Terminating the Recursion In one embodiment, the recursion can be signaled to terminate when the message digest of a given code segment matches that supplied with the code segment itself. This
methodology may be made more robust against attack if the message digest is calculated by means of a hardware hashing function. A digital signature may also be utilized in certain embodiments. A digital signature mechanism has the potential to provide at least two main attributes: 1 ) an assurance that the code segment has not been tampered with and 2) ready identification of the code segment author. However, in the case of embodiments where such a digital signature is cached in publicly visible or modifiable locations, additional security may be desired since the digital signature itself may be modified at any time and thus may not necessarily be genuine. Thus, in these types of embodiments, a public-key system may be used to validate the digital signature or a compound key structure (as described above) may be used to assure that the digital signature provided with the code segment in question was created by some party who was in possession of the target unit's secret key. For the latter case, the use of that compound key may also be limited to a single endpoint or some set of endpoints. Additionally, both the public-key as well as the compound key approaches may be utilized in tandem. In that manner, it can be guaranteed that both the code segment is genuine as well as that the code segment is intended for the recipient of the compound digital signature.
[0337] It is also may be desired, in certain embodiments to validate the security mechanisms on the target unit. While a hardware-generated digital signature for any one segment of the security system on the target device may be utilized, in the case where the security system is recursive, a distinct digital signature can be substantially automatically generated as the security system itself is traversed. As mentioned earlier, once the execution of a recursive security protocol has terminated, the entire calling chain has been exposed. Thus, the innermost (and thus, most recent) portion of the security protocol has access to the entire environment in which it has been invoked, potentially including the calling arguments stored on the stack as well as other environmental variables that are stored in the system heap (or even elsewhere in memory). This built-in system attestation mechanism is particularly efficient as well as robust against attack since it is evaluated concurrently with the traversal of the security protocol itself.
[0338] In one embodiment, then, a set of conditions that must be in place before the "execution phase" of the security system stack traversal may be specified. In one embodiment, these conditions can be expressed as an "intersection set" of all of the individually required security conditions. That way, when new security risks are discovered additional conditions which account for those risks may easily be put in place. These conditions can ensure that no portion of the security system will be allowed to execute until all of the conditions, both new and old, are met. This "intersection set" of the various security system conditions can be achieved through the use of a compound key structure mechanism as discussed above. If, for example, one of the components of such a compound key structure is based in part on a target unit's secret key, then this secret key can be considered as one of the "Roots-of-Trust" of the entire security system. Furthermore, if a hardware-based timestamp mechanism is utilized as one of the other components of the compound key, then the system can be better protected against replay attacks. There are a number of components in addition to the above that could be employed in certain embodiments to enforce other conditions. Such components include using a hardware-based hash calculation of the message digest of a code block as a part of the compound key in order to prevent the key from being properly evaluated if the code has been tampered with. In one embodiment, another such component may be a digital signature of some selected subset of the calling arguments of the code block to be executed, which could protect against stack overflow style attacks.
[0339] In the case where the code segment has other constraints on its execution, such as time stamp or usage-related limitations, in certain embodiments, further terms can be added to the compound digital signature to ensure that those constraints are also properly enforced. It should be noted that this same mechanism can also be used to force specific multiple iterations through the various security stack layers by enforcing the proper code branching within each layer of the system, based on the correct evaluation of the intermediate security tokens.
[0340] As we have described above, embodiments of a recursive security system are
advantageous in certain embodiments where it is desired to ensure that all of the conditions are in place prior to beginning to evaluate a security token. A recursive system with its ability to enforce of inside-out security stack traversal and limits on the visibility of intermediate results can thus provide an enhanced robustness against external attack as well as flexibility when it is desired to add more constraints on the security system evaluation in a minimally disruptive fashion.
[0341 ] It should be noted here, that the recursive traversal of the security system stack does not necessarily equate to a recursive form for the overall algorithmic flow. Thus, the logical flow of the security system and that of the code threads that are making use of the system's security system may be completely distinct.
[0342] Additionally, in certain embodiments by including a set of functions to specify how the digital signature is modified as a particular code segment is parsed, the flexibility of how the digital signature is used may be increased. For example, if a code segment is allowed to pass the digital signature through the parsing process unchanged after the first iteration, then that code segment can be validated without having to specify in advance how many times the security system cycles through that particular code block. Similarly, it could be specified that the digital signature would be reset to a known "seed" state as a particular code segment is encountered. Thus, simply by supplying a single unique number (which can be stored in the clear) a unique variation of how many times and in what order the various portions of the security system are traversed may be specified. In fact, such a code validation process can be used to implement a variety of useful functions and thus, this technique does not necessarily have to be limited to the exclusive use of the security system itself.
[0343] In the case where the proper digital signature is supplied with generic code (code which may or may not be related to the implementation of security) the manner in which that particular block of code will execute on a specific target unit may be quite specifically controlled. This is a very powerful mechanism that can be used for securely distributing generic code to a set of target devices. This method of distribution may be, for example, effectively applied to free or paid upgrades to applications or to manage the spread of software viruses and other undesirable malware. In this latter embodiment, a recursive security system could be used to validate each and every code block that is a candidate for execution on a target device. Thus, a malware application or even a polymorphic viral attack on previously authenticated code segments could be prevented from executing.
[0344] In order to provide the ability to incorporate hardware dependencies into the security system evaluation, in certain embodiments, a hardware-implemented version number may be utilized as one of the compound components of the digital signature evaluation. If the hardware version number is updated each time the security system is modified (and if that update is secure), then it can be ensured that the security system is matched to the target unit on which it is executing. Note that this is distinct from the time-stamping mechanism described earlier, although the two may be used together in a compound key evaluation to protect against replay attack scenarios or other violations.
[0345] If we use a hardware-derived checksum, such as a JTAG signature, for example, as a part of our compound key structure, then the hardware implementation itself may be
authenticated. This kind of mechanism could then ensure that the software and hardware are a matched pair and that the hardware is itself authentic (or has not been tampered with). Furthermore, if the JTAG signature that is used as a part of the compound key evaluation is not directly observable (for example, it is taken from a point in the scan chain where its state is neither externally visible nor architecturally visible), then the difficulty of mounting a potential attack based on cloning the hardware can be increased many fold. This strategy can be made effective, for example, if the device's individual serial number is included in this scan chain.
[0346] It should be noted here that, from the processor's perspective, in essence, there may be no logical difference between an encrypted code block (which is not directly executable) and an "outdated" code block, which might have possibly been executable at one time, given the correct digital signature matching, but is no longer executable, because its digital signature is no longer valid. This scenario may occur, for example, because the target device's timestamp register has been changed or, alternately, if the target device's hardware has been modified in some unauthorized manner.
[0347] Thus, in the case where a particular code block is replaced with an updated version (even though both are potentially executable), in one embodiment, a simple but yet effective method for accomplishing this could be to first replace the decryption key pointer for the code block in question with a new pointer that leads to a means for replacing the old version of the code block with the updated version and then to update the target endpoint device's timestamp register. Here, the updated timestamp register value may invalidate all of the previous digital signatures that were generated using the old value and may thus entail that the entire security system be revamped (ideally in a secure manner) to bring it up to date and to replace the old digital signatures (or keys) with new key/digital signature values and updated functionality. This is a very powerful (and potentially very far-reaching) mechanism that can be easily affected with a single change to the value stored in the endpoint device's timestamp register. In this case, care should be taken that the endpoint timestamp register value does not get changed in an insecure or reckless manner. One embodiment of such a forced update scenario may be referred to as logically equivalent to adding a layer of encryption to an otherwise directly executable code block (simply by forcing a single digital signature mismatch).
Secured Mode and Secured Code Binding
[0348] In an embodiment where the system utilizes one of the architecturally invisible secret keys as described above, the code that makes use of such a key must be designed in a manner such as to prevent these secret keys from being compromised. As mentioned earlier, we can use a secured code binding mechanism to prevent the correct execution of an otherwise legitimate code block on a particular endpoint device when it is used in an unauthorized manner.
[0349] In one embodiment, this secured code binding is based on the requirement that the result of applying a specific kind of hashing function to a candidate code segment must match a specially pre-determined message digest provided with that code segment before that code segment is allowed to execute. This hashing function may be applied after a candidate code segment is called, but before it is allowed to execute. Once this hashing function has been initiated, any writes to that particular memory space comprising the candidate code segment may be either disabled or ignored. If the candidate code segment is located on the same chip as the CPU execution unit, such as in the CPU's instruction cache, then this may be easily implemented. However, in a multiprocessor system, where an l-cache may be shared between more than one processor residing on the same chip, for example, this may not be as straightforward to implement as it may seem on the surface. Another potential method to prevent the code from being modified after the message digest has been computed is to configure the system such that any attempted writes to that memory space that occur after the hashing function has been initiated will cause a processor interrupt. As described above, this may reset the processor's secure execution mode to its default initial "not secure" mode. Another response to such an intrusion might be to cause the secured execution thread to be terminated with an error by initiating a memory segmentation fault, for example.
[0350] If the calculated message digest of a candidate code segment matches the pre-determined message digest received with the candidate code segment, then the candidate code segment is allowed to execute in what is termed "Secured Mode" or "Secured Execution Mode". As described earlier, only code that is operating in Secured Mode can utilize the architecturally invisible secret key. If a particular code segment is not operating in Secured Mode, then the secret key(s) are disabled and any reference to one of them will return some other value (such as zero).
[0351 ] In certain embodiments, the hashing function utilized used in calculating the message digest for the candidate code segment may have certain properties. The first property is that the hashing function may be implemented in the hardware of the target unit. This means that this function cannot be completely replaced by some other, (perhaps subverted) version of this original hardware hashing function. It should be noted that this hashing function may be supplemented by a refined version (or even a conditioned outright replacement) of the original function when desired. In one embodiment, the method for replacing the hardware hashing function with a refined version would be substantially similar to the procedure described earlier that is used to insert new layers into the security system, through a recursive definition of the security system's structure. However, it should be noted that in this case, even though the new hashing function could replace the original function for the purposes of all subsequent security system operations, this new hashing function itself may still rely on the original hardware hashing function as the foundation of its root of trust. Thus, the use of the term "conditioned outright replacement". In one embodiment, the original hardware-based root of trust may remain constant. This may be desirable in that it can be very difficult to undermine such a hardware-based security system. However, if a shortcoming in the original hardware hashing function is found after the target device has been deployed in the field; such a shortcoming can potentially be contained by using the original hashing function in a single application, where the calling arguments can be effectively limited.
[0352] A second property of the hardware hashing function is that it may use the architecturally invisible secret key as its seed value. Thus, even given the same input arguments, the message digest result of such a hardware hashing function can differ from unit to unit. This difference can be exploited in that it could result in a unique message digest for each and every target unit. This property is similar in concept to that of a digital signature, but it does not necessarily require the addition of a separate encryption/decryption block to the hardware hashing function. Since the candidate code segment is then constrained to execute (at least in Secured Mode) only on units where the hardware-produced message digest matches that which is distributed with the candidate code segment a circular dependency has been created. This circular dependency means that only code whose message digest has been created with the secret key of the correct target unit can actually make use of this same secret key. This property substantially impairs the ability for a would- be attacker to create a code segment which would be allowed to execute in secured mode on a target device.
[0353] The mechanism described above is termed "Secured Code Binding", since a code segment can be "bound" to a particular target device (or even to a specific set of endpoint devices). As mentioned earlier, in the case where an executing block of secured code is interrupted, then the context is not saved and thus, the execution of this code segment must either be abandoned or restarted from the beginning. Also, once the execution of a code segment in secured mode is interrupted, the processor may no longer operate in secured mode and any access to the architecturally invisible secret key(s) may be cut off until the processor returns to secured mode. In certain embodiments, any off-chip store operations may also be controlled, or prohibited while the processor is operating in secured mode.
[0354] As discussed, in certain embodiments, each target unit may have a unique set of
architecturally invisible secret keys. In other embodiments, however, some subset of these keys may be common to a number of identical devices. Thus, a particular code segment can be bound to a particular class of endpoint devices with a common subset of keys, while still protecting this set of architecturally invisible secret keys that are held in common between such devices. The combination of the hardware hashing function and one or more architecturally invisible secret keys may thus provide the basis for a chain of trust for a highly effective and robust recursive security protocol.
[0355] Implementation details of the various embodiments will now be further described using the attached figures. Note that, in all of these examples, the term "Digital Bitstream" refers to a generic collection of digital data and thus, this term may be used interchangeably with the words Digital Content, Code Block or Digital Data Set. In the case of the Code Block term, the referenced data can be further assumed to represent an executable file, an executable script or even an algorithmic description or block of pseudocode.
[0356] FIGURE 24 depicts one embodiment of the creation of a compound key for digital content.
This compound key 2410 may be created by applying encryption engine 2420 to a global content key 2430 (which may be provided or determined by the owner or author of the digital content) utilizing an endpoint specific hardware key 2440, which may be an architecturally invisible secret key (as discussed above) associated with a particular endpoint device (target unit). The resulting compound key, which is specific both to the particular endpoint and the digital content may be transmitted and stored to, and stored in that clear, on an endpoint device to which the compound key is provided. [0357] FIGURE 25A depicts one embodiment of the creation of a secured digital data block structure. In this embodiment, the digital data block 2510 may not be encrypted, but a digital signature 2520 is formed by encrypting the message digest calculated by the Hashing Function 2530 from the digital data block with one or more tokens 2540 or 2550. These tokens may be either secret keys or publicly available data, such as a timestamp. Note that the methods employed to encrypt the data passing through the encryption engine(s) 2560 and 2561 may or may not be identical. In the case where a secret key is used as one of the encryption keys, then it may be more difficult to forge the Digital Signature without knowledge of that secret key value. It is also instructive to note that the order of the encryption operations 2560 and 2561 are not relevant to the overall security of the result, but the resulting Digital Signature 2520 will be different if the order of the operations is changed.
[0358] FIGURE 25B depicts an alternate embodiment of the creation of a secured code block data structure. In this case, a secret key 2570 is appended to a digital data block 2571 to form an overall message 2580. As before, it is not necessarily relevant to the robustness of the resultant security whether this appending action places the secret key 2570 before or after the original digital data set 2571 , but the end result will differ if the order is changed. Note also that, to ensure security, secret key 2570 should not be published along with the original digital data set 2571 . Therefore, the published data set would be restricted to just the digital data set 2571 rather than the entire data structure 2580. This entire data structure 2580 is then run through a hashing function 2530, in essentially the same manner as shown before with respect to FIGURE 25A. In this embodiment, however, the final output 490 has many of the characteristics of the digital signature 2520 shown in FIGURE 25A, but may not require the use of encryption engine(s) 2560 or 2561 . Thus, the result 2590 of this operation will be referred to as a digital signature equivalent. It should be noted that this digital signature equivalent 2590 is unique (assuming that the hashing function 2530 is properly constructed) for each unique overall data structure 2580. Thus, if the secret key 2570 is shared only by the author of the digital data set 2571 and the consumer of that digital data set (the endpoint device or target device), then only these two parties should be able to recreate the same correct digital signature equivalent 2590. In this case, digital data block 2571 may be considered to be "bound" to that secret key 2570 (and thus, to the target device).
[0359] FIGURE 26A depicts one embodiment of how a security system such as that described herein may be used to cryptographically bind an encrypted data block 2610 to a specific decryption engine code block 2662 and then to bind that combination 2630 to a specific endpoint's hardware secret key 2623 using a digital signature 2624 that is calculated by means of hashing function 2640 and an encryption engine 2661 . Note that, in this example, the Public Key 2622 (which is constructed by encrypting the message digest 2621 of the Decryption Engine Code Block 2662 with the Global Content Secret Key 2620) is publicly distributed along with the original encrypted data block 2610 as a single concatenated data set 2630. The act of creating a digital signature 2624 from the message digest of the combined message 2630 (which comprises the original encrypted data block 2610 combined with the Public Key 2622) ensures that only the properly authorized endpoint devices are able to decrypt the original encrypted data block 2610, and not only that, but that this decryption process can only be accomplished by using the prescribed method of Decryption Engine 2662. Note that more constraints can be easily added to the decryption authorization procedure by adding more components to the encryption engine chain 2660 (such as a multi-term compound encryption, for example).
[0360] FIGURE 26B depicts a variation of the embodiment shown in FIGURE 26A. In this
embodiment, the author of a particular encrypted message 261 1 can be unambiguously authenticated, but only on a specific endpoint device. Here, the original encrypted data block 261 1 is cryptograph ically bound to a specific decryption routine 2662, as described above. At this point, it can further be specified that decryption routine 2662 is an asymmetric encryption engine, where the input may be the author's secret private key 2625, and the output would only be correctly decrypted using the author's public key. The message digest 2627 of asymmetric encryption routine 2662 is appended along with digital signature 2626 to the original encrypted digital data 261 1 to form an overall data structure 2631 . Data structure 2631 can then be cryptograph ically bound to a specific endpoint device by using that endpoint device's secret key 2623, hashing function 2644 and encryption engine 2661 to form digital signature 2628. With this embodiment, it can be ensured that the encrypted message 261 1 is genuine and its author is known as well as the fact that the author is in possession of the hardware secret key 2623. It should be noted here that the term author as used herein does not necessarily mean the originator of data but may also refer to a licensor, distributor, or another type of entity which wishes to distribute or otherwise communicate such data. One example where this particular chain of trust can be of significant use is in the case where the endpoint device's security system is to be updated using a secured code block (which would be contained in encrypted form in the original data block 261 1 ).
[0361 ] FIGURE 27 depicts one embodiment of utilizing a cascaded hashing method in order to control the execution of a secured code block 2720. In this case there are two independent code blocks 2710, 2720. In this example, the first code block (secured code block 2710) includes an embedded subroutine call to the second routine (secured code block 2720). Thus, the message digest 2730 computed by the hashing function 2740 for secured code block 2710 is dependent on the reference to secured code block 2720 that is contained inside secured code block 2710. This message digest 2730 then links the two secured code blocks together from the perspective of secured code block 2710. Next, the message digest 2750 may be constructed for code block 2720 using hashing function 2770. However, in order to tie the message digest 2750 to both secured code block 2720 as well as its calling parent routine (in this case, secured code block 2710), the original message digest 2730 may be used as a seed to the message digest 2750 that is computed by hashing function 2770. Recall that such a seed value can be implemented in many ways, but one such method is to simply concatenate the original message digest 2730 to the second digital data set (for example, in this case secured code block 2720) to form an overall message 2760. Overall message 2760 is then run through hashing function 2770 (which can either be identical to hashing function 2740 or it can be some other independent hashing function) to form a second message digest 2750, which is thus dependent on both secured code block 2720 as well as the original message digest 2730 (which is itself dependent on both secured code blocks 2710 and 2720). As we noted in the discussion of FIGURE 25B, the order of these concatenated elements 2720 and 2730 may be important to the resulting message digest 2750, but in the case of hashing function 2770, the order of the elements comprising the overall message 2760 may have no substantive impact on the security of hashing function 2770.
[0362] This second message digest 2750 can then be used in a manner substantially similar to that described above to ensure that secured code block 2720 may only be executed correctly if it is called from code block 2710. Note that code block 2720 may actually be an exact duplicate (or equivalent reference) of code block 2710, which would make this an embodiment of a recursive system. The only difference between the two instantiations of the same code block may be the particular message digest that is appended to the code block in order to form the secured code block message digest.
[0363] In this particular embodiment, note that we have not used any secret keys, so this type of structure can be used without specificity to enforce the proper execution order on any endpoint device that is using the same overall security system as described herein. Also, as before, a similar example may be constructed where the execution of either of the secured code blocks 2710 or 2720 is additionally constrained to a certain specific endpoint device or set of devices by utilizing a compound key-based digital signature structure or its equivalent in place of message digests 2730 or 2750 respectively.
[0364] FIGURE 28A depicts embodiments of the construction of a secured code block message. In one embodiment, the Encrypted Digital Data Set 281 1 has been encrypted using an encryption algorithm that is identified by pointer 2820. The data structure 2830 is formed by a concatenation of Digital Data Set 281 1 and Pointer 2820. The message digest 2850 of data structure 2830 is generated by hashing function 2840. This arrangement allows the cryptographic binding of an encrypted data set and its associated decryption routine.
[0365] In the second embodiment, an additional term is added to the concatenated data structure 2831 , namely the pointer 2821 to the decryption key 2860. It should be noted that this key 2860 is not necessarily a hardware-based secret key as is depicted in this particular embodiment. In fact, the key 2860 that is pointed to by pointer 2821 may even be itself a data structure, as will be discussed in the description of FIGURE 28C below. Otherwise, this embodiment is substantially similar to previously described embodiments. Encrypted Digital Data set 281 1 is created as a result of using encryption engine 2870 and one or more keys 2860 operating on the original unencrypted data set 2810. The message digest 2851 is generated using Hashing Function 2841 on the concatenated data structure 2831 . In this case, there is now a mechanism for cryptographically associating the unencrypted data set 2810 with both the encryption engine 2870 as well as the unique key 2860 that can be used to recreate the unencrypted data set 2810 from the encrypted data set 281 1 . As with previous embodiments, additional terms may be added to the encryption chain in order to cryptographically bind the entire structure to a specific set of conditions that are to be satisfied on a given endpoint device and its unique secret hardware key 2860. It is worth noting that the format and encryption status (i.e., is it encrypted or not) of the digital data sets 2810 and 281 1 may not be relevant to this process, since these details can be inferred from the pointers 2820,2821 .
[0366] With this in mind, FIGURE 28B depicts one possible embodiment for a basic generalized format for a Universal Cryptographic Data Structure that can thus be used in a recursive security system. Embodiments of this structure may be simple and powerful, and can be implemented as a simple linked list of three basic elements; a generic data block 2812, a decryption pointer 2820 and a decryption key pointer 2821 . The overall linked list is bundled together in a data structure 2832. By using a linked list, it can easily be seen that the ordering of the elements in the concatenated data structure 2832 may not be relevant to its function, although it may have an impact on the operation or evaluation of the data structure. Another interesting aspect of using a generic (for example, not predefined) data block structure and a linked list format is that the three elements 2812, 2820 and 2821 also do not necessarily have to be ordered linearly or even contiguously. Thus, one embodiment may comprise an auxiliary data structure 2813 that includes some other independent, but perhaps related, data that is stored in conjunction with the overall data structure 2832. One embodiment of this concept might be to locate the actual decryption engine code block 2871 , such as that which is pointed to by pointer 2820 inside the auxiliary data structure 2813 of FIGURE 28. Another such example could be to store the actual key value that is specified by pointer 2821 inside this auxiliary data block.
[0367] In both of these cases, the actual data contained in such auxiliary data blocks may be used in the process of generating a message digest or a digital signature as depicted variously in the embodiment examples presented in FIGURES 25A, 25B, 26A, 26B, 27 and 28A. As has been noted in this disclosure, the ordering of the various data fields stored in a concatenated data set may have an impact on the resulting message digest (or digital signature), if the hashing function is properly designed.
[0368] It will be apparent then, that a similar block structure may also be used to secure the keys that are utilized in certain embodiments. FIGURE 28C depicts one embodiment of such a secured data block 2833 which comprises only keys. Here, a data block may comprise a list of device specific keys 2814, 2815, 2816 (or others, as desired). In this example, any of these keys may have been created using (for example) a secret key of an endpoint device 2860, and an endpoint device timestamp register 2890, which were encrypted using encryption engines 2871 and 2872 respectively. As was the case in earlier descriptions of such operations from a perspective of the security system's robustness, there is no requirement that encryption engines 2871 and 2872 should be distinct or even different and there may no fundamental limit to a certain number of these encryption operations in the encryption chain and, while the order of these operations may matter to the resulting compound keys, there is no requirement for a particular order for the encryption operations. One other feature of note in this case is that the key list pointer element 2821 of the concatenated key list data structure 2833 may point to yet another concatenated key list data structure 2834. Since both of these data structures are of the same universal cryptograph ical format as depicted in FIGURE 28B, the key list data structure can be formed in a recursive manner. Accordingly, the keys 2833 for use in embodiments of such in a recursive security system may be protected in the same manner and using the same structures as any other data to which embodiments of such a security protocol may be applied and similarly, these protected keys may also be decrypted and authenticated on an endpoint device in the same manner as other data secured by embodiments of the systems and methods disclosed herein.
[0369] Turning now to FIGURE 29, one embodiment of how a compound key may be utilized to decrypt encrypted content is depicted. This decryption operation may occur in "secured mode", as described above. Here, content 2910 may be provided to an endpoint device along with a compound key 2930 where the content has been initially encrypted using a global content key. The compound key 2930 may be created as described above in FIGURE 24. Accordingly, when the encrypted content 2910 is received at an endpoint device it may be received with an associated compound key 2930. Executing in secured mode, such that the secret key 2940 at the device may be accessed, the compound key 2930 may be decrypted inside of secured code block 2960 to yield the global content key. The global content key may be used, in turn, inside secured code block 2960 to decrypt the original encrypted content 2910 to yield decrypted content 2980.
[0370] FIGURE 30 depicts one embodiment of how a secret key may be utilized to verify that a code block is authorized to run on a particular endpoint device before execution. Candidate code block 3010 for execution may be provided to an endpoint device or may be obtained by decrypting encrypted digital content which was received (for example, as depicted earlier in FIGURE 29). Additionally, the endpoint device may receive a corresponding digital signature 3020 corresponding to the candidate code block 3010. This digital signature 3020 may comprise a message digest created from a code block (for example, by hashing that code block) which has been encrypted using the endpoint device hardware specific secret key 3030. Thus, to verify whether the candidate code block 3010 may be executed, an authentication operation may be implemented in secured mode whereby the candidate code block 3010 is hashed to create a message digest (3012). This message digest 3012 can then be encrypted using the endpoint device hardware specific key 3030 of the endpoint device (which may be accessible because the verification is occurring in secured mode) to create a digital signature that is compared with the originally supplied digital signature 3020 in step 3014. If this digital hardware-generated digital signature matches the received digital signature 3020 corresponding to the candidate code block 3010, then the candidate code block 3010 may be considered verified and may be deemed executable, otherwise an exception error may occur (step 3016).
FIGURE 31 is a block diagram of one embodiment of how a code block may be allowed to run on a particular endpoint processor (under prescribed circumstances) in "secured execution" mode. In this particular case, the pre-computed digital signature 3130 (which can also be referred to as an endpoint-specific decryption key) of the code block 31 1 1 is constructed using the message digest of the code block and encrypting it with one or more of the following: the secret key 3140 of an authorized target endpoint device, the most recent timestamp value 3141 of the authorized target endpoint device, or one or more of any number of constraining conditions as described earlier (not shown in this particular embodiment).
[0371 ] It should also be noted that any one of these terms could also be pre-conditioned by
applying a masking function to a subset of the term itself. For example, if a number of the least significant bits of the timestamp field are masked off (and thus may not be considered in the calculation of the digital signature), then the effective granularity of that timestamp value can be easily controlled on a code-segment by code-segment basis without any changes in the hardware. This same principle can be applied to any number of the terms that are used in the calculation of the digital signature in certain embodiments.
[0372] As with the key list data structure depicted in FIGURE 28, the concatenated digital data set 31 10 that contains code block 31 1 1 also includes at least one decryption pointer 31 12 and at least one decryption key or key list pointer 31 13. Also as described before, either one of these may refer to an external data structure (such as the Endpoint Specific Digital Key or Digital Signature 3130) or to an embedded data structure that is wholly contained within the concatenated data set 31 10.
[0373] For purpose of describing the embodiment shown in FIGURE 31 , it will be assumed that code block 31 1 1 is not encrypted (and is thus potentially executable on the endpoint device target processor). In this case, the decryption pointer may be null, since there is no further decryption required for the code block 31 1 1 prior to its use. When the code block is not encrypted, as it is in this case, then its corresponding decryption key (pointer) 31 13 may point to the associated endpoint or hardware-specific digital signature 3130. Thus, embodiments of data structures and methods such as those depicted earlier in FIGURES 25A, 25B, 26A and 26B may be used to enforce a wide variety of authentication, cryptographic binding or other constraints on the use of an unencrypted data set such as depicted in block 31 1 1 .
[0374] In the case where the endpoint specific digital signature (or decryption key) 3130 points only to the hardware secret key 3140 or alternately, only to the hardware secret key 3140 and the endpoint device timestamp register 3141 , then we can determine that the security system related calls have reached the "bottom" of the calling chain and that there will be no further calls to additional layers of the security system in this particular calling chain. Thus, the security system recursion has "terminated" at this point. This recursion termination condition is detected by hardware block 3150, which acts as a "gatekeeper" to selectively allow or deny access to the value of the endpoint specific hardware secret key 3140, and then only as an input component to a cryptographic function that uses output of the hardware hashing function block 3161 . In the example shown in FIGURE 31 , the hardware specific secret key 3140 and the (message digest) output of hardware hashing function block 3161 are used as input arguments to encryption engines 3162 and 3163.
[0375] Finally, if the output of encryption engine 3163 (which is a digital signature of the original concatenated data structure 31 10) then matches the value of digital signature 3130 that was supplied, the "Secured Mode Enabled" hardware bit 3170 is then set. This condition indicates that the candidate code block 31 1 1 that was loaded into the endpoint hardware I- Cache 3120 is now authorized to execute in "Secured" mode. Note that there is no physical change to the candidate code block 31 1 1 that resides in l-cache 3120, nor is there any change to the l-cache 3120 itself. The only thing that has changed at this point is the value of the "Secured Mode Enabled" hardware bit 3170.
[0376] FIGURE 32 depicts one embodiment of a decryption operation which may be performed by a recursive security system. This decryption operation may use a compound key to validate a secured code block that is to be used in the process of decrypting or otherwise manipulating and making use of distributed content. As described above, an endpoint device may receive a data structure 3210 containing encrypted content 321 1 , a pointer 3212 to a decryption engine 3220 (or the decryption engine itself) and a pointer 3213 to an Endpoint-Specific Compound key 3230 (as discussed earlier with respect to FIGURE 30). Before it is allowed to execute in secured mode, the compound decryption engine 3240 pointed to, or received, will be authenticated. This authentication may be accomplished by calculating the message digest 3222 of the compound decryption engine 3240 code block using the hashing function 3221 resident in the endpoint device. Note that, although the hashing function 3221 is depicted as being a hardware block in this example, this hashing function 3221 may be, for example, a secured software code block that can be used in place of the endpoint device's built-in hardware hashing function, as was discussed earlier. In this case, however, the software version of the hashing function may still ultimately depend on the built-in hardware hashing function for authentication or authorization purposes, so the eventual root of trust in this case still resides with the endpoint's built-in hardware hashing function block 3221 .
[0377] The message digest 3222 generated by this hashing block 3221 may then be compared in step 3223 against a pre-computed message digest 3250 that corresponds to the decryption engine 3240. This pre-computed message digest 3250 may for example, have been provided to the endpoint device in a secure fashion, or pre-computed and stored on the endpoint device itself. If the message digests match, then the compound decryption engine 3240 may be allowed to execute on the endpoint device (step 3225). If the message digests are not substantially identical, then an invalid code exception may occur (step 3226).
[0378] If however, the message digests are substantially identical, the processor of the endpoint device may then enter secured execution mode to execute the code contained in the compound decryption engine 3240. The first part of this compound decryption engine 3241 may be accomplished utilizing the endpoint device's hardware-specific secret key 1 131 to generate the global content specific key from the compound key (step 3232). The second decryption operation 3242 may then use the intermediate result generated by decryption operation 3241 in order to generate the decrypted content 3252 from the encrypted content 3210, using the obtained global content specific key. It should be noted here that while decryption engine 3240 is depicted as a pair of decryption algorithms (3241 and 3242), it may encompass any fewer or greater number of cascaded decryption stages such that the final result of the operation of the various individual components (3241 , 3242, etc.) of secured code block 3240 applied to the original encrypted data set 3210 will produce the desired decrypted content result 3252. It should also be noted that any two of these various individual decryption components may be either the same or different algorithms.
[0379] In certain embodiments, it may additionally be desired to layer further security thus, in some embodiments, a compound key may be formed from the pre-computed message digest using an endpoint device specific hardware key and an endpoint specific timestamp value, in substantially the same manner as was depicted earlier with respect to FIGURES 25A, 28C and 31 .
[0380] FIGURE 33 depicts one embodiment of the implementation of a recursive security protocol at an endpoint device. Specifically, one embodiment of the use of a set of compound keys for the validation of a secured code block as well as for the actual decryption /or other use of a distributed digital bitstream is depicted. This embodiment is similar to the embodiment depicted in FIGURE 32 in many aspects so only those aspects of the embodiment that are different will be concentrated on with respect to FIGURE 33. A message 3310 comprising encrypted content 331 1 may be received including a pointer 3312 to a decryption engine 3340 (or the decryption engine itself), a content specific compound key 3331 (as discussed with respect to FIGURE 29) and an endpoint and time stamp specific compound key 3332. The encrypted content 331 1 can be loaded into memory at the endpoint device and the pointer 3312 to decryption engine 3340 may also be loaded into memory (for example, the instruction cache or secured portion of the instruction cache at the endpoint device). The decryption engine 3340 pointed to will then be authenticated. This authentication may be accomplished by computing the message digest of the encryption engine 3340 using the hashing function 3321 that is resident in the endpoint device, in a substantially similar manner as was described with respect to FIGURE 32.
[0381 ] In this example, the hardware-generated message digest may then be encrypted using an encryption engine, which may be implemented either in hardware or in software on the endpoint device, and which comprises one or more cascaded compound encryption engine stages 3324, 3325, etc. that operate on the computed message digest and one or more of the hardware specific keys or registers, such as the endpoint device hardware specific secret key 3370 or the value of the endpoint device timestamp register 3360. The resulting compound digital signature 3326 that is generated may correctly correspond to the decryption engine code block 3340 and may also thus be cryptographically bound to the specific endpoint device (by using one or more encryption stages 3324, 3325 and the various secret or public variables or constants such as 3360 and 3370). As was discussed earlier, this generated digital signature may optionally be further encrypted (using either the same or different encryption engines) and other constraining variables or constants in order to further limit the applicability of this compound digital signature. Also, in the case where it is desired to extend the application of the code block 3340 that is associated with this digital signature 3332 beyond a single unique endpoint unit, for example, one or more of the encryption stages may be optionally limited in order to broaden the field of potential generated compound digital signature matches.
[0382] The generated compound digital signature 3326 may then be compared in step 3323 against the endpoint and time stamp specific compound digital signature 3332 corresponding to that encryption engine 3340 which may have been originally provided to the endpoint device (for example, by a licensing authority as a part of the endpoint code licensing process at a prior point). Note that the data structure may be identical whether this token 3332 is a digital signature or a key, so the terms "key" and "digital signature" may possibly be used interchangeably in those cases.
[0383] If the compound digital signatures 3326 and 3332 are substantially identical, the processor of the endpoint device may then be allowed to run the code contained in the decryption engine code block 3340 in secured execution mode. When running in secured execution mode, the decryption engine 3340 may then make use of the endpoint device's hardware key 3370 to generate the global content-specific key from the device-specific compound key 3331 using decryption engines 3341 or 3342. The global content-specific key may thus be an intermediate result and accordingly may never be cached or otherwise made visible to any software or hardware entities other than the compound decryption engine code block 3340. This global content-specific key is then used, by way of decryption engine 3343 to generate the final decrypted content 3350 from the original encrypted content 331 1 .
[0384] If, however, the generated digital signature 3326 does not substantially match the supplied digital signature 3332, then there may be several possible reasons why the mismatch may have occurred, including the case where attempts to make use of decryption engine code block 3340 are made by unauthorized parties. However, another possible reason for a mismatch may be the case where the software for decryption engine has been updated (and the endpoint's timestamp register has likewise been incremented or otherwise changed). In this case, the two digital signatures may not match and it may be checked in step 3381 if the encryption engine code 3340 is either itself encrypted (for example) or otherwise in need of replacement. Recall that embodiments discussed herein may be effectively utilized for a recursive security protocol, thus in many cases encryption algorithms (which may be pointed or included with encrypted content) may themselves be encrypted, these encrypted encryption algorithms themselves encrypted, etc. As such, if the generated endpoint and time stamp specific compound key 3326 for an encryption algorithm and the received endpoint and time stamp specific compound key 3332 do not match it may be the case that at least one more layer of indirection or encryption has been utilized.
[0385] As mentioned earlier, the concept of adding a layer of encryption to a particular executable code block can be logically equivalent with the act of replacing an outdated version of a particular code block with a newer version of that code block. Accordingly, it can be determined if the decryption engine 3340 is itself either encrypted or otherwise in need of replacement (as indicated in step 1282), as indicated by examining one or more of the following tokens associated with that code block: the endpoint and timestamp specific compound digital signature 3332, the code block's decryption pointer (not shown) or the code block's decryption key pointer (also not shown). In one example, if the code block's 3340 associated decryption pointer points to a null value, it would indicate that the encryption engine 3340 is not encrypted or otherwise outdated and thus, an exception error may result (step 3383), since the generated digital signature 3326 and the supplied digital signature 3332 are not substantially identical but there may be no other recourse for replacing the code block with a different version that may possibly produce the correct digital signature. If, however, the decryption engine code block's 3340 decryption pointer points to another code block; either another (possibly updated) encryption engine (not shown) or some other code block, then this new code block may be loaded and the authentication steps above applied to this next encryption engine (in other words, another layer of recursion may be introduced). This recursive execution mechanism may continue until it is determined that a match between an generated endpoint and time stamp specific compound digital signature 3326 and the supplied endpoint and time stamp specific compound digital signature 3332 occurs (at step 3327) or that it is determined that there is no match and the decryption engine 3340 itself is not encrypted, at which point an exception error may occur (step 3383).
[0386] If it is determined that a generated endpoint and time stamp specific compound digital
signature 3326 and the supplied endpoint and time stamp specific compound digital signature 3332 match, then the recursion is terminated and may be unwound. This may entail the authentication and execution of each of the code blocks that were encountered and saved on the stack during the initial forward pass through the overall recursive calling chain. It should be noted that some or perhaps even all of these code blocks may not necessarily be encryption or decryption engines. In any case, each of these code blocks may be authenticated while the processor of the target endpoint device operates in secured execution mode.
[0387] This execution may be better explained with reference to FIGURE 34, which depicts one embodiment of a decryption operation that may be performed by a recursive security system. As described, an endpoint device may receive a message 3410 that may contain, among other things, encrypted content 3412 along with a content specific compound key 3416 (as discussed with respect to FIGURE 29), a pointer 3413 to an decryption engine data structure 3420 or the decryption engine itself, if it is embedded in the original message 3410 and a key list pointer 3414, that may point to a key or key list data structure 3418. As discussed earlier, this data structure may include a key or key list 3416 or a digital signature 3417. The decryption engine data structure 3420 may, in turn, contain an encrypted code block 3421 , a subsequent decryption pointer 3422 associated with the encrypted (or alternately, obsolete and in need of replacement) decryption code block 3421 and an associated decryption key list pointer 3423. The subsequent decryption pointer 3422 may point to a final decryption code block data structure 3430, which has structure substantially similar to that of decryption code block data structure 3420, except that, in the case of data structure 3430, the decryption code block 3431 is not itself in encrypted form.
[0388] The operation of the embodiment as depicted in FIGURE 34 can be explained as follows.
Encrypted Content data structure 3410 is loaded into the endpoint processor's memory space in anticipation of decrypting the encrypted content 3412 contained within. Since the data structure 3410 contains a decryption pointer 3413, the associated decryption engine code block data structure 3420 is located and read into memory. Since this subsequent data structure 3420 also contains a decryption pointer 3422the decryption engine code block data structure 3430 associated with pointer 3422 is then located and loaded into memory. For data structure 3430, the embedded decryption pointer 3432 in this example is determined to be a null pointer, so the target endpoint device's security system is thus able to determine that the current decryption recursion chain has terminated (as discussed, for example, in FIGURE 31 ) and thus, the decryption engine 3431 that was just read into memory as a part of data structure 3430 may contain an unencrypted (and thus potentially executable) code block.
[0389] Since it can be determined that digital content 3431 is a code block and not data (by the manner in which it was called), then it can also be determined that the key list data structure 3438 that is pointed to by the decryption key list pointer 3433 (which was read into memory as a part of data structure 3430) may contain a digital signature 3437 (in addition to a compound key 3436). It should also be noted that the key list data structures in this example (3418, 3428 and 3438) may be implemented using the universal cryptographic data structure as depicted earlier with respect to FIGURE 28B. Thus, the order of the arguments in these key list data structures 3418, 3428 and 3438 is not necessarily fixed and they may therefore be interpreted at runtime as the data structures themselves are traversed. In fact, it should be noted that these key list data structures (3418, 3428 and 3438) may themselves include references to further decryption or subsequent interpretation by incorporating supplementary decryption pointers and key list pointers within any or all of these key list data structures (3418, 3428 and 3438) themselves, although this particular option was not pictured in the embodiment of FIGURE 34 for the sake of simplicity.
[0390] It can further be determined that at least one of the key pointers 3436 in the key list data structure 3438 corresponds to a reference to the endpoint's hardware secret key 3492. This reference to the endpoint's hardware secret key 3492 may be accomplished either explicitly by pointing to an appropriately reserved memory location (a location that may be specified in the processor's architecture, even though it may never be directly read by the processor and thus, not directly architecturally visible) or implicitly, by using some specially reserved value for the pointer. In either case, this reference may implemented using various means, but an example one such embodiment may be to equate the value of "0" (as distinct from the value of "null") in the key list data structure to a reference to the endpoint's hardware secret key 3492. The fact that at least one part of the key list data structure refers to the endpoint's hardware secret key 3492 may further indicate that the decryption engine code block 3431 is intended to run in secured execution mode on the target endpoint device's processor. Thus, the output of hardware-based digital signature generator block 3490 is compared with the value stored in data structure 3437. In the case where the two values substantially match, then the processor is allowed to enter secured execution mode.
[0391 ] It should be noted here that hardware-based digital signature generator block 3490 (the details of one embodiment of which will be presented more comprehensively with respect to FIGURE 36) may, in one embodiment, comprise one or more software-based elements, but may also incorporate at least one hardware-based security component, either directly or indirectly, as discussed earlier. That hardware component is the hardware-based hashing function that has been referenced in many of the earlier descriptions contained herein, and which comprises the overall target endpoint unit's security system root of trust. [0392] At this point, then, decryption engine code block 3431 is allowed to run in secured execution mode, which allows the endpoint processor to potentially make use of the endpoint's hardware device-specific secret key 3492 as a part of a security-related computation (as has been described earlier herein). In the case where the processor was not operating in secured execution mode, then the value of secret key 3492 would not be available for use in such a security related computation. This concept is depicted with respect to FIGURE 34 as hardware access control block 3443, which will only allow the value of secret key 3492 to pass through to subsequent use (for example in decryption engine code block 3431 ) if the processor is running in secured execution mode.
[0393] In addition, it can be seen that one of the input parameters to hardware access control block 3443 is the output of access control block 3441 . In this manner, the state of hardware access control block 3443 (which is effectively the "secured execution mode enabled" indicator for decryption code block 3421 ) is dependent on the fact that decryption code block 3431 was also running in secured execution mode. This may be indicated by the state of the "secured execution mode enabled" indicator for decryption code block 3431 (for example, the output of hardware access control block 3441 ). This dependency constrains the ability of decryption engine code block 3421 to be able to run in secured execution mode only if decryption code block 3431 was also running in secured execution mode. In an essentially identical manner, the output of hardware access control block 3443 is used as one of the inputs to hardware access control block 3445, which is the "secured execution mode enabled" indicator for decryption code block 341 1 . Thus the mechanism that allows the "secured execution mode enabled" bit to be propagated back up the calling chain in the reverse direction, for the purposes of authorizing the preceding parent code blocks to run in secured execution mode only if they are both authenticated properly (as will be explained in more detail with respect to FIGURE 35) and if they are supplied with authentic decryption results from properly authorized portions of the security chain from lower down in the recursive calling chain. Note that, as described earlier, any one of several conditions may cause any of the "secured execution mode enabled" bits to be reset to a "non-secured" default state (and thus, potentially require the entire security chain to be restarted). Such conditions may include a processor interrupt or a subsequent digital signature comparison mismatch. Although these hardware access control blocks 3441 , 3443 and 3445 are depicted as separate entities for purposes of clarity in FIGURE 34, it can be seen that they may, in fact, be embodied in a single hardware unit (such as that described with respect to FIGURE 36), whose output is thus fed back as one of its own input terms. Ultimately, the output of the highest-level or final "secured execution mode enabled" bit in the overall chain (in this embodiment, the output of hardware access control block 3445) may be used as part of a control mechanism to enable or disable some externally-visible output for the target device (such as an audio or video output enable, for example).
[0394] The action of decryption engine code block 3431 in step 3470 is to replace or otherwise supplement the data set stored in the decryption engine code block portion 3421 of data structure 3420 with an updated and/or properly executable version of the original data. This action may be accomplished utilizing the original data that was stored in 3421 and decrypting it with one or more decryption keys that are stored in or pointed to by key list data structure 3428. Alternately, as was discussed earlier, the action 3470 of decryption engine code block 3431 may be to either replace the decryption code block 3421 with an updated version or even to execute directly in place of decryption engine code block 3421 . In any case, decryption engine code block 3431 may first operate using various input data, including (in this embodiment) the value contained in the target endpoint device's timestamp register 3494, the target endpoint device's hardware-specific secret key 3492 (as modified by passage through hardware access control 3442) and endpoint and timestamp-specific compound digital key 3426. In the case where decryption engine code block 3431 is then subsequently operating as a direct replacement of decryption engine code block 3421 , it may then utilize a second set of input data (for example in this embodiment, the value contained in the target endpoint device's timestamp register 3494, the target endpoint device's hardware-specific secret key 3492 (as modified by passage through hardware access control 3444) and endpoint and timestamp-specific compound digital key 3416.
[0395] A further action of the updated decryption engine code block 3421 in step 3471 is to replace or otherwise interpret the original encrypted content data 3412 in order to produce the desired output data 3480. This action may be accomplished utilizing the original data that was stored in 3412 and decrypting it with one or more decryption keys that are stored in or pointed to by key list data structure 3418. Since the actions of both decryption engine code blocks 3421 and 3431 are similar in nature, is should be evident that any of the options detailed earlier in the description of the operation of decryption engine code block 3431 are equally applicable to the operation of the updated version of decryption engine code block 3421 . Also, in the case of the operation of decryption engine code block 3421 , it should be noted that in some embodiments, the associated hardware access control block 3444 is distinct from hardware access control block 3442. The actions of these two hardware access control blocks 3442 and 3444, however are similar in nature in that their purpose is to enable or disable the use of the target endpoint device's hardware-specific secret key 3492 by their associated decryption engines 3431 or 3421 respectively and thus in other embodiments may not be distinct. [0396] Finally in all of the operations depicted in the embodiment of FIGURE 34 described above, the use of the target endpoint device's timestamp register 3494 is essentially similar to those examples described earlier herein for other embodiments. Thus, it follows that the value stored in register 3494 may be used as an additional element in the generation of the various compound keys and/or digital signatures that are employed in the different authorization and decryption operations described in the particular embodiment depicted in FIGURE 34.
[0397] FIGURE 35 depicts one embodiment of how a recursive calling chain may be traversed and terminated and how a processor may be allowed to enter into secured execution mode using a message-digest based authentication of one or more embedded code blocks. In this embodiment, the operation of two candidate code blocks 3512 and 3522 may be explained, both of which may be contained within universal cryptographic data structures (351 1 and 3521 respectively) as was discussed earlier with respect to FIGURE 28B.
[0398] Notice that the code block data structure 3521 is represented twice in FIGURE 35. This duplication was illustrated to represent separate iterations for the sake of clarity, although it should be noted that this is exactly the same data structure in both instances. One difference that may be noticed, however, is in the key list data structures 3528 and 3538 that are pointed to by the instances of key list pointer 3521 . Even though the value of key list pointer 3521 does not vary between the two instances shown in this figure, the values contained within (or pointed to by) key list data structure 3528 may change between the two iterations, and so this detail is indicated by renumbering the data structure (and its various
components) from 3526, 3527 and 3528 to 3536, 3537 and 3538 respectively. The fact that this structure is renumbered does not necessarily indicate that the actual location of the data structure has moved, just that its contents may have changed. Likewise, the hardware hashing function 3580 is also depicted multiple times in this figure, for the same reason of increased clarity. Finally, note that neither of the two candidate code blocks 3512 or 3522 are encrypted, and so their associated decryption pointers 3516, 3526 and 3536 may be all null pointers.
[0399] In this embodiment, a call to candidate code block 3512 may be initiated. In the same
manner as has been described previously, the code block data structure 351 1 may be read into memory and its message digest 3541 may be computed by means of hashing function 3580 (which may be realized either wholly or partially in hardware, as was described previously). However, in this embodiment, the hashing function may be given an initial seed value 3540 (which may, or may not, be set to all zeroes). As was discussed earlier, this hashing function seed value feature may be implemented using one of a number of methods, but in this embodiment the seed value 3540 is known and the method by which it affects the message digest output 3541 of hashing function block 3580 is both repeatable and deterministic.
[0400] Once the result 3541 of the hashing function is generated, the processor can begin
executing the code contained in code block 3512. In the embodiment shown in FIGURE 35, where both the decryption pointer 3513 and the values of both of the locations 3516 and 3517 (which are contained inside key list data structure 3518) that is pointed to by the key list pointer 3514 are all null, then code block 3512 may not be designed to run in secured execution mode and therefore does not require the use of any of the target endpoint unit's security hardware features. The processor thus begins to execute the instructions contained within code block 3512 until it reaches an embedded subroutine call that points to code block 3522.
[0401 ] At that point, code block data structure 3521 is loaded into memory and the process of generating the next message digest 3542 is repeated by the hashing function block 3580. In this particular instance, however, the hashing function seed value may no longer be the initial seed value 3540, but rather the previously generated result 3541 . Thus, the value of message digest 3542 can be seen to be deterministically dependent on the message digest of both code blocks 351 1 and 3521 . However, as in the previous case, the values of decryption pointer 3523 and those contained in the key list data structure 3528 pointed to by key list pointer 3524 may still be null, so the processor continues on in non-secured execution mode as before.
[0402] At some later point, the processor encounters another subroutine call, but in this example, code block 3522 contains a recursive call (for example, a subroutine call to itself). It should be noted that in certain embodiments, such a recursive calling structure is illustrative only and correct operation of the target endpoint device's security system may be achieved by other means, for example, be ensuring that any calls to the security system are contained within a single layer of code. However, as soon as multiple levels of the security system are to be traversed, then the recursive calling form may be relatively more secure, as detailed earlier, and may be effectively utilized to implement a security system in conjunction with the depicted embodiment.
[0403] In any case, when the processor encounters the subroutine call embedded inside code block 3522 (which references itself), then the code block data structure 3521 is once again loaded into memory (for example, in most contemporary systems, the data structure 3521 may be loaded to a different physical location the second time it is fetched) and the hashing function 3580 calculates the new message digest 3543. Notice that this new message digest 3543 is - i dependent on the initial message digest seed value 3540, message digest 3541 (of code block 3512) as well as the message digest of two separate iterations of code block 3522.
[0404] Also note that this second time, the key list pointer points to a new data structure 3538, that contains a non-null digital signature value 3537. This non-null value is an indicator to the security system that this iteration of code block 3522 contains a reference to the target endpoint hardware specific security system. Thus, in this embodiment, in order for such a reference to operate properly, the processor must enter secured execution mode at some point. Thus, the digital signature 3543 generated when code block data structure 3521 was most recently loaded into memory may then be compared to the digital signature 3537 contained within key list data structure 3538. In the case where the two values are found to be substantively similar in step 3591 , then the target endpoint processor is allowed to enter secured execution mode. If, however, the two digital signature values 3537 and 3543 do not match (and given that digital signature 3537 is known to be non-null at this point), then the result of step 3592 is to direct the processor to execute the appropriate exception error handler portion 3570 of the security system.
[0405] FIGURE 36 depicts one embodiment of how a digital signature generator block 3660 may be implemented in hardware in order to support the features detailed above. The embodiment depicted in FIGURE 36 shows a hardware implementation of functionality similar to the functionality of the digital signature generator block depicted in FIGURE 31 and which will support the functional features that were described in operational detail, for example, with respect to FIGURES 32, 33, 34 and 35.
[0406] The hashing function seed register 3610 may comprise a similar functionality as that labeled as block 3540 of FIGURE 35 and it may be operable to hold the initial value that is fed to hashing function block 3661 . The output of hashing function block 3661 is fed as one of the inputs to the first stage 3662 of a compound encryption engine. The other input to encryption engine 3662 is the output of the target endpoint device's timestamp register 3641 . The resulting output of the first stage encryption engine 3662 is then supplied as one of the inputs to the second stage encryption engine 3663. The other input to second stage encryption engine 3663 is the output of secured execution mode access point 3666.
[0407] Access point 3666 is operable to pass through the value of the target endpoint's hardware specific secret key 3640 only when the target endpoint device is either running in secured execution mode or when the "recursion terminated" condition is detected, as was detailed earlier with respect to FIGURE 35. The resulting output value from second stage encryption engine 3663 is then stored in digital signature register 3664, for use in comparing this generated digital signature with the digital signatures that are supplied with the candidate code blocks (as referenced, for example, in the descriptions of FIGURES 30, 31 , 32, 33, 34 and 35).
[0408] The output of digital signature register 3664 is gated by access point 3665, whose action is to pass through the value of digital signature register 3664 when the target endpoint device is not running in secured execution mode. The output of access point 3665 is then fed back to the input of the hashing function seed register 3610 in order to create the cascaded message digest feature that was detailed in the description with respect to FIGURE 35. When the target endpoint device is running in secured execution mode, then the input to the hashing function seed register 3610 is not dependent on the value of digital signature register 3664 and can thus either be set to some initial value (as detailed in the description with respect to FIGURE 35) or by some other means (for example, such as a processor write to a specific memory location).
[0409] Embodiments described herein can be implemented in the form of control logic in software or hardware or a combination of both. The control logic may be stored in an information storage medium, such as a computer-readable medium, as a plurality of instructions adapted to direct an information processing device to perform a set of steps disclosed in the various embodiments. Based on the disclosure and teachings provided herein, a person of ordinary skill in the art will appreciate other ways and/or methods to implement the invention.
[0410] It is also within the spirit and scope of the invention to implement in software programming or of the steps, operations, methods, routines or portions thereof described herein, where such software programming or code can be stored in a computer-readable medium and can be operated on by a processor to permit a computer to perform any of the steps, operations, methods, routines or portions thereof described herein. The invention may be implemented by using software programming or code in one or more general purpose digital computers, by using application specific integrated circuits, programmable logic devices, field programmable gate arrays, optical, chemical, biological, quantum or nanoengineered systems, components and mechanisms may be used. In general, the functions of the invention can be achieved by any means as is known in the art. For example, distributed or networked systems, components and circuits can be used. In another example,
communication or transfer (or otherwise moving from one place to another) of data may be wired, wireless, or by any other means.
[041 1 ] A "computer-readable medium" may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, system or device. The computer readable medium can be, by way of example, only but not by limitation, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, system, device, propagation medium, or computer memory. Such computer-readable medium shall generally be machine readable and include software programming or code that can be human readable (e.g., source code) or machine readable (e.g., object code).
[0412] A "processor" includes any, hardware system , mechanism or component that processes data, signals or other information. A processor can include a system with a general-purpose central processing unit, multiple processing units, dedicated circuitry for achieving functionality, or other systems. Processing need not be limited to a geographic location, or have temporal limitations. For example, a processor can perform its functions in "real-time," "offline," in a "batch mode," etc. Portions of processing can be performed at different times and at different locations, by different (or the same) processing systems.
[0413] It will also be appreciated that one or more of the elements depicted in the drawings/figures can also be implemented in a more separated or integrated manner, or even removed or rendered as inoperable in certain cases, as is useful in accordance with a particular application. Additionally, any signal arrows in the drawings/figures should be considered only as exemplary, and not limiting, unless otherwise specifically noted.
[0414] Furthermore, the term "or" as used herein is generally intended to mean "and/or" unless otherwise indicated. As used herein, a term preceded by "a" or "an" (and "the" when antecedent basis is "a" or "an") includes both singular and plural of such term (i.e., that the reference "a" or "an" clearly indicates only the singular or only the plural). Also, as used in the description herein, the meaning of "in" includes "in" and "on" unless the context clearly dictates otherwise.
[0415] Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments. However, the benefits, advantages, solutions to problems, and any component(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential feature or component.

Claims

WHAT IS CLAIMED IS:
1 . A system, comprising:
a processor;
a memory;
a secret key stored in hardware;
a cache having a line comprising data of a process executed on the processor in a secure mode; and
a secure execution controller configured to control access to the line of the cache using a first secure descriptor based on the secret key and associated with the process such that only the process can access the line of the cache.
2. The system of claim 1 , wherein the system was placed in secure mode based on the first secure descriptor.
3. The system of claim 1 , wherein the secure execution controller is configured to cause an entire working set of the process to be stored in the cache and to cause writes to a memory location other than the cache in the secure mode to be disabled.
4. The system of claim 1 , wherein the process has terminated.
5. The system of claim 3, wherein the secure execution controller is configured to cause the line of the cache to be associated with the first secure descriptor associated with the process.
6. The system of claim 5, wherein the secure execution controller is configured to cause a security flag associated with the line of the cache to be set when the process writes the data.
7. The system of claim 6, wherein the secure execution controller is configured to control access by causing the following steps to be performed:
determining that the line of cache is being accessed by a currently executing process,
determining if a currently executing process is executing in secure mode, determining a second secure descriptor associated with the currently executing process, comparing the second secure descriptor and the second secure descriptor, and allowing access only if the currently executing process is executing in secure mode and the first secure descriptor matches the second secure descriptor.
8. A method, comprising:
executing a process on a processor in a secure mode;
storing data in a line of a cache, wherein the data was stored by the process executed on the processor in the secure mode; and
controlling access to the line of the using a first secure descriptor associated with the process such that only the process can access the line of the cache, wherein the first secure descriptor is based on a secret key stored in hardware on a system comprising the processor and the cache.
9. The method of claim 8, wherein the secure mode was entered based on the first secure descriptor.
10. The method of claim 8, further comprising storing an entire working set of the process in the cache and disabling writes to a memory location other than the cache in the secure mode.
1 1 . The method of claim 8, wherein the process has terminated.
12. The method of claim 10, further comprising associating the line of the cache with the first secure descriptor associated with the process.
13. The method of claim 12, further comprising setting a security flag associated with the line of the cache when the process writes the data.
14. The method of claim 13, wherein controlling access comprises:
determining that the line of cache is being accessed by a currently executing process,
determining if a currently executing process is executing in secure mode, determining a second secure descriptor associated with the currently executing process,
comparing the second secure descriptor and the second secure descriptor, and allowing access only if the currently executing process is executing in secure mode and the first secure descriptor matches the second secure descriptor.
15. A non-transitory computer readable medium, comprising instructions for:
executing a process on a processor in a secure mode;
storing data in a line of a cache, wherein the data was stored by the process executed on the processor in the secure mode; and
controlling access to the line of the using a first secure descriptor associated with the process such that only the process can access the line of the cache, wherein the first secure descriptor is based on a secret key stored in hardware on a system comprising the processor and the cache.
16. The computer readable medium of claim 15, wherein the secure mode was entered based on the first secure descriptor.
17. The computer readable medium of claim 15, further comprising instructions for storing an entire working set of the process in the cache and disabling writes to a memory location other than the cache in the secure mode.
18. The computer readable medium of claim 15, wherein the process has terminated.
19. The computer readable medium of claim 17, further comprising instructions for associating the line of the cache with the first secure descriptor associated with the process.
20. The computer readable medium of claim 19, further comprising instructions for setting a security flag associated with the line of the cache when the process writes the data.
21 . The computer readable medium of claim 20, wherein controlling access comprises: determining that the line of cache is being accessed by a currently executing process,
determining if a currently executing process is executing in secure mode, determining a second secure descriptor associated with the currently executing process,
comparing the second secure descriptor and the second secure descriptor, and allowing access only if the currently executing process is executing in secure mode and the first secure descriptor matches the second secure descriptor.
PCT/US2013/033009 2012-03-20 2013-03-19 Method and system for process working set isolation WO2013142517A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
JP2015501858A JP2015511050A (en) 2012-03-20 2013-03-19 Method and system for process working set isolation
KR1020147029364A KR20150011802A (en) 2012-03-20 2013-03-19 Method and system for process working set isolation
EP13765051.1A EP2828759A4 (en) 2012-03-20 2013-03-19 Method and system for process working set isolation

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201261613290P 2012-03-20 2012-03-20
US61/613,290 2012-03-20

Publications (1)

Publication Number Publication Date
WO2013142517A1 true WO2013142517A1 (en) 2013-09-26

Family

ID=49213445

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2013/033009 WO2013142517A1 (en) 2012-03-20 2013-03-19 Method and system for process working set isolation

Country Status (5)

Country Link
US (2) US9575906B2 (en)
EP (1) EP2828759A4 (en)
JP (1) JP2015511050A (en)
KR (1) KR20150011802A (en)
WO (1) WO2013142517A1 (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015157690A1 (en) * 2014-04-11 2015-10-15 Rubicon Labs, Inc. System and method for sharing data securely
WO2016109558A1 (en) * 2014-12-29 2016-07-07 Rubicon Labs, Inc. System and method for secure code entry point control
CN108965220A (en) * 2017-11-29 2018-12-07 北京视联动力国际信息技术有限公司 A kind of method and system that Conference control power is synchronous

Families Citing this family (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7203844B1 (en) 2002-06-20 2007-04-10 Oxford William V Method and system for a recursive security protocol for digital copyright control
US8438392B2 (en) 2002-06-20 2013-05-07 Krimmeni Technologies, Inc. Method and system for control of code execution on a general purpose computing device and control of code execution in a recursive security protocol
US8904189B1 (en) 2010-07-15 2014-12-02 The Research Foundation For The State University Of New York System and method for validating program execution at run-time using control flow signatures
WO2013040241A1 (en) * 2011-09-13 2013-03-21 Privatecore, Inc. Software cryptoprocessor
US9477603B2 (en) 2013-09-05 2016-10-25 Facebook, Inc. System and method for partitioning of memory units into non-conflicting sets
US9983894B2 (en) 2013-09-25 2018-05-29 Facebook, Inc. Method and system for providing secure system execution on hardware supporting secure application execution
US10049048B1 (en) 2013-10-01 2018-08-14 Facebook, Inc. Method and system for using processor enclaves and cache partitioning to assist a software cryptoprocessor
US9747450B2 (en) 2014-02-10 2017-08-29 Facebook, Inc. Attestation using a combined measurement and its constituent measurements
JP6609262B2 (en) 2014-03-14 2019-11-20 アビニシオ テクノロジー エルエルシー Mapping of attributes of keyed entities
US9734092B2 (en) 2014-03-19 2017-08-15 Facebook, Inc. Secure support for I/O in software cryptoprocessor
US9639671B2 (en) * 2014-05-27 2017-05-02 Assured Information Security, Inc. Secure execution of encrypted program instructions
US9830162B2 (en) * 2014-12-15 2017-11-28 Intel Corporation Technologies for indirect branch target security
FR3030827B1 (en) * 2014-12-19 2017-01-27 Stmicroelectronics (Grenoble 2) Sas METHOD AND DEVICE FOR SECURE PROCESSING OF CRYPTED DATA
US10880316B2 (en) * 2015-12-09 2020-12-29 Check Point Software Technologies Ltd. Method and system for determining initial execution of an attack
US10291634B2 (en) 2015-12-09 2019-05-14 Checkpoint Software Technologies Ltd. System and method for determining summary events of an attack
US10440036B2 (en) * 2015-12-09 2019-10-08 Checkpoint Software Technologies Ltd Method and system for modeling all operations and executions of an attack and malicious process entry
US9660978B1 (en) * 2016-08-08 2017-05-23 ISARA Corporation Using a digital certificate with multiple cryptosystems
US10102375B2 (en) 2016-08-11 2018-10-16 Qualcomm Incorporated Multi-modal memory hierarchical management for mitigating side-channel attacks in the cloud
KR20240038828A (en) * 2016-09-15 2024-03-25 너츠 홀딩스 엘엘씨 Encrypted userdata transit and storage
KR102501776B1 (en) 2018-01-31 2023-02-21 에스케이하이닉스 주식회사 Storage device and operating method thereof
US10944557B2 (en) * 2018-04-25 2021-03-09 Nxp B.V. Secure activation of functionality in a data processing system
US10852988B2 (en) * 2018-04-30 2020-12-01 Intel Corporation On access memory zeroing
US11138132B2 (en) * 2018-06-20 2021-10-05 Intel Corporation Technologies for secure I/O with accelerator devices
US10425401B1 (en) 2018-10-31 2019-09-24 ISARA Corporation Extensions for using a digital certificate with multiple cryptosystems
US11190336B2 (en) * 2019-05-10 2021-11-30 Sap Se Privacy-preserving benchmarking with interval statistics reducing leakage
US11282078B2 (en) 2019-07-03 2022-03-22 Sap Se Transaction auditing using token extraction and model matching
US20210004795A1 (en) * 2019-07-03 2021-01-07 Sap Se Anomaly and fraud detection using duplicate event detector
US11645425B2 (en) 2019-07-03 2023-05-09 Beyond Semiconductor, d.o.o. Systems and methods for data-driven secure and safe computing
US20220261505A1 (en) * 2019-07-23 2022-08-18 Sony Interactive Entertainment Inc. Access control apparatus, access control method, and program
DE102019128528A1 (en) 2019-10-22 2021-04-22 Infineon Technologies Ag DATA CRYPTOGRAPHY DEVICES AND STORAGE SYSTEMS
US11907132B2 (en) * 2022-03-23 2024-02-20 International Business Machines Corporation Final cache directory state indication
EP4261679A1 (en) * 2022-04-13 2023-10-18 Thales Dis France SAS Method for a secure execution of instructions

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060265568A1 (en) * 2003-05-16 2006-11-23 Burton David A Methods and systems of cache memory management and snapshot operations
US20100122088A1 (en) * 2002-06-20 2010-05-13 Oxford William V Method and system for control of code execution on a general purpose computing device and control of code execution in a recursive security protocol
US20100281220A1 (en) * 2009-04-30 2010-11-04 International Business Machines Corporation Predictive ownership control of shared memory computing system data
US20110225168A1 (en) * 2010-03-12 2011-09-15 Lsi Corporation Hash processing in a network communications processor architecture

Family Cites Families (88)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4293910A (en) * 1979-07-02 1981-10-06 International Business Machines Corporation Reconfigurable key-in-storage means for protecting interleaved main storage
FR2514593B1 (en) 1981-10-09 1986-12-26 Bull Sa METHOD AND DEVICE FOR AUTHENTICATING THE SIGNATURE OF A SIGNED MESSAGE
US5319710A (en) 1986-08-22 1994-06-07 Tandem Computers Incorporated Method and means for combining and managing personal verification and message authentication encrytions for network transmission
US4893339A (en) 1986-09-03 1990-01-09 Motorola, Inc. Secure communication system
US5029207A (en) 1990-02-01 1991-07-02 Scientific-Atlanta, Inc. External security module for a television signal decoder
US5210748A (en) 1990-02-09 1993-05-11 Hitachi, Ltd. Address filter unit for carrying out address filter processing among plurality of networks and method thereof
US5210870A (en) 1990-03-27 1993-05-11 International Business Machines Database sort and merge apparatus with multiple memory arrays having alternating access
US5222136A (en) 1992-07-23 1993-06-22 Crest Industries, Inc. Encrypted communication system
US5285497A (en) 1993-04-01 1994-02-08 Scientific Atlanta Methods and apparatus for scrambling and unscrambling compressed data streams
US5343527A (en) 1993-10-27 1994-08-30 International Business Machines Corporation Hybrid encryption method and system for protecting reusable software components
GB2288476A (en) 1994-04-05 1995-10-18 Ibm Authentication of printed documents.
US5724425A (en) 1994-06-10 1998-03-03 Sun Microsystems, Inc. Method and apparatus for enhancing software security and distributing software
JPH10512074A (en) 1995-02-13 1998-11-17 インタートラスト テクノロジーズ コーポレイション System and method for secure transaction management and electronic rights protection
JPH0950465A (en) 1995-08-04 1997-02-18 Hitachi Ltd Electronic shopping method, electronic shopping system and document authentication method
US5623545A (en) 1995-08-31 1997-04-22 National Semiconductor Corporation Automatic data generation for self-test of cryptographic hash algorithms in personal security devices
US5631961A (en) 1995-09-15 1997-05-20 The United States Of America As Represented By The Director Of The National Security Agency Device for and method of cryptography that allows third party access
US5764774A (en) 1995-09-25 1998-06-09 Intermec Corporation Source data compression and decompression in code symbol printing and decoding
US5999629A (en) 1995-10-31 1999-12-07 Lucent Technologies Inc. Data encryption security module
US6055314A (en) 1996-03-22 2000-04-25 Microsoft Corporation System and method for secure purchase and delivery of video content programs
US6009176A (en) 1997-02-13 1999-12-28 International Business Machines Corporation How to sign digital streams
US6101605A (en) 1997-05-15 2000-08-08 Vlsi Technology, Inc. Method and apparatus for performing a secure operation
US5890129A (en) 1997-05-30 1999-03-30 Spurgeon; Loren J. System for exchanging health care insurance information
US6378072B1 (en) 1998-02-03 2002-04-23 Compaq Computer Corporation Cryptographic system
US7809138B2 (en) 1999-03-16 2010-10-05 Intertrust Technologies Corporation Methods and apparatus for persistent control and protection of content
US6226742B1 (en) 1998-04-20 2001-05-01 Microsoft Corporation Cryptographic technique that provides fast encryption and decryption and assures integrity of a ciphertext message through use of a message authentication code formed through cipher block chaining of the plaintext message
JP2000010860A (en) * 1998-06-16 2000-01-14 Hitachi Ltd Cache memory control circuit, processor, processor system, and parallel processor system
US6278966B1 (en) 1998-06-18 2001-08-21 International Business Machines Corporation Method and system for emulating web site traffic to identify web site usage patterns
US6865675B1 (en) 1998-07-14 2005-03-08 Koninklijke Philips Electronics N.V. Method and apparatus for use of a watermark and a unique time dependent reference for the purpose of copy protection
US6438235B2 (en) 1998-08-05 2002-08-20 Hewlett-Packard Company Media content protection utilizing public key cryptography
US6389403B1 (en) 1998-08-13 2002-05-14 International Business Machines Corporation Method and apparatus for uniquely identifying a customer purchase in an electronic distribution system
US6226618B1 (en) 1998-08-13 2001-05-01 International Business Machines Corporation Electronic content delivery system
US7228437B2 (en) 1998-08-13 2007-06-05 International Business Machines Corporation Method and system for securing local database file of local content stored on end-user system
US6412070B1 (en) 1998-09-21 2002-06-25 Microsoft Corporation Extensible security system and method for controlling access to objects in a computing environment
US6330670B1 (en) 1998-10-26 2001-12-11 Microsoft Corporation Digital rights management operating system
US6327652B1 (en) 1998-10-26 2001-12-04 Microsoft Corporation Loading and identifying a digital rights management operating system
JP2000155735A (en) 1998-11-20 2000-06-06 Mitsubishi Electric Corp Digital content distribution system device
FR2787900B1 (en) 1998-12-28 2001-02-09 Bull Cp8 INTELLIGENT INTEGRATED CIRCUIT
US6654889B1 (en) 1999-02-19 2003-11-25 Xilinx, Inc. Method and apparatus for protecting proprietary configuration data for programmable logic devices
US6367019B1 (en) 1999-03-26 2002-04-02 Liquid Audio, Inc. Copy security for portable music players
US7073063B2 (en) 1999-03-27 2006-07-04 Microsoft Corporation Binding a digital license to a portable device or the like in a digital rights management (DRM) system and checking out/checking in the digital license to/from the portable device or the like
US7225333B2 (en) 1999-03-27 2007-05-29 Microsoft Corporation Secure processor architecture for use with a digital rights management (DRM) system on a computing device
US6701432B1 (en) 1999-04-01 2004-03-02 Netscreen Technologies, Inc. Firewall including local bus
US6681214B1 (en) 1999-06-29 2004-01-20 Assure Systems, Inc. Secure system for printing authenticating digital signatures
KR100682290B1 (en) 1999-09-07 2007-02-15 소니 가부시끼 가이샤 Contents management system, device, method, and program storage medium
US6683954B1 (en) 1999-10-23 2004-01-27 Lockstream Corporation Key encryption using a client-unique additional key for fraud prevention
CN1818990A (en) 2000-01-21 2006-08-16 索尼公司 Method and apparatus for symmetric encryption/decryption of recorded data
JP2001209583A (en) 2000-01-26 2001-08-03 Sony Corp Recorded data regenerator and method for saved data processing and program distribution media
EP1252738A2 (en) 2000-01-31 2002-10-30 VDG Inc. Block encryption method and schemes for data confidentiality and integrity protection
EP1139064B1 (en) 2000-03-30 2004-05-19 Siemens Aktiengesellschaft Vehicle navigation system with a protected storage medium
JP3734408B2 (en) * 2000-07-03 2006-01-11 シャープ株式会社 Semiconductor memory device
IL137296A (en) 2000-07-13 2009-09-01 Nds Ltd Configurable hardware system
TW513883B (en) 2000-08-03 2002-12-11 Telepaq Technology Inc A secure transaction mechanism system and method integrating wireless communication and wired communication
JP4552294B2 (en) 2000-08-31 2010-09-29 ソニー株式会社 Content distribution system, content distribution method, information processing apparatus, and program providing medium
US7272720B2 (en) 2000-09-27 2007-09-18 Fujitsu Limited Date-and-time management device and signature generation apparatus with date-and-time management function
US7088822B2 (en) 2001-02-13 2006-08-08 Sony Corporation Information playback device, information recording device, information playback method, information recording method, and information recording medium and program storage medium used therewith
US7047405B2 (en) 2001-04-05 2006-05-16 Qualcomm, Inc. Method and apparatus for providing secure processing and data storage for a wireless communication device
US20020138435A1 (en) 2001-03-26 2002-09-26 Williams L. Lloyd Method and system for content delivery control using a parallel network
US20030037237A1 (en) 2001-04-09 2003-02-20 Jean-Paul Abgrall Systems and methods for computer device authentication
DE10224473A1 (en) 2001-06-18 2003-12-24 Hans-Joachim Mueschenborn Data encryption system has iterative part block encryption and decryption key generation using base decryption and encryption keys
JP3846230B2 (en) 2001-06-18 2006-11-15 日本ビクター株式会社 Content information authentication playback device
US7203966B2 (en) 2001-06-27 2007-04-10 Microsoft Corporation Enforcement architecture and method for digital rights management system for roaming a license to a plurality of user devices
KR20040039443A (en) 2001-09-27 2004-05-10 마쯔시다덴기산교 가부시키가이샤 An encryption device, a decrypting device, a secret key generation device, a copyright protection system and a cipher communication device
JP4248208B2 (en) 2001-09-27 2009-04-02 パナソニック株式会社 Encryption device, decryption device, secret key generation device, copyright protection system, and encryption communication device
US20030084298A1 (en) 2001-10-25 2003-05-01 Messerges Thomas S. Method for efficient hashing of digital content
US7159240B2 (en) 2001-11-16 2007-01-02 Microsoft Corporation Operating system upgrades in a trusted operating system environment
US7328345B2 (en) 2002-01-29 2008-02-05 Widevine Technologies, Inc. Method and system for end to end securing of content for video on demand
US7003702B2 (en) 2002-03-18 2006-02-21 Emc Corporation End-to-end checksumming for read operations
US7203844B1 (en) 2002-06-20 2007-04-10 Oxford William V Method and system for a recursive security protocol for digital copyright control
US20040003248A1 (en) 2002-06-26 2004-01-01 Microsoft Corporation Protection of web pages using digital signatures
AU2003279642A1 (en) 2002-10-31 2004-05-25 Telefonaktiebolaget Lm Ericsson (Publ.) Secure implementation and utilization of device-specific security data
JP3880933B2 (en) * 2003-01-21 2007-02-14 株式会社東芝 Data access control method using tamper resistant microprocessor and cache memory processor
US7647507B1 (en) 2003-07-08 2010-01-12 Marvell International Ltd. Secure digital content distribution system and secure hard drive
US7366302B2 (en) 2003-08-25 2008-04-29 Sony Corporation Apparatus and method for an iterative cryptographic block
US20050172132A1 (en) 2004-01-30 2005-08-04 Chen Sherman (. Secure key authentication and ladder system
EA010611B1 (en) 2004-02-13 2008-10-30 АйВиАй СМАРТ ТЕКНОЛОДЖИЗ, ИНК. Method and apparatus for cryptographically processing data
US20060090073A1 (en) * 2004-04-27 2006-04-27 Shira Steinberg System and method of using human friendly representations of mathematical values and activity analysis to confirm authenticity
JP2005346182A (en) 2004-05-31 2005-12-15 Fujitsu Ltd Information processor, tamper resistant method, and tamper resistant program
JP4755189B2 (en) 2004-10-12 2011-08-24 韓国科学技術院 Content encryption method, network content providing system and method using the same
US7480385B2 (en) 2004-11-05 2009-01-20 Cable Television Laboratories, Inc. Hierarchical encryption key system for securing digital media
JP2006222496A (en) 2005-02-08 2006-08-24 Matsushita Electric Ind Co Ltd Digital image receiver and system for receiving digital image
US7639819B2 (en) 2005-06-16 2009-12-29 Oracle International Corporation Method and apparatus for using an external security device to secure data in a database
EP2019992B1 (en) * 2006-07-14 2015-09-16 Scytl Secure Electronic Voting, S.A. Method and system of generating immutable audit logs
JP2010520703A (en) * 2007-03-06 2010-06-10 ウィリアム ブイ. オックスフォード, Method and system for recursive security protocol for digital rights control
JP5211716B2 (en) 2008-01-29 2013-06-12 富士通株式会社 File access control method, file access control program, and file access control apparatus
US20110055585A1 (en) * 2008-07-25 2011-03-03 Kok-Wah Lee Methods and Systems to Create Big Memorizable Secrets and Their Applications in Information Engineering
US9298894B2 (en) * 2009-06-26 2016-03-29 International Business Machines Corporation Cache structure for a computer system providing support for secure objects
US8972746B2 (en) * 2010-12-17 2015-03-03 Intel Corporation Technique for supporting multiple secure enclaves
US9448950B2 (en) * 2013-12-24 2016-09-20 Intel Corporation Using authenticated manifests to enable external certification of multi-processor platforms

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100122088A1 (en) * 2002-06-20 2010-05-13 Oxford William V Method and system for control of code execution on a general purpose computing device and control of code execution in a recursive security protocol
US20060265568A1 (en) * 2003-05-16 2006-11-23 Burton David A Methods and systems of cache memory management and snapshot operations
US20100281220A1 (en) * 2009-04-30 2010-11-04 International Business Machines Corporation Predictive ownership control of shared memory computing system data
US20110225168A1 (en) * 2010-03-12 2011-09-15 Lsi Corporation Hash processing in a network communications processor architecture

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP2828759A4 *

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2015157690A1 (en) * 2014-04-11 2015-10-15 Rubicon Labs, Inc. System and method for sharing data securely
WO2015157693A3 (en) * 2014-04-11 2015-12-03 Rubicon Labs, Inc. System and method for an efficient authentication and key exchange protocol
US9734355B2 (en) 2014-04-11 2017-08-15 Rubicon Labs, Inc. System and method for an efficient authentication and key exchange protocol
WO2016109558A1 (en) * 2014-12-29 2016-07-07 Rubicon Labs, Inc. System and method for secure code entry point control
CN108965220A (en) * 2017-11-29 2018-12-07 北京视联动力国际信息技术有限公司 A kind of method and system that Conference control power is synchronous
CN108965220B (en) * 2017-11-29 2021-04-23 视联动力信息技术股份有限公司 Method and system for synchronizing conference control right

Also Published As

Publication number Publication date
US9575906B2 (en) 2017-02-21
EP2828759A1 (en) 2015-01-28
US20130254494A1 (en) 2013-09-26
US20170192909A1 (en) 2017-07-06
JP2015511050A (en) 2015-04-13
KR20150011802A (en) 2015-02-02
EP2828759A4 (en) 2015-09-30

Similar Documents

Publication Publication Date Title
WO2013142517A1 (en) Method and system for process working set isolation
US9705677B2 (en) Method and system for control of code execution on a general purpose computing device and control of code execution in a recursive security protocol
US7457968B2 (en) Method and system for a recursive security protocol for digital copyright control
JP5636371B2 (en) Method and system for code execution control in a general purpose computing device and code execution control in a recursive security protocol
US10885202B2 (en) Method and apparatus to provide secure application execution
KR101457355B1 (en) Method and apparatus to provide secure application execution
KR100996784B1 (en) Saving and retrieving data based on public key encryption
JP4073913B2 (en) Open general-purpose attack-resistant CPU and its application system
KR101067399B1 (en) Saving and retrieving data based on symmetric key encryption
US20050060568A1 (en) Controlling access to data
US20160188874A1 (en) System and method for secure code entry point control
TWI468969B (en) Method of authorizing access to electronic content and method of authorizing an action performed thereto
US20170063544A1 (en) System and method for sharing data securely
EP2119092A2 (en) Method and system for a recursive security protocol for digital copyright control
KR101604892B1 (en) Method and devices for fraud prevention of android-based applications
JP2015135703A (en) Method and system for recursive security protocol for digital copyright control
JP2014017871A (en) Method and system for recursive security protocol for digital copyright control
JP2019109910A (en) Processor
JP2013084294A (en) Method and system for recursive security protocol for digital copyright control
WO2005092060A2 (en) Apparatus and method for intellectual property protection using the microprocessor serial number

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 13765051

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2015501858

Country of ref document: JP

Kind code of ref document: A

NENP Non-entry into the national phase

Ref country code: DE

REEP Request for entry into the european phase

Ref document number: 2013765051

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 2013765051

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 20147029364

Country of ref document: KR

Kind code of ref document: A