The present disclosure generally relates to the field of computing. More particularly, an embodiment of the invention generally relates to software copy protection via protected execution of applications.
As computer networks become more common place and faster, various types of services may become available to computing platforms through such networks. One example of such services is a Software-As-A-Service (SAAS).
In SAAS or digital content delivery model, software and/or content may be delivered on demand over a network to a computing platform. In the SAAS model, software metering may be used to measure the use of software on a platform based on vendor metrics. For example, software metering may be done by ensuring that credits allocated for software are correctly counted (e.g., when accessed) to determine if the software may continue executing on the platform. However, there may be various security attacks possible on the software portion of these models which may effectively disable the software metering functionality or allow for snooping on decrypted content, thereby directly attacking the revenue model for providers relying on such delivery models.
The detailed description is provided with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of various embodiments. However, various embodiments of the invention may be practiced without the specific details. In other instances, well-known methods, procedures, components, and circuits have not been described in detail so as not to obscure the particular embodiments of the invention. Further, various aspects of embodiments of the invention may be performed using various means, such as integrated semiconductor circuits (“hardware”), computer-readable instructions organized into one or more programs (“software”), or some combination of hardware and software. For the purposes of this disclosure reference to “logic” shall mean either hardware, software (including for example micro-code that controls the operations of a processor), or some combination thereof.
In some implementations, software metering may utilize hardware support to ensure that the platform resources used for executing metered software are tracked for their use by time or units of compute used. For example, there may be some basic aspects of metering that may be implemented in hardware, such as, time stamping events when certain software was installed, tamper-resistant storage, or out-of-band network connections, e.g. via Intel's® Active Management Technology (AMT). There is also a larger aspect of software metering that may be an instrumentation of application to collect application-specific meta-data that may account for how the application is being used. Applications may also interact with operating system (OS) specific services that may use this meta-data to make decisions on resources given to the metered applications. However, as previously discussed, there may be various security attacks possible on the software portion of these models which may effectively disable the software metering functionality or allow for snooping on decrypted content, thereby directly attacking the revenue model for providers relying on such delivery models.
To alleviate these issues, some of the embodiments discussed herein may provide techniques for associating a software application with a computing platform and verifying whether the software application is utilizing protected memory of the computing platform. For example, in one embodiment, a remote server may verify whether a software container is utilizing protected memory on a specific machine based on a platform specific value and a negotiated value shared between the server and the software container.
Furthermore, the operating system 104 may include a software container (which may also be referred to as “software module”) 110. For example, in the case of a SAAS implementation, the software container 110 may be a portable executable (PE) packer or the minimal portion of an application. In one embodiment, once a remote server 112 verifies that the software container 110 is executing under Intel's® Virtualization Technology (VT) Integrity Services (VIS) memory protection (e.g., via exchange of one or more signals or messages), the remote server 112 may provide the requisite information to the PE-packer so that it may unpack the encrypted PE file in protected memory of the platform 102 for execution. Additionally, software may be streamed in an encrypted manner (e.g., via a secure communication channel, including for example, using IPSec (Internet Protocol security) or TLS (Transport Layer Security)) to the software container 110 where it may be decrypted under memory protection. Additionally, in some embodiments, e.g., in the case of a content protection implementation, the software container 110 may be a content player which may retrieve keys for the specific digital rights management (DRM) scheme it follows, such as the advanced access content system (AACS).
In some embodiments, encryption keys may be delivered to the computing platform 102 such that they may be accessible only by the software container 110 with which the server 112 communicates. For example, this may be achieved by the software container 110 passing keys to the hypervisor via protected memory. The hypervisor may perform a TPM_Seal operation to seal the AACS keys along with platform configuration register (PCR) state into the platform trusted platform module (TPM) 108. Subsequent launches of the software may allow the hypervisor 106 to deposit keys into protected memory.
As shown in
Additionally,
Furthermore, at 128, the hypervisor 106 may retrieve the shared value from the software container 110. At 130, the hypervisor may sign (e.g., encrypt) the hypervisor measurement stored in the platform configuration registers 108 and the shared value from the software container. 110. Additionally, at 132, the encrypted values may be returned to the software container 110. At 134, the encrypted values may be communicated to the remote server 112 and may be used to verify whether the software container 110 is utilizing protected memory on the platform 102 and whether the software container 110 is running on the same platform as the hypervisor 106. Once the verification by the remote server 112 is done, the software container 110 may decrypt and/or decompress a portion of itself into the protected memory at 136.
Moreover, the local license proxy server 202 may perform the operations performed by the remote server 112 of system 100, as described with reference to operations 126 and 134 of system 100. For example, on mobile systems, such configuration may allow for an “occasionally” connected mode of operation where the software application may not have network connectivity to interact with a remote server continuously. To handle such scenarios, the remote server 112 may delegate the DH negotiation and verification of the TPM quote to a local trusted entity like its local license proxy server 202 (e.g., executing in a service partition or on a dedicated controller such as the Intel Management Engine (ME)). The remote server 112 may provide this proxy with authorization to allow the protected software to be used as per a negotiated license, e.g., number of invocations, time based, etc.
Referring to
At an operation 312, the software container checks the protected data page to determine if the hypervisor has written a Trusted Platform Module (TPM) Quote based on a nonce (which generally refers to a number or bit string used only once in security) including for example the DH shared secret value (also referred to herein more generally as “nonce”) to the protected data page. For example, a TPM Quote command may be used to sign selected PCRs (in one example, PCR 17 set as a result of the hypervisor launch) and the provided shared secret with the TPM automatic installation kit (AIK) private key.
At an operation 314, the software container may verify the TPM Quote by using the remote server as verifier. For example, the software container may provide the quote to the remote server that verifies that the certificate is valid and then may use the AIK public key to verify whether the TPM Quote is valid. The contents of the TPM Quote may be used to verify whether the hypervisor is running and that the DH exchange was done in VIS-protected memory on the same platform that the hypervisor is executing on. This process may protect the software container against man-in-the-middle attacks where rogue software may execute the hypervisor on one platform and the software container on the other.
At an operation 316, the remote server may verify the TPM Quote and the PCR value. At an operation 318, it may be determined that the software container is utilizing VIS-protected memory. Alternatively, at an operation 324, it may be determined that the software container is not using VIS-protected memory at which point the processing of the software container may be finished, operation 322. At an operation 320, the software container may decrypt content in protected memory pages based on the determination made at operation 318. For example, the software container may unpack compressed PE files or decrypt content using VIS-protected memory.
At an operation 404, the hypervisor may measure and protect the software container if the measurement of the software container is verified. For example, the hypervisor may receive a registration message from the software container containing an integrity manifest. The registration message may be un-trusted and may be used by the hypervisor to verify the contents of the software container. If the in-memory verification passes, the hypervisor may use VIS to protect the pages for the software container in memory. In addition to protecting the memory pages, the hypervisor may also initialize or zero out the data page that may be used subsequently by the software container.
At an operation 406, the hypervisor may fetch the nonce from the software container's data page, e.g., as discussed with reference to
More particularly, the computing system 500 may include one or more central processing unit(s) (CPUs) 502 or processors that communicate via an interconnection network (or bus) 504. Hence, various operations discussed herein may be performed by a CPU in some embodiments. Moreover, the processors 502 may include a general purpose processor, a network processor (that processes data communicated over a computer network 503 (e.g., between the software container 110 and the remote server 112 of
A chipset 506 may also communicate with the interconnection network 504. The chipset 506 may include a graphics and memory control hub (GMCH) 508. The GMCH 508 may include a memory controller 510 that communicates with a memory 512. The memory 512 may store data, including sequences of instructions that are executed by the CPU 502, or any other device included in the computing system 500. In an embodiment, the memory 512 may be the same or similar to the main memory 412 of
The GMCH 508 may also include a graphics interface 514 that communicates with a display 516. In one embodiment of the invention, the graphics interface 514 may communicate with the display 516 via an accelerated graphics port (AGP). In an embodiment of the invention, the display 516 may be a flat panel display that communicates with the graphics interface 514 through, for example, a signal converter that translates a digital representation of an image stored in a storage device such as video memory or system memory into display signals that are interpreted and displayed by the display 516. The display signals produced by the interface 514 may pass through various control devices before being interpreted by and subsequently displayed on the display 516.
A hub interface 518 may allow the GMCH 508 and an input/output control hub (ICH) 520 to communicate. The ICH 520 may provide an interface to I/O devices that communicate with the computing system 500. The ICH 520 may communicate with a bus 522 through a peripheral bridge (or controller) 524, such as a peripheral component interconnect (PCI) bridge, a universal serial bus (USB) controller, or other types of peripheral bridges or controllers. The bridge 524 may provide a data path between the CPU 502 and peripheral devices. Other types of topologies may be utilized. Also, multiple buses may communicate with the ICH 520, e.g., through multiple bridges or controllers. Moreover, other peripherals in communication with the ICH 520 may include, in various embodiments of the invention, integrated drive electronics (IDE) or small computer system interface (SCSI) hard drive(s), USB port(s), a keyboard, a mouse, parallel port(s), serial port(s), floppy disk drive(s), digital output support (e.g., digital video interface (DVI)), or other devices.
The bus 522 may communicate with an audio device 526, one or more disk drive(s) 528, and a network interface device 530, which may be in communication with the computer network 503. For example, a remote server (e.g., the remote server 112 discussed with reference to
Furthermore, the computing system 500 may include volatile and/or nonvolatile memory (or storage). For example, nonvolatile memory may include one or more of the following: read-only memory (ROM), programmable ROM (PROM), erasable PROM (EPROM), electrically EPROM (EEPROM), a disk drive (e.g., 528), a floppy disk, a compact disk ROM (CD-ROM), a digital versatile disk (DVD), flash memory, a magneto-optical disk, or other types of nonvolatile machine-readable media that are capable of storing electronic data (e.g., including instructions). In an embodiment, components of the system 500 may be arranged in a point-to-point (PtP) configuration such as discussed with reference to
More specifically,
As illustrated in
The processors 602 and 604 may be any suitable processor such as those discussed with reference to the processors 602 of
At least one embodiment of the invention may be provided by utilizing the processors 602 and 604. For example, the processors 602 and/or 604 may perform one or more of the operations of
The chipset 620 may be coupled to a bus 640 using a PtP interface circuit 641. The bus 640 may have one or more devices coupled to it, such as a bus bridge 642 and I/O devices 643. Via a bus 644, the bus bridge 643 may be coupled to other devices such as a keyboard/mouse 645, the network interface device 630 discussed with reference to
In various embodiments of the invention, the operations discussed herein, e.g., with reference to
Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment may be included in at least an implementation. The appearances of the phrase “in one embodiment” in various places in the specification may or may not be all referring to the same embodiment.
Also, in the description and claims, the terms “coupled” and “connected,” along with their derivatives, may be used. In some embodiments of the invention, “connected” may be used to indicate that two or more elements are in direct physical or electrical contact with each other. “Coupled” may mean that two or more elements are in direct physical or electrical contact. However, “coupled” may also mean that two or more elements may not be in direct contact with each other, but may still cooperate or interact with each other.
Additionally, such computer-readable media may be downloaded as a computer program product, wherein the program may be transferred from a remote computer (e.g., a server) to a requesting computer (e.g., a client) by way of data signals, e.g., through a carrier wave or other propagation medium, via a communication link (e.g., a bus, a modem, or a network connection).
Thus, although embodiments of the invention have been described in language specific to structural features and/or methodological acts, it is to be understood that claimed subject matter may not be limited to the specific features or acts described. Rather, the specific features and acts are disclosed as sample forms of implementing the claimed subject matter.
Number | Name | Date | Kind |
---|---|---|---|
5826041 | Ogus | Oct 1998 | A |
6708272 | McCown et al. | Mar 2004 | B1 |
7444523 | Morais et al. | Oct 2008 | B2 |
7627758 | Tock et al. | Dec 2009 | B1 |
8127292 | Dobrovolskiy et al. | Feb 2012 | B1 |
8171321 | Kumar et al. | May 2012 | B2 |
8244945 | Shanbhogue et al. | Aug 2012 | B2 |
20020082824 | Neiger et al. | Jun 2002 | A1 |
20020108050 | Raley et al. | Aug 2002 | A1 |
20020161891 | Higuchi et al. | Oct 2002 | A1 |
20020166070 | Mualem et al. | Nov 2002 | A1 |
20030149670 | Cronce | Aug 2003 | A1 |
20040062267 | Minami et al. | Apr 2004 | A1 |
20040153672 | Watt et al. | Aug 2004 | A1 |
20050039183 | Romero et al. | Feb 2005 | A1 |
20050132122 | Rozas | Jun 2005 | A1 |
20050182838 | Sheets et al. | Aug 2005 | A1 |
20050204405 | Wormington et al. | Sep 2005 | A1 |
20050209876 | Kennis et al. | Sep 2005 | A1 |
20050223220 | Campbell et al. | Oct 2005 | A1 |
20050246716 | Smith et al. | Nov 2005 | A1 |
20050259678 | Gaur | Nov 2005 | A1 |
20050278722 | Armstrong et al. | Dec 2005 | A1 |
20060048221 | Morais et al. | Mar 2006 | A1 |
20060080257 | Vaughan et al. | Apr 2006 | A1 |
20060080553 | Hall | Apr 2006 | A1 |
20060143687 | O'Connor et al. | Jun 2006 | A1 |
20060174077 | Abadi et al. | Aug 2006 | A1 |
20060184549 | Rowney et al. | Aug 2006 | A1 |
20060190243 | Barkai et al. | Aug 2006 | A1 |
20060206887 | Dodge et al. | Sep 2006 | A1 |
20060236094 | Leung et al. | Oct 2006 | A1 |
20060272027 | Noble | Nov 2006 | A1 |
20070006175 | Durham et al. | Jan 2007 | A1 |
20070028244 | Landis et al. | Feb 2007 | A1 |
20070033419 | Kocher et al. | Feb 2007 | A1 |
20070100771 | Eckleder et al. | May 2007 | A1 |
20070192761 | Sahita et al. | Aug 2007 | A1 |
20070192854 | Kelley et al. | Aug 2007 | A1 |
20070234061 | Teo | Oct 2007 | A1 |
20070266037 | Terry et al. | Nov 2007 | A1 |
20080022129 | Durham et al. | Jan 2008 | A1 |
20080059811 | Sahita et al. | Mar 2008 | A1 |
20080114916 | Hummel et al. | May 2008 | A1 |
20080235793 | Schunter et al. | Sep 2008 | A1 |
20080244573 | Sahita et al. | Oct 2008 | A1 |
20090019437 | Feng et al. | Jan 2009 | A1 |
20090038017 | Durham et al. | Feb 2009 | A1 |
20090083532 | Brannock et al. | Mar 2009 | A1 |
20090172328 | Sahita et al. | Jul 2009 | A1 |
20090172346 | Sahita et al. | Jul 2009 | A1 |
20090172438 | Kumar et al. | Jul 2009 | A1 |
20090172639 | Natu et al. | Jul 2009 | A1 |
20090222792 | Shanbhogue et al. | Sep 2009 | A1 |
20090241189 | Shanbhogue et al. | Sep 2009 | A1 |
20090327575 | Durham et al. | Dec 2009 | A1 |
20100169667 | Dewan | Jul 2010 | A1 |
20100169968 | Shanbhogue et al. | Jul 2010 | A1 |
20100333206 | Dewan et al. | Dec 2010 | A1 |
Number | Date | Country |
---|---|---|
101944013 | Jan 2011 | CN |
0179401 | Apr 1986 | EP |
2006-065851 | Mar 2006 | JP |
2007-510198 | Apr 2007 | JP |
201032137 | Sep 2010 | TW |
2005036405 | Apr 2005 | WO |
2007027739 | Mar 2007 | WO |
2009069136 | Jun 2009 | WO |
2010078143 | Jul 2010 | WO |
2010078143 | Aug 2010 | WO |
Entry |
---|
“Intel Trusted Execution Technology Architectural Overview”, 2003, Intel Corporation, http://www.intel.com/technology/security/downloads/arch-overview.pdf, retrieved from wayback machine. |
Tan, Min “Home PC Maintenance with Intel AMT”, Intel Technology Journal, vol. 11, Issue 1, 12, (Feb. 15, 2007), pp. 57-66. |
Shanbhogue et al., “Virtualization Enabled Integrity Services (VIS)”, Nov. 2007, 10 pages. |
Office Action Received for U.S. Appl. No. 12/347,890, mailed on Jun. 27, 2012, 25 pages. |
Grevstad, Eric, “CPU-Based Security: The NX Bit Jupiterimages”, May 24, 2004, 4 pages. |
Office Action Received for U.S. Appl. No. 12/039,486, mailed on Aug. 3, 2012, 13 pages. |
Office Action received for U.S Appl. No. 11/516,113, mailed on Nov. 6. 2009, 17 pages. |
International Search Report and Written Opinion received for Patent Application No. PCT/US2009/069136, mailed on Jun. 29, 2010, 10 pages. |
International Preliminary Report on Patentability Received for the PCT Application No. PCT/US2009/069136, mailed on Jul. 14, 2012, 5 pages. |
Office Action Received for U.S. Appl. No. 11/516,113, mailed on May 21, 2010, 14 pages. |
Office Action Received for U.S. Appl. No. 12/459,359, mailed on Aug. 30, 2011, 23 pages. |
Office Action Received for U.S. Appl. No. 12/459,359, mailed on Jan. 6, 2012, 23 pages. |
Office Action Received for U.S. Appl. No. 11/395,488, mailed on Apr. 15, 2008, 20 pages. |
Office Action Received for U.S. Appl. No. 11/395,488, mailed on Apr. 27, 2009, 20 pages. |
Uhlig, Rich et al., “Intel Virtualization Technology”, IEEE Computer Society, May 2005, pp. 48-56. |
Notice of Allowance Received for the U.S. Appl. No. 12/050,862, mailed on Apr. 16, 2012, 5 pages. |
Office Action Received for U.S. Appl. No. 12/050,362, mailed on Mar. 18, 2011, 10 pages. |
Office Action Received for U.S. Appl. No. 12/050,862, mailed on Oct. 19, 2011, 10 pages. |
Dewan, et al., “A Hypervisor-based system for protecting software runtime memory and persistent storage”, Apr. 2008. |
Sahita, et al. “Mitigating the Lying-Endpoint Problem in Virtualized Network Access Framework”, Oct. 2007. |
“Key Blobs: Windows CE .Net”, from MSDN, Retrieved on Jan. 1, 2013 Webpage Available at: <http://msdn.microsoft.com/en-us/library/ms884374.aspx>, last updated Apr. 8, 2004, with copyright notice 1992-2003. |
Office Action Received for U.S. Appl. No. 12/347,890, mailed on Nov. 5, 2012, 24 pages. |
Office Action received for Japanese Patent Application No. 2011-536632, mailed on Jan. 15, 2013, 4 Pages of Office Action and 4 pages of English Translation. |
Number | Date | Country | |
---|---|---|---|
20090323941 A1 | Dec 2009 | US |