The present invention relates to an information processing apparatus. More particularly, the invention relates to an information processing apparatus for allowing a single device to manage contents belonging to different categories.
With the Internet coming into general use today, a number of schemes have been proposed whereby audio and video contents are distributed over the Internet for use with devices. Some of these schemes have now been implemented. In such cases, contents are subject to diverse use conditions to protect their copyright. Each device handling contents can make use of them only if it satisfies specific use conditions applicable to these contents.
Conventionally, the devices dealing with contents had to manage all contents in all categories in the same manner. That is, each device could not change the manner of managing contents depending on the different categories of the services offered, use conditions applied, or content providers involved. This posed problems for both content providers and device users: the content providers were unable flexibly to manage the contents they provided, and device users found it difficult to operate their devices in utilizing the contents.
The present invention has been made in view of the above circumstances and provides an apparatus, a method and a program for allowing a single device to make use of a plurality of contents belonging to different categories of services offered, use conditions applied, and content providers involved, thereby affording convenience to both the content providers and device users and improving the operability of the devices employed.
In carrying out the invention and according to a first aspect thereof, there is provided an information processing apparatus comprising: an assigning element which, in a key-managed hierarchical tree structure having a content provision category assigned to a first node on a given level of the structure, assigns uniquely a second information processing apparatus to a leaf subordinate to the first node; and a providing element for providing the second information processing apparatus with the device node key corresponding to a path between the leaf assigned by the assigning element and the first node.
In a preferred structure according to the first aspect of the invention, the providing element may further provide the second information processing apparatus with leaf identification information for identifying the leaf, in addition to the device node key.
In another preferred structure according to the first aspect of the invention, the information processing apparatus may further comprise a receiving element for receiving from the second information processing apparatus a license request including both the leaf identification information and license identification information for identifying a license granting the use of the content; and a transmitting element for transmitting the license which is added the leaf identification information included in the license request and which comprises a digital signature.
In a further preferred structure according to the first aspect of the invention, the providing element may further provide the second information processing apparatus with a private key and a public key of the second information processing apparatus as well as a public key of the information processing apparatus, in addition to the device node key.
According to a second aspect of the invention, there is provided an information processing method for use with an information processing apparatus for providing a device node key used to decrypt, an enabling key block included in a content, the information processing method comprising the steps of: in a key-managed hierarchical tree structure having a content provision category assigned to a first node on a given level of the structure, assigning uniquely a second information processing apparatus to a leaf subordinate to the first node; and providing the second information processing apparatus with the device node key corresponding to a path between the leaf assigned in the assigning step and the first node.
According to a third aspect of the invention, there is provided a storage medium which stores a computer-readable program for use with an information processing apparatus for providing a device node key used to decrypt an enabling key block included in a content, the program comprising the steps of: in a key-managed hierarchical tree structure having a content provision category assigned to a first node on a given level of the structure, assigning uniquely a second information processing apparatus to a leaf subordinate to the first node; and providing the second information processing apparatus with the device node key corresponding to a path between the leaf assigned in the assigning step and the first node.
According to a fourth aspect of the invention, there is provided a program executable by a computer for controlling an information processing apparatus for providing a device node key used to decrypt an enabling key block included in a content, the program causing the computer to carry out the steps of: in a key-managed hierarchical tree structure having a content provision category assigned to a first node on a given level of the structure, assigning uniquely a second information processing apparatus to a leaf subordinate to the first node; and providing the second information processing apparatus with the device node key corresponding to a path between the leaf assigned in the assigning step and the first node.
According to a fifth aspect of the invention, there is provided an information processing apparatus for providing a license granting the use of a content, the information processing apparatus comprising: a receiving element for receiving from a second information processing apparatus leaf identification information for identifying in a key-managed hierarchical tree structure a leaf assigned to the second information processing apparatus; and a transmitting element which, if the leaf identification information received by the receiving element identifies a leaf subordinate to a first node on a given level of the structure, the first node being assigned a content provision category, then transmits the license including the leaf identification information to the second information processing apparatus.
According to a sixth aspect of the invention, there is provided an information processing method for use with an information processing apparatus for providing a license granting the use of a content, the information processing method comprising the steps of: receiving from a second information processing apparatus leaf identification information for identifying in a keymanaged hierarchical tree structure a leaf assigned to the second information processing apparatus; and if the leaf identification information received in the receiving step identifies a leaf subordinate to a first node on a given level of the structure, the first node being assigned a content provision category, then transmitting the license including the leaf identification information to the second information processing apparatus.
According to a seventh aspect of the invention, there is provided a storage medium which stores a computer-readable program for use with an information processing apparatus for providing a license granting the use of a content, the program comprising the steps of: receiving from a second information processing apparatus leaf identification information for identifying in a keymanaged hierarchical tree structure a leaf assigned to the second information processing apparatus; and if the leaf identification information received in the receiving step identifies a leaf subordinate to a first node on a given level of the structure, the first node being assigned a content provision category, then transmitting the license including the leaf identification information to the second information processing apparatus.
According to an eighth aspect of the invention, there is provided a program executable by a computer for controlling an information processing apparatus for providing a license granting the use of a content, the program causing the computer to carry out the steps of: receiving from a second information processing apparatus leaf identification information for identifying in a keymanaged hierarchical tree structure a leaf assigned to the second information processing apparatus; and if the leaf identification information received in the receiving step identifies a leaf subordinate to a first node on a given level of the structure, the first node being assigned a content provision category, then transmitting the license including the leaf identification information to the second information processing apparatus.
According to a ninth aspect of the invention, there is provided an information processing apparatus for offering contents, comprising: a receiving element for receiving a content request including content identification information for identifying a content; and a transmitting element for transmitting an encrypted content including an enabling key block decryptable by use of a device node key corresponding to a path between a leaf subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category.
According to a tenth aspect of the invention, there is provided an information processing method for providing contents, comprising the steps of: receiving a content request including content identification information for identifying a content; and transmitting an encrypted content including an enabling key block decryptable by use of a device node key corresponding to a path between a leaf subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category.
According to an eleventh aspect of the invention, there is provided a storage medium which stores a computer-readable program for use with an information processing apparatus for providing contents, the program comprising the steps of: receiving a content request including content identification information for identifying a content; and transmitting an encrypted content including an enabling key block decryptable by use of a device node key corresponding to a path between a leaf subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category.
According to a twelfth aspect of the invention, there is provided a program executable by a computer for controlling an information processing apparatus for providing contents, the program causing the computer to carry out the steps of: receiving a content request including content identification information for identifying a content; and transmitting an encrypted content including an enabling key block decryptable by use of a device node key corresponding to a path between a leaf subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category.
According to a thirteenth aspect of the invention, there is provided an information processing apparatus for outputting contents, comprising: a storing element for storing a device node key corresponding to an extent between a leaf which is assigned to the information processing apparatus and which is subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category; a content acquiring element for acquiring an encrypted content including an enabling key block for associating the first node with a root key; a decrypting element for decrypting the encrypted content by decrypting the enabling key block included in the encrypted content acquired by the content acquiring element, through the use of the device node key stored in the storing element; and an outputting element for outputting the content decrypted by the decrypting element.
According to a fourteenth aspect of the invention, there is provided an information processing method for use with an information processing apparatus for outputting contents, the information processing method comprising the steps of: storing a device node key corresponding to an extent between a leaf which is assigned to the information processing apparatus and which is subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category; acquiring an encrypted content including an enabling key block for associating the first node with a root key; decrypting the encrypted content by decrypting the enabling key block included in the encrypted content acquired in the content acquiring step, through the use of the device node key stored in the storing step; and outputting the content decrypted in the decrypting step.
According to a fifteenth aspect of the invention, there is provided a storage medium which stores a computer-readable program for use with an information processing apparatus for outputting contents, the program comprising the steps of: storing a device node key corresponding to an extent between a leaf which is assigned to the information processing apparatus and which is subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category; acquiring an encrypted content including an enabling key block for associating the first node with a root key; decrypting the encrypted content by decrypting the enabling key block included in the encrypted content acquired in the content acquiring step, through the use of the device node key stored in the storing step; and outputting the content decrypted in the decrypting step.
According to a sixteenth aspect of the invention, there is provided a program executable by a computer for controlling an information processing apparatus for outputting contents, the program causing the computer to carry out the steps of: storing a device node key corresponding to an extent between a leaf which is assigned to the information processing apparatus and which is subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category; acquiring an encrypted content including an enabling key block for associating the first node with a root key; decrypting the encrypted content by decrypting the enabling key block included in the encrypted content acquired in the content acquiring step, through the use of the device node key stored in the storing step; and outputting the content decrypted in the decrypting step.
Where the information processing apparatus, information processing method, and program according to the first, second, and fourth aspects of the invention are in use, as outlined above, a second information processing apparatus is assigned uniquely to a leaf subordinate to a first node on a given level of a keymanaged hierarchical tree structure, the first node being assigned a content provision category. The second information processing apparatus is provided with a device node key corresponding to a path between the assigned leaf and the first node.
Where the information processing apparatus, information processing method, and program according to the fifth, sixth, and eighth aspects of the invention are in use, the inventive apparatus receives from a second information processing apparatus leaf identification information for identifying in a key-managed hierarchical tree structure a leaf assigned to the second information processing apparatus. If the received leaf identification information identifies a leaf that is subordinate to a first node on a given level of the tree structure, the first node being assigned a content provision category, then the inventive apparatus transmits a license including the leaf identification information to the second information processing apparatus.
Where the information processing apparatus information processing method, and program according to the ninth, tenth, and twelfth aspects of the invention are in use, the inventive apparatus receives a content request including content identification information for identifying a content. In response, the inventive apparatus transmits an encrypted content including an enabling key block (EKB) decryptable by use of a device node key corresponding to a path between a leaf subordinate to a first node on a given level of a key-managed hierarchical tree structure, and the first node which is assigned a content provision category.
Where the information processing apparatus, information processing method, and program according to the thirteenth, fourteenth, and sixteenth aspects of the invention are in use, the inventive apparatus stores a device node key corresponding to an extent between a leaf which is assigned to the inventive apparatus and which is subordinate to a first node on a given level of a keymanaged hierarchical tree structure, and the first node which is assigned a content provision category. The apparatus proceeds to acquire an encrypted content including an enabling key block (EKB) for associating the first node with a root key. The encrypted content is decrypted by decrypting the enabling key block included in the encrypted content by use of the device node key. The decrypted content is then output.
The Internet 2 is also connected with a content server 3, a license server 4, and an accounting server 5. The content server 3 provides contents to the client 1. The license server 4 offers the client 1 licenses for using the contents provided by the content server 3. The accounting server 5 performs an accounting process regarding the client 1 having acquired a license.
Any number of content servers 3, license servers 4, and accounting servers 5 may be configured and connected to the Internet 2 in practice.
In
An encryption/decryption unit 24 encrypts content data and decrypts previously encrypted content data. A codec unit 25 encodes content data illustratively according to ATRAC3 (Adaptive Transform Acoustic Coding Version 3) standards, and sends the encoded data through an I/O interface 32 to a semiconductor memory 44 in a drive 30 for storage. The codec unit 25 also decodes encoded data retrieved from the semiconductor memory 44 in the drive 30.
The semiconductor memory 44 is illustratively constituted by a Memory Stick (trademark).
The CPU 21, ROM 22, RAM 23, encryption/decryption unit 24, and codec unit 25 are interconnected via a bus 31. The bus 31 is further connected to the I/O interface 32.
The I/O interface 32 is connected with an input unit 26, an output unit 27, a storage unit 28, and a communication unit 29. The input unit 26 comprises a keyboard and a mouse. The output unit 27 is composed of a display such as a CRT or an LCD as well as speakers. The storage unit 28 is typically made up of a hard disc drive. The communication unit 29 is illustratively composed of a modem or a terminal adapter that executes communication processes over the Internet 2. The communication unit 29 also exchanges analog or digital signals with other clients.
The I/O interface 23 is also connected to the drive 30 as needed. The drive 30 is loaded with a storage medium such as a magnetic disc 41, an optical disc 42, a magneto-optical disc 43, or a semiconductor memory 44 where necessary. Computer programs are retrieved from the loaded storage medium and installed into the storage unit 28 as needed.
Although not shown, the content server 3, license server 4, and accounting server 5 are each constituted by a computer having basically the same structure as that of the client 1 in
How the client 1 is provided with a content from the content server 3 will now be described by referring to the flowchart of
The user orders access to the content server 3 by operating the input unit 26. In response, the CPU 21 reaches step S1 and causes the communication unit 29 to access the content server 3 via the Internet 2. In step S2, the user inputs information for designating the content to be provided by operating the input unit 26. Given the content-designating information, the CPU 21 reports the information to the content server 3 through the communication unit 29 and via the Internet 2. Upon receipt of the report, the content server 3 returns encrypted content data, as will be described later with reference to the flowchart of
Described below with reference to the flowchart of
In step S21, the CPU 21 of the content server 3 waits until it is accessed by the client 1 through the communication unit 29 and over the Internet 2. When accessed by the client 1, the CPU 21 reaches step S22 and acquires content-designating information sent from the client 1. This is the information reported by the client 1 in step S2 of
In step S23, the CPU 21 of the content server 3 retrieves from the storage unit 28 the content designated by the information acquired in step S22. In step S24, the CPU 21 supplies the encryption/decryption unit 24 with the content data retrieved from the storage unit 28 and causes the unit 24 to encrypt the supplied data using a content key Kc.
All content data held in the storage unit 28 have already been encoded by the codec unit 25 based on ATRAC3. Any encoded content data retrieved from the storage unit 28 are thus encrypted further by the encryption/decryption unit 24.
Obviously, all content data to be placed in the storage unit 28 may be encrypted in advance. In such a case, step S24 of
In step S25, the CPU 21 of the content server 3 adds key information (i.e., enabling key block (EKB) and data KEKBC(Kc) to be described later by referring to
The header comprises content information, a URL (uniform resource locator), a license ID, an enabling key block (EKB), and data KEKBc (Kc) as the content key Kc encrypted by use of a key KEKec derived from the EKB. The EKB will be described later in more detail with reference to
The content information includes a content ID (CID) as information for identifying the content data formatted as data, and a codec method for coding and decoding the content in question.
The URL is information denoting the address to be accessed in acquiring the license designated by the license ID. Illustratively with the system of
The data part comprises any number of encryption blocks. Each encryption block is made up of an initial vector (IV), a seed, and data EK'c(data) obtained by encrypting the content data using a key K'c.
The key K's is constituted by a value obtained by applying the content key Kc and a randomly established seed (value) to a hash function, as defined by the following expression:
K'c=Hash(Kc, Seed)
Each encryption block is furnished with a different initial vector (IV) and a different seed.
The encryption of content data is carried out in units of eight bytes. Each eight-byte portion is encrypted by use of the encrypted result from the preceding eight-byte portion in what is known as CBC (cipher block chaining) mode.
In CBC mode, the first eight-byte content data portion cannot be encrypted using the encrypted result from the preceding eight-byte portion. Instead, the first eight-byte portion is encrypted by use of the initial vector IV as the initial value.
With CBC mode in effect, even if any one encryption block is unlawfully decrypted, the other encryption blocks will not be decrypted correspondingly.
This encryption scheme will be described later in more detail by referring to
This encryption scheme, it should be noted, is not limitative of the invention. Alternatively, the content data may be encrypted by simply utilizing the content key Kc.
In the manner described, the client 1 can acquire content data unrestrainedly and free of charge from the content server 3. That is, large quantities of contents can be distributed in a fairly unconstrained manner.
However, before using any acquired content, each client 1 must be in possession of a license corresponding to the content. How the client reproduces a content will now be described by referring to
In step S41, the CPU 21 of the client 1 acquires content ID information (CID) designated by the user operating the input unit 26. The ID information may be constituted illustratively by a content title and a number unique to each of the stored contents.
When a given content is designated, the CPU 21 reads a license ID relative to the content (i.e., ID of the license for granting the use of the content). The license ID is described in the header of the encrypted content data, as depicted in
In step S42, the CPU 21 determines whether or not the license corresponding to the license ID retrieved in step S41 has already been acquired by the client 1 and stored in the storage unit 28. If the license has yet to be acquired, the CPU 21 goes to step S43 and performs a license acquiring process. Details of the license acquiring process will be described later with reference to the flowchart of
If in step S42 the license is judged to have been acquired already or if the license acquiring process is carried out in step 543, then step S44 is reached. In step 544, the CPU 21 judges whether or not the acquired license falls within the corresponding expiration date. Whether or not the license has expired is determined by comparing the expiration date stipulated in the license (which will be described later by referring to
If in step S44 the license is judged to be effective or if the license is renewed in step 545, then step S46 is reached. In step 546, the CPU 21 reads the applicable encrypted content data from the storage unit 28 and places the retrieved data into the RAM 23. In step 547, the CPU 21 supplies the encryption/decryption unit 24 with the content data stored in the RAM 23 in units of encryption blocks as shown in
The content key Kc is obtained (to be described later in more detail by referring to
In step S48, the CPU 21 supplies the codec unit 25 with the content data decrypted by the encryption/decryption unit 24, and causes the codec unit 25 to decode the supplied data. The CPU 21 then sends the data decoded by the codec unit 25 to the output unit 27 through the I/O interface 32. In turn, the output unit 27 converts the received digital data to analog format for audio output through the speakers.
How the license acquiring process is performed in step S43 of
The client 1 accesses the license server 4 in advance for a registering process whereby service data are acquired, including a leaf ID, a DNK (device node key), a private key paired with a public key for the client 1, a public key of the license server 4, and certificates of the respective public keys. The registering process by the client 1 will be described later in detail by referring to
The leaf ID represents identification information assigned to each client. The device node key (DNK) is required in decrypting an encrypted content key Kc included in the enabling key block (EKB) corresponding to the license of interest (DNK will be described later by referring to
In step S61 of
In step S63, the CPU 21 acquires the license-designating information from the input unit 26. In step S64, the CPU 21 obtains the previously acquired user ID and password. In step 565, the CPU 21 causes the communication unit 29 to transmit to the license server 4 over the Internet a license request comprising the entered user ID, password, license-designating information, and a leaf ID contained in the service data (to be described later).
In turn, as will be described later with reference to
In step 566, the CPU 21 judges whether or not the license has arrived from the license server 4. If the license is judged transmitted, step S67 is reached in which the license is fed to the storage unit 28 for storage therein.
If in step S66 the license is not judged transmitted from the license server 4, then the CPU 21 goes to step S68 for error handling. More specifically, the CPU 21 inhibits any content reproducing process because the license for granting the use of the content in question is not acquired.
It is only after the client 1 has obtained the license applicable to the license ID attached to the content data in carrying out the above steps, can the content be used for reproduction.
The license acquiring process of
The license offered to the client 1 contains use conditions, a leaf ID, and other data items as shown in
The use conditions include such information as a use time limit within which the content may be used, a download time limit within which the content may be downloaded, a maximum number of times the content may be copied, the number of times the content has been checked out so far, a maximum number of times the content may be checked out, the right to record the content to a CD-R, a maximum number of copies that can be made of the content to PDs (portable devices), the right to purchase the license outright, and the duty to keep use logs, all according to the license in question.
Described below with reference to the flowchart of
In step S101, the CPU 21 of the license server 4 waits until it is accessed by the client 1. The CPU 21 goes to step 5102 when accessed by the client 1. In step S102, the CPU 21 requests the accessing client 1 to transmit a user ID, a password, and license-designating information. As described above, the user ID, password leaf ID, and license-designating information (i.e., license ID) are transmitted from the client 1 in step S65 of
In step S103, the CPU 21 of the license server 4 gains access to the accounting server 5 through the communication unit 29 and requests the accounting server 5 to perform a credit authorization process regarding the user corresponding to the user ID and password. Given the credit authorization request from the license server 4 over the Internet 2, the accounting server 5 examines the payment history or other suitable records of the user defined by the user ID and password. A check is made illustratively to see if the user in question has failed to pay the price of any license in the past. If the user is not judged to have such nonpayment records, the accounting server 5 transmits credit authorization data; if the user is judged to have any nonpayment records, the accounting server 5 transmits credit rejection data.
In step S104, the CPU 21 of the license server 4 determines whether or not the accounting server 5 has returned the credit authorization data for granting the license to the user. If the credit authorization data are judged returned, step S105 is reached. In step S105, the CPU 21 retrieves from the storage unit 28 one of the stored licenses which corresponds to the license-designating information acquired in step S102. Each license held in the storage unit 28 has a license ID, version information, a date and time of preparation, and an expiration date described therein beforehand. In step S106, the CPU 21 adds the received leaf ID to the license. In step S107, the CPU 21 selects the use conditions corresponding to the license selected in step S105. If the use conditions were designated in step S102 by the user, the designated use conditions may be added as needed to the previously prepared use conditions. The CPU 21 furnishes the license with the use conditions thus selected.
In step S108, the CPU 21 affixes a digital signature to the license by use of a private key from the license server 4. This step generates a license whose structure is shown in
In step S109, the CPU 21 of the license server 4 transmits the license (shown structurally in
In step S110, the CPU 21 of the license server 4 places into the storage unit 28 the license that has just been transmitted (including the use conditions and leaf ID) in correspondence with the user ID and password acquired in step S102. In step S111, the CPU 21 carries out an accounting process. More specifically, through the communication unit 29, the CPU 21 requests the accounting server 5 to carry out an accounting process regarding the user corresponding to the user ID and password. Given the accounting request, the accounting server 5 bills the user for the license. If the user fails to pay the billed amount, the user from then on will be banned from acquiring any further license that may be requested.
In such a case, the accounting server 5 returns in step S104 the credit rejection data banning the granting of the requested license. Step S104 is then followed by step S112 in which the CPU 21 performs error handling. More specifically, the CPU 21 of the license server 4 outputs to the client 1 having gained access through the communication unit 29 a message saying that the license cannot be granted to the user. The CPU 21 then terminates the process.
In this case, the user cannot utilize the content (i.e., unable to decrypt the content), having failed to receive the license for the reason above.
In response to the transmission from the client 1 in step S135, the license server 4 proposes use conditions as will be described later (in step S153 of
In step S151, the CPU 21 of the license server 4 is first accessed by the client 1. In step S152, the CPU 21 receives the license-designating information transmitted by the client 1 in step S135 together with a license renewal request.
In step S153, given the license renewal request, the CPU 21 retrieves from the storage unit 28 the use conditions (to be renewed) corresponding to the license in question. The retrieved use conditions are transmitted to the client 1.
Upon receipt of the use conditions thus proposed, the client 1 signs up for the purchase of the conditions in step S137 of
The inventive system, as shown in
Each key is defined so as to correspond with each of the nodes (shown as circles in the figure) constituting the tree structure. In this example, a root key KR denotes the root node at the highest level; keys KO and K1 correspond to the nodes at the second-highest level; keys K00 through K11 represent the nodes at the third-highest level; and keys K000 through K111 match the nodes at the fourth-highest level. Keys K0000 through Kills correspond to the leaves representative of the nodes at the bottom level (i.e., device nodes).
In this hierarchical structure, the key immediately-above, say, keys K0010 and K0011 is a key K001; and the key immediately above keys K000 and K000 is a key K00. In like manner, keys K00 and K01 are topped by a key K0, and keys K0 and K01 are topped by the route key KR.
The key granting the use of any content is managed in the form of a key corresponding to each node on a single path ranging from a given leaf at the bottom level to the root node at the topmost level. For example, the keys granting the use of a content based on the license relative to node No. 3 (leaf ID) are managed in the form of a path comprising the keys K0011, K001, K00, K0, and KR.
The inventive system, as shown in
That is, licenses are made to correspond with the keys representing the nodes at the 24 levels below the node of this system (T system). In this case, it is possible to define as many as 2 to the 24th power (about 16 million) licenses. If the lowest 32 levels are also taken into account, it is possible to define as many as 2 to the 32nd power (about 4 billion) users (or clients). A device node key (DNK) refers to the key corresponding to each of the nodes on a given path ranging from any one of the leaves denoting the nodes at the lowest 32 levels to the root node. A leaf ID denotes the ID of any one of the leaves at the bottom level of the structure.
Each of the keys of devices and licenses corresponds to one of the paths made up of the nodes at the 64 (=8+24+32) levels. For example, a content key derived from a particular content through encryption is encrypted by use of the keys corresponding to the nodes making up the path assigned to the license of interest. The key at a given level is encrypted using the keys at the immediately lower level before being placed into an enabling key block (EKB; to be discussed later by referring to
The nodes at the M-th highest level (M=8 in the example of
For example, a node 2305 at the M-th highest level in
Further a subcategory node 2306 may be established illustratively several levels below the M-th highest level. In the example of
The categories and subcategories are not limited to the types of devices alone; they may also be applied to nodes managed by manufacturers, content providers, banking or settlement organizations or the like in their unique manner in the form of processing units, jurisdictional units, units of provided services, or any other suitable units (called entities hereunder). For example, one category node may be established as the highest-level node dedicated to a game console XYZ marketed by a game console manufacturer. In this case, the manufacturer can market the game console XYZ by furnishing it with entities denoted by node keys or leaf keys that come under the topmost node. Thereafter, in distributing or renewing encrypted contents or various keys, the manufacturer may generate enabling key blocks (EKB) each constituted by any of the node keys or leaf keys under the highest-level node key in order to distribute data that can be used only on the devices corresponding to the nodes or leaves involved.
As described, where one node tops the other nodes defined as categories or subcategories subsumed in the highest node, a manufacturer, a content provider or any other organization managing the tree structure made up of these nodes may generate uniquely defined enabling key blocks (EKB) each covering nodes leading up to the highest-level node and may distribute the generated blocks to any devices belonging to the subordinate nodes under the topmost node. In that setup, any key may be renewed in a manner totally independent of the devices belonging to any other category except the topmost node.
For example, in the tree structure of
Suppose that at a given point “t” the keys K0011, K001, K00, K0 and KR owned by the device 3 are found to be exposed by a hacker through analysis. In that case, the device 3 needs to be isolated from the system in order to protect data exchanged within the system (i.e., in the group of devices 0, 1, 2 and 3). This requires replacing the node keys K001, K00, K0 and KR with new keys K(t)001, K(t)00, K(t)0 and K(t)R respectively and informing the devices 0, 1 and 2 of the renewed keys. The notation K(t)aaa indicates a renewed key of a generation “t” derived from a key Kaaa.
How renewed keys are distributed will now be described. The key renewal process is carried out illustratively by furnishing the devices 0, 1 and 2 with a table composed of block data called an enabling key block (EKB), shown in
The enabling key block (EKB) shown in
As indicated by the EKB in
Likewise, another encryption key Enc(K(t)00, K(t)0) in the second row from the top in
Meanwhile, the node key K000 is not subject to renewal. What the nodes 0 and 1 need as renewed node keys are the keys K(t)00, K(t)0 and K(t)R. The nodes 0 and 1 acquire the renewed node key K(t)00 by decrypting the encryption key Enc(K000, K(t)00) in the third row from the top in
In
Suppose that renewal of the node keys K(t)0 and K(t)R at the upper levels of the tree structure in
The EKB shown in
Illustratively, the devices 0, 1 and 2 can obtain the content key K(t)con in effect at time “t” by decrypting the encrypted data using the key K(t)00 derived from the EKB.
As shown in
The data part 606 accommodates data prepared illustratively by encrypting the node keys to be renewed. For example, the data part 606 may store encryption keys regarding the renewed node keys shown in
The tag part 607 comprises tags that indicate the positions of the encrypted node keys and leaf keys contained in the data part 606. How the tags are furnished will now be described by referring to
Tags are established to indicate where a given data item Enc(Kxxx, Kyyy) is positioned in the tree structure. Whereas key data Enc(Kxxx, Kyyy), . . . held in the data part 606 are merely a series of encrypted data, the positions of the encryption keys representing the data can be determined in the tree structure through the use of the above-described tags. If the tags were not used, the data could still be structured as
0: Enc(K(t)0, K(t)R)
00: Enc(K(t)00, K(t)0)
000: Enc(K((t)000, K(t)00)
. . .
using the node indexes relative to the encrypted data as explained above with reference to
Returning to
As illustrated, the content is first provided from the content server 3 to the client 1. The client 1 is then furnished with the license from the license server 4. The content is encrypted (Enc(Kc, Content)) using a content key Kc. The content key Kc is encrypted (Enc(KR, Kc)) using the root key KR (obtained from the EKB and corresponding to the key KEKBC in
The EKB in
As described, where the DNK is assigned individually to each client 1, the license of a given client 1 can be revoked independently on the basis of the principle described above with reference to
When each license is distributed together with a leaf ID to the client 1, the client 1 brings the service data into correspondence with the license. Such correspondence helps prevent illegal copying of the license.
Where a client-addressed certificate and a private key are distributed as the service data to each client, the end user at the client can prepare a content that is resistant to illegal copying through the use of the service data.
How the certificate and private key are utilized will be described later with reference to the flowchart of
As described above with reference to
In the tree structure of
In the example of
In this setup, keys can be managed independently in units of categories according to the invention.
Also according to the invention, it is possible to have DNKs downloaded through the license server 4 to individual devices or storage media at the time of a registering process, instead of having the DNKs incorporated in devices or embedded on storage media beforehand. This makes it possible to implement a system for allowing users to acquire keys.
How the above-mentioned registering process is performed by the client 1 will now be described with reference to
In step S161, the CPU 21 of the client 1 causes the communication unit 29 to transmit a service data request to the license server 4. In step S165, the CPU 21 of the license server 4 receives the service data request through the communication unit 29. In step S166, the CPU 21 of the license server 4 transmits a user information request to the client 1 through the communication unit 29.
In step S162, the CPU 21 of the client 1 receives the user information request through the communication unit 29. In turn, the CPU 21 causes the output unit 27 to display a message prompting the user to enter user information. Upon viewing the message, the user operates the keyboard or the like to enter the user information such as the user's personal information and accounting information into the input unit 26. In step S163, the CPU 21 of the client 1 transmits the user-input information to the license server 4 through the communication unit 29.
In step S167, the CPU 21 of the license server 4 receives the user information through the communication unit 29. In step S168, the CPU 21 assigns the client 1 to any one of the unassigned leaves below the node of the category corresponding to the license server 4, and generates a device node key in the form of a set of node keys assigned to the nodes along the path ranging from the leaf assigned to the client 1 to the node corresponding to the category of the license server 4. The CPU 21 then generates service data by putting together the device node key generated as described, the leaf ID of the leaf assigned to the client 1, a private key of the client 1, a public key paired with the private key of the client 1, a public key of the license server, and certificates of the public keys. In step S169, the CPU 21 of the license server 4 transmits the generated service data to the client 1 through the communication unit 29 and causes the drive 30 to record the user information to an appropriate storage medium such as a hard disc in correspondence with the leaf ID.
In step S164, the CPU 21 of the client 1 receives the service data through the communication unit 29. In turn, the CPU 21 causes the encryption/decryption unit 24 to encrypt the received service data and causes the drive 30 to write the encrypted data to a suitable storage medium such as the hard disc.
In the manner described, the license server 4 registers the client 1 and its user. With the registration completed, the client 1 can receive service data including the device node key necessary for utilizing a desired content distribution service.
It is preferred that a content, once prepared, be made usable in any applications regardless of the way it is used. Illustratively, the same content should preferably be used in different content distribution services or irrespective of the domain use status differing from one situation to another. According to this invention, the license server 4 acting as a certificate authority provides each user (i.e., client 1) with a private key and a certificate of a public key corresponding to the private key. Each user prepares a signature using the distributed private key and affixes the signature to the content to attest its integrity, whereby any tampering of the content is prevented.
How the above process is carried out will now be described by referring to the flowchart of
In step S171, the CPU 21 of the client 1 first acquires data reproduced from the CD as write data through the communication unit 29. In step S172, the CPU 21 determines whether or not the write data acquired in step S171 contain a watermark. The watermark, made up of three-bit copy control information (CCI) and one-bit trigger data, is embedded in the content data. If the watermark is detected, the CPU 21 goes to step S173 to extract the watermark from the content. If no watermark is detected, step S173 is skipped.
In step S174, the CPU 21 prepares header data to be recorded in correspondence with the content. The header data is composed of a content ID, a license ID, the URL of the location to be accessed for acquisition of the license, and copy control information (CCI) along with trigger data included in the watermark.
In step S175, the CPU 21, using the client's private key, prepares a digital signature based on the header data generated in step S174. The private key has been acquired earlier from the license server 4 (in step S67 of
In step S176, the CPU 21 causes the encryption/decryption unit 24 to encrypt the content using a content key. The content key is generated illustratively through random number generation.
In step S177, the CPU 21 writes the data illustratively to the magneto-optical disc 43 such as a Mini-disc in accordance with a suitable file format.
Where the storage medium is a Mini-disc, the CPU 21 in step S176 feeds the content to the codec unit 25 to encode the content based on ATRAC3. The encoded data are further encrypted by the encryption/decryption unit 24.
A watermark (WM) is extracted from an encrypted content E(At3) and written outside the content (i.e., in the header).
The watermark, usually embedded in the content, may be taken out of the content and placed into the header as shown in
The meta data represent such data as a jacket, photos, and lyrics regarding the content. The meta data will be described later in more detail with reference to
The public key certificate in
In the example of
Where the license for granting the use of each content is distributed independent of the content in question, the content can be distributed unrestrainedly. All contents acquired in any manner or through any channels may then be handled in unified fashion.
If the file format is constituted as shown in
Furthermore, if the content is distributed on a storage medium or over the Internet 2 as shown in
Described below with reference to the flowchart of
In step S191, the CPU 21 judges whether or not a digital signature is affixed to the content. If the digital signal is judged affixed, step S192 is reached. In step S192, the CPU 21 extracts a certificate from the content and authenticates it using a public key of the certificate authority (i.e., license server 4). More specifically, the client 1 acquires from the license server 4 a public key paired with the private key of the license server 4 and decrypts the digital signature affixed to the public key certificate by use of the acquired public key. As described above with reference to
In step S193, the CPU 21 checks to see whether or not the certificate has been tampered with. If the certificate is judged to be free of tampering, step S194 is reached in which the certificate is authenticated using the EKB. The authenticating process is carried out by determining whether or not it is possible to effect trace through the EKB based on the leaf ID included in the certificate (
Suppose now that a device having a leaf key K1001 is a revoked device as shown in
All leaves except the revoked device 1001 can acquire a renewed root key K(t)R. That is, since the leaves below a node key K0 each retain the unrenewed node key K0 within the device, each of these leaves can obtain a renewed root key K(t)R by decrypting an encryption key Enc(K0, K(t)R) using the key K0.
The leaves below a node 11 may each acquire a renewed node key K(t)1 by decrypting an encryption key Enc(Kll, K(t)1) using a node key K11 yet to be renewed. Furthermore, an updated root key K(t)R may be obtained by decrypting an encryption key Enc(K(t)1, K(t)R) using the node key K(t)1. The leaves below a node key K101 may likewise obtain the renewed root key K(t)R.
A device 1000 having an unrevoked leaf key K1000 may acquire a node key K(t)100 by decrypting an encryption key Enc(K1000, K(t)100) using its own leaf key K1000. The node key K(t)100 thus acquired is then used successively to decrypt node keys at higher levels until the renewed root key K(t)R is obtained.
On the other hand, the revoked device 1001 is incapable of acquiring the renewed node key K(t)100 one level higher through the EKB process. That means the renewed root key K(t)R cannot be obtained.
The valid (i.e., unrevoked) device (client 1) is furnished with the EKB containing the data and tags shown in
Each client may carry out an EKB tracing process using the furnished tags. The process involves determining whether or not the key distribution tree may be traced starting from the topmost root key.
Illustratively, the leaf ID “1001” of the leaf 1001 in
Because the most significant bit of the ID “1001” is “1,” the trace advances right from the root key KR in
The trace now goes to a node below the node key K1. The second bit in the ID “1001” is 0, indicating a leftward advance. The tag numbered 1 denotes the presence or absence of data below the node key KO to the left, and the tag numbered 2 represents the presence or absence of data below the node key K1. The latter tag is formulated as 2: {0, 0} as shown in
The third bit in the ID “1001” is 0 denoting a leftward advance. The tag numbered 3 indicates the presence or absence of data below the node key K10. Formulated as 3: {0, 0}, this tag indicates the presence of data on both branches. The advance is to the left and the node key K100 is reached.
The least significant bit in the ID “1001” is “1” indicative of a rightward advance. The tag numbered 4 corresponds to the node key K11, and the tag numbered 5 denotes the sign of data under the node key K100. The latter tag is defined as 5: {0, 1} interpreted to indicate the absence of data to the right. That means the node 1001 cannot be reached. As a result, the device with the ID “1001” is judged as a revoked device, i.e., a device that is banned from acquiring any renewed root key through the EKB.
Meanwhile, a device with, say, the leaf key K1000 has the device ID of “1000.” When the EKG tracing process is carried out using the tags in the EKB as described above, the node “1000” can be reached. This allows the device with the ID “1000” to be judged as a valid device.
Returning to
As shown in
In step S197, the CPU 21 determines whether or not the header has been tampered with. If no tampering is detected, step 5198 is reached in which the watermark is authenticated. In step S199, the CPU 21 determines whether or not the result of watermark authentication justifies a check-out process. If the check-out process is judged to be allowed, then step S200 is reached in which the CPU 21 checks out the content. Specifically, the CPU 21 transfers the content to the client 1 of the check-out destination for copying.
Step S201 is reached for error handling and checkout is inhibited in any one of the following cases: if no digital signature is judged to exist in step 5191; if the certificate is judged to have been tampered with in step 5193; if the certificate cannot be authenticated in step S195 based on the EKB; if the result of digital signature authentication in step S197 has revealed that the header has been tampered with; or if the watermark is interpreted to require suppression of check-out in step S199.
As described, the license server 4 distributes a certificate and a private key to each user. Upon preparing a content, the user affixes a digital signature to the content to attest its integrity, whereby illegal distribution of the content is inhibited.
The watermark is extracted during preparation of the content and the watermark information is added to the digital signature. This protects the watermark information against tampering and ensures the integrity of the content.
Each content, once prepared, is thus ensured in its integrity regardless of the manner in which the content is distributed.
Since the use conditions are attached not to each content but to the license for granting the use of that content, the use conditions for all contents associated with a given license may be changed collectively as needed by simply changing the use conditions of the license in question.
How a mark is used will now be explained. As described above, use conditions are added not to contents but to licenses. It might happen that contents relative to a given license are subject to individually different usages. This state of affairs is dealt with by adding marks to the contents under a given license according to the invention.
Because one license is matched with a plurality of contents, it is difficult to specify individual usages of the contents solely in the use conditions of the corresponding license. In such cases, the use conditions are attached to individual contents for additional management purposes apart from the licenses.
As shown in
The mark is also supplemented with a digital signature based on the leaf ID, ownership flag, use start time, copy count and the like constituting a message.
The ownership flag is added if the license for grating a limited-time use of the content is replaced by an outright purchase of the license (i.e., for permanent usage). The use start time is described if the content has started to be used within a specific time period. Illustratively, if the time period in which to download the content is limited, the use start time described here indicates the actual date and time at which the content is downloaded within that period. This is to certify that the content is used legitimately within the designated period.
The copy count is a log describing the number of times the content in question has been copied so far.
Described below with reference to the flowchart of
In step S221, the CPU 21 first gains access to the license server 4 over the Internet 2 in response to a command entered by the user into the input unit 26.
In step S222, the CPU 21 acquires the command input from the user through the input unit 26. In accordance with the command, the CPU 21 requests an outright purchase of the license from the license server 4.
Upon receipt of the request, the license server 4 proposes a price for the license, as will be described later with reference to the flowchart of
Upon viewing the display, the user decides whether or not to accept the proposed price. The user enters the result of his or her decision into the input unit 26.
In step S224, the CPU 21 receives the user's input through the input unit 26 and judges whether or not the user has accepted the proposed price. If the proposed price is judged accepted, the CPU 21 goes to step S225 and reports the acceptance to the license server 4.
Given the report of the acceptance, the license server 4 returns a mark that has an ownership flag, i.e., information denoting the outright purchase of the license at the proposed price, described therein (in step S244 of
If in step S224 the price proposed by the license server 4 is not judged accepted, step S228 is reached. In step S228, the CPU 21 reports rejection of the proposed price to the license server 4.
In conjunction with the above-described process of the client 1, the license server 4 carries out the steps in the flowchart of
In step S241, the CPU 21 of the license server 4 first receives a license purchase request from the client 1 (in step S222 of
As described above, the client 1 reports either the acceptance or the rejection of the proposed price.
In step S243, the CPU 21 of the license server 4 judges whether or not the report of the acceptance is received from the client 1. If the acceptance report is judged received, then step S244 is reached. In step 5244, the CPU 21 of the license server 4 generates a mark that contains a message specifying the purchase of the license in question, affixes a digital signature to the mark using its own private key, and transmits the mark to the client 1. The mark thus transmitted is written to the applicable content in the storage unit 28 of the client 1 as described above (in step S227 of
If in step S243 the acceptance report is not judged received from the client 1, then step 5244 is skipped. In this case, the purchase of the license is not accomplished, so that the mark will not be transmitted.
The mark is valid only for a specific content of a particular user. If the content in question is copied, the mark accompanying the copied content is invalidated.
As described, each content and its license are handled independently of one another, and the use conditions are associated with each license. This scheme makes it possible to offer diverse services reflecting the different use status of individual contents.
Described below is what is known as grouping. Grouping involves putting together a plurality of devices or storage media to form a group within which a content may be exchanged freely. Grouping usually applies to devices or storage media owned by an individual. Whereas the devices or storage media forming a single group were conventionally assigned a group key for control purposes, the target devices or storage media to be grouped may be associated with a single license for easier grouping control according to the invention.
It is also possible to register beforehand each of the devices forming a given group for the same control purpose. Typical grouping with devices registered in advance will now be described.
In this example, the user needs to register beforehand with the server the certificates of the devices to be grouped. The certificates are registered in the steps of the flowcharts in
Referring first to
In step S262, the CPU 21 gains access to the content server 3 based on the user's input through the input unit 26. In step S263, the certificate prepared in step S261 is transmitted to the content server 3.
Alternatively, the certificate received from the license server 4 may be used unmodified for the registration.
The steps above are carried out by all devices that constitute the group in question.
Described below with reference to the flowchart of
The steps above are carried out regarding each of the devices constituting the group in question. As a result, the storage unit 28 of the content server 3 has the certificates of the devices registered in units of groups, as illustrated in
In the example of
Likewise, certificates C21 through C23 are registered in association with a group 2. The certificates C21 through C23 include corresponding public keys KP21 through KP23 respectively.
In the manner described, the devices constituting each of the groups above have their certificates registered in advance. It might happen that a user possessing a group of devices requests the content server 3 to provide a content to the grouped devices. In that case, the content server 3 carries out the steps in the flowchart of
In step S281, the CPU 21 of the content server 3 first authenticates the certificates belonging to the group in question from among the certificates held in the storage unit 28.
The authenticating process of step S281 is carried out as described above with reference to
In step S282, the CPU 21 of the content server 3 selects the certificates found valid following the authenticating process of step S281. In step S283, the CPU 21 encrypts the content key using those certificates of the devices which were selected in step S282. In step S284, the CPU 21 transmits to the grouped devices the content together with the content key encrypted in step S283.
Suppose now that in the group 1 of
In the example of
In conjunction with the process of
In step S291, the CPU 21 of the client 1 receives the content together with the content key following its transmission from the content server 3 in step S284 of
In step S292, the CPU 21 using its own private key decrypts and acquires the content key addressed to the client, the self-addressed content key having been received in step S291. The acquired content key is then used to decrypt the content.
Illustratively, the device corresponding to the certificate Cll shown in
The above-described steps are also carried out by the devices corresponding to the certificates C12 and C13. The device corresponding to the revoked certificate C14 does not receive along with the content a content key Kc that would have been encrypted by use of the public key specific to the device in question. That means the device is incapable of acquiring the content using the content key Kc.
In the foregoing description, devices are shown grouped with respect to the content key (i.e., content). Alternatively, devices may be grouped with regard to a license key (i.e., license).
In the manner described, multiple devices may be grouped for control purposes without recourse to a special group key or to an ICV (integrity check value), to be described later. The grouping procedure above is best suited for grouping a small number of devices.
According to this invention, it is also possible to checked out, check in, move or copy licenses. These processes are carried out under rules stipulated by SDMI.
How a license is checked out by a client will now be described by referring to the flowcharts of
Described first are the steps in which the client checks out a license to another client, as shown in
In step S302, the CPU 21 reads a maximum check-out count N2 of the license to be checked out. The maximum check-out count is also retrieved from the use conditions of the license.
In step S303, the CPU 21 compares the check-out count N1 retrieved in step S301 with the maximum check-out count N2 read in step S302. A check is made to see if the check-out count N1 is smaller than the maximum check-out count N2.
If the check-out count N1 is judged smaller than the maximum check-out count N2, step S304 is reached. In step S304, the CPU 21 acquires the leaf key of the other client (i.e., client of the check-out destination) and writes the acquired leaf key to a check-out list in the storage unit 28 in correspondence with the ID of the license to be checked out.
In step S305, the CPU 21 increments by 1 the check-out count N1 of the license, the count having been retrieved in step S301. In step S306, the CPU 21 computes an ICV based on the message of the license. The ICV will be described later with reference to
In step S307, the CPU 21 encrypts the license in question as well as the ICV computed in step S306 using the public key of this client, and outputs what is encrypted together with an EKB and a certificate to the other client for copying. In step S308, the CPU 21 writes the ICV computed in step S306 to a check list in the storage unit 28 in correspondence with the leaf key of the other client and the license ID.
If in step S303 the check-out count N1 is not judged smaller than (e.g., found equal to) the maximum check-out count N2, that means the maximum permissible check-out count has been exhausted so that the license can no longer be checked out. In that case, the CPU 21 goes to step S309 for error handling. The check-out process will be terminated unaccomplished.
Described below with reference to the flowchart of
In step S321, the CPU 21 of the client 1 (of the check-out destination) transmits the leaf key of this client to another client (i.e., the license check-out source client). The leaf key is stored by the other client in correspondence with the license ID (in step S304).
In step S322, the CPU 21 receives from the other client 1 the encrypted license and ICV together with the EKB and certificate. The license, ICV, EKB, and certificate were transmitted earlier by the other client in step S307 of
In step S323, the CPU 21 stores into the storage unit 28 the license, ICV, EKB, and certificate received in step S322.
The client 1 has the license checked out thereto from the other client in the manner described above. Thereafter, the client 1 reproduces the content corresponding to the checked-out license by carrying out the steps in the flowchart of
In step S341, the CPU 21 of the client 1 computes the ICV of the content designated to be reproduced by the user through the input unit 26. In step S342, the CPU 21 decrypts the ICV in the storage unit 28 based on the public key included in the certificate.
In step S343, the CPU 21 judges whether or not the ICV computed in step S341 matches the ICV that was retrieved and decrypted in step S341. If the two values match, it means the license has not been tampered with. In that case, the CPU 21 goes to step S344 to reproduce the applicable content.
If in step S343 the two ICVs fail to match, that means the license may have been tampered with. In such a case, the CPU 21 goes to step S345 for error handling. Here, the content cannot be reproduced by use of the license in question.
Described below with reference to the flowchart of
In step S361, the CPU 21 first acquires the leaf key of the other client (i.e., the client about to check in the license) and the ID of the license to be checked in. In step S362, the CPU 21 judges whether or not the target license whose ID was acquired in step S361 is a license previously checked out from this client to the other client. The judgment is made based on the ICV, leaf key and license ID stored in step S308 of
If the result of the check in step S362 is affirmative, then the CPU 21 goes to step S363 requesting the other client to delete the license, EKB and certificate involved. Given the request, the other client deletes the license, EKB and certificate as will be described later (in step S383 of
In step S364, the CPU 21 decrements by 1 the check-out count N1 of the license in question. This is done to reflect the fact that a previously checked-out license is now returned (i.e., checked in).
In step S365, the CPU 21 determines whether or not this client has any other license still checked out to the other client. If there is no such license, step S366 is reached in which the CPU 21 deletes from the check-out list the record of the other client as a possible client for subsequent check-in. If in step S365 any other license is judged still checked out to the other client, the other client may subsequently request another check-in session and thus step S366 is skipped.
If in step S362 the license in question is not judged to be one previously checked out to the other client, then the CPU 21 goes to step S367 for error handling. In this case, the license in question is not subject to control by this client and the check-in process will not take place.
If the user has illegally copied the license, the stored ICV becomes different from the ICV computed on the basis of the license acquired in step S361. In that case, the check-in process will end unaccomplished.
In step S381, the CPU 21 of the client 1 transmits to another client (i.e., client 1 carrying out the steps in the flowchart of
In step S382, the CPU 21 of this client 1 judges whether or not the other client has requested deletion of the license. That is, if the license is a legitimate license that can be checked in, the other client requests deletion of the license, EKB and certificate involved in step S363 as described above. Upon receipt of that request, the CPU 21 reaches step S383 to delete the license, EKB and certificate. Following step S383, the other client can no longer make use of the license in question. The check-out count N1 of the license is then decremented by 1 in step S364 and the check-in process is accomplished.
If in step S382 the other client is not judged to request the deletion of the license, then the CPU 21 goes to step S384 for error handling. The check-in process remains unaccomplished due to a mismatch of the ICVs involved.
In the same manner in which the check-in and check-out processes are carried out as described above, licenses can also be copied or moved from one client to another.
What follows is a description of how an integrity check value (ICV) is generated for each license, how the ICV is brought into correspondence with the license, and how the ICV is computed to determine whether or not the license in question has been tampered with. The same process applies to prevention of tampering with regard to both licenses and contents.
The ICV (integrity check value) for a given license is computed illustratively by having a hash function applied to that license as
ICV=hash(Kicv, L1, L2, . . . )
where Kicv stands for an ICV generation key, and L1, L2, . . . denote license information. A message authentication code (MAC) for use in ICV generation constitutes an important element of the license information.
A hash function is applied to the MAC thus acquired and to the ICV generation key for the license, whereby an integrity check value (ICV) of the license is generated. Illustratively, if the ICV created upon generation of the license is judged to be the same as the ICV produced anew based on the license, it guarantees that the license has not been tampered with. If the two ICVs are found to be different upon comparison, that means the license has been tampered with.
Described below is how the ICV generation key Kicv of a given license is typically delivered to devices using the above-described enabling key block (EKB). In this case, encrypted message data in the EKB are used as the ICV generation key for the license in question.
In the example of
The other devices 4, 5, 6, 7, etc., even when they receive the same enabling key block (EKB), cannot acquire the renewed node key K(t)00 by decrypting the received EKB using their own node keys and leaf keys. Thus only the legitimate devices alone can receive the delivered ICV generation key.
In the example of
Shown on the right-hand side of
The devices 4, 5, 6, etc., in other groups shown in
Where the ICV generation key is delivered by use of the EKB as described above, it is possible to implement a scheme whereby the ICV generation key is delivered in a way securely decryptable only by those entitled to receive the key with a minimum of data amount involved.
The use of the integrity check value (ICV) for licenses makes it possible to eliminate illegal copy of EKBs and encrypted licenses. Illustratively, as shown in
In the example of
ICV=hash(Kicv, Ll, L2)
which is an integrity check value computed by having a hash function applied to the licenses L1 and L2. In the example of
In the case of
In order to enhance security further, it is possible to generate the integrity check value (ICV) for each license on the basis of data including a renewal counter. More specifically, the ICV is computed as
ICV=hash(Kicv, counter+l, L1, L2, . . . )
where the counter (counter+l) is established as a value that is incremented by 1 every time the ICV is renewed. The counter value needs to be stored in a secure memory.
Where the ICV for a license cannot be held on the same storage medium as the license in question, that ICV may be held on a storage medium separate from that of the license.
Illustratively, if a license is placed onto a read-only medium, an MO, or like storage medium that is not copy-protected, then putting the corresponding ICV on the same medium may prompt an unscrupulous user illegally to renew the ICV compromising its integrity. Such an eventuality is circumvented by keeping the ICVs on a secure storage medium in the host machine so that they are retrieved as needed for license copy control (e.g., check-in, check-out, move). This scheme provides securer ICV control measures and more elaborate license tampering checks.
The scheme above is typically implemented as shown in
The clients to which this invention applies include not only so-called personal computers but also PDAs (personal digital assistants), mobile telephones and game consoles.
The series of steps described above may be executed either by hardware or by software. For software-based processing to take place, programs constituting the software may be either incorporated beforehand in dedicated hardware of a computer or installed upon use over a network or from a suitable program storage medium into a general-purpose personal computer or like equipment capable of executing diverse functions.
As shown in
In this specification, the steps which are stored on the program storage medium and which describe the programs to be executed represent not only the processes that are carried out in the depicted sequence (i.e., on a time series basis) but also processes that are conducted parallelly or individually.
Any programs implementing security-related processes should preferably be encrypted to guard against analysis for tampering. Illustratively, the programs for carrying out cryptographic processes should be structured as tamper-resistant modules.
Information placed in the header of a content to identify the license for using that content is not limited to the license ID for uniquely identifying the license in question. In the above-described embodiments, the license ID serves as information which specifies the license granting the use of a particular content; as information which identifies the content whose use is granted by a specific license; and as information which is requested by a license request from the client 1 for identification of a given license. Alternatively, each content may include a list of information about various attributes of the content in question, and each license may comprise a conditional expression of the content whose use is granted by the license in question. In this case, the attribute information attached to each content constitutes information for identifying the license for granting the use of the content in question, and the conditional expression included in each license serves as information for specifying the content whose use is granted by the license in question; the license ID serves as information for uniquely identifying each license. These arrangements make it possible to assign a plurality of licenses to a single content, thereby providing a flexible license issuing scheme.
The content data are not limited to music data. Contents may be constituted illustratively by image data, moving image data, text data, animation data, software programs, or a combination of any of them.
In this specification, the term “system” refers to an entire configuration made up of a plurality of component devices.
As described above, where the information processing apparatus, information processing method, and program according to the first, second, and fourth aspects of the invention are in use the inventive apparatus can manage keys depending on the different provision categories.
As described above, where the information processing apparatus, information processing method, and program according to the fifth, sixth, and eighth aspects of the invention are in use, the inventive apparatus can manage keys depending on the different provision categories.
Where the information processing apparatus, information processing method, and program according to the ninth, tenth, and twelfth aspects of the invention are in use, the inventive apparatus can make use of a plurality of contents belonging to different provision categories.
Where the information processing apparatus, information processing method, and program according to the thirteenth, fourteenth, and sixteenth aspects of the invention are in use, the inventive apparatus can store a plurality of different device node key.
Number | Date | Country | Kind |
---|---|---|---|
P2001-094803 | Mar 2001 | JP | national |
This application is a divisional of U.S. application Ser. No. 10/276,469, filed on Nov. 18, 2002, the disclosure of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 10276469 | Apr 2003 | US |
Child | 11589404 | Oct 2006 | US |