The present invention relates to content protection, and more specifically, to media key blocks in broadcast encryption systems.
Broadcast encryption is an important cryptographic key management approach, especially useful in content protection systems. Two popular broadcast-encryption-based systems are the Content Protection for Recordable Media (CPRM) system from IBM, Intel, Panasonic, and Toshiba, and the Advanced Access Content System (AACS) from Disney, IBM, Intel, Microsoft, Panasonic, Sony, Toshiba, and Warner Bros.
A media key block is the fundamental structure in broadcast-encryption-based system. This structure is also sometimes called a session key block. A media key block is a data structure which is processed by a device using a set of device keys. The result of the processing allows the device to calculate a media key. The media key, in turn, is used to decrypt a message. In content protection systems, these “messages” are actually content like video or music. Often in a content protection system, each piece of content is associated with a different media key block.
In some cases, the media key block is associated with a set of devices, not a particular item of content. One such example is IBM's Advanced Secure Content Cluster Technology (ASCCT), in which all the content that devices can access is protected by a single media key block. This feature is useful, for example, in case where a consumer might have a library of entertainment content in his home, and wants that library to be freely viewed by all the devices he owns. It should be noted that in this single media key block, it is often the case that not all the content being protected is equally valuable. For example, the user might have some movies in standard definition and some movies in high definition. From the point of view of the movies' creators, the high definition version is more valuable, and would have more serious economic consequences if the users were to make unlimited unauthorized copies. Likewise, not all devices are equally privileged. There is no reason, for example, why a standard definition television needs a set of keys that allows it to decrypt high-definition video.
According to one embodiment of the present invention, a method comprises: receiving a common media key block in a device of a first class and in a device of a second class; calculating a first media key from the common media key block in the device of a first class; calculating a first media key precursor from the common media key block in the device of a second class; and calculating a second media key from the first media key precursor in the device of a second class.
According to another embodiment of the present invention, a method comprises: receiving encrypted media of a first class in a device of the first class, the encrypted media of a first class including a common media key block; receiving encrypted media of a second class in a device of the second class, the encrypted media of a second class including the common media key block; calculating a first media key from the common media key block in the device of a first class; calculating a first media key precursor from the common media key block in the device of a second class; decrypting the encrypted media of a first class using the first media key; and decrypting the encrypted media of a second class using the first media key precursor.
According to a further embodiment of the present invention, a system comprises: a common media key block; a plurality of devices, each receiving the common media key block, the plurality of devices including a device belonging to a first class and a device belonging to a second class; the device belonging to a first class including means for generating a first media key from the common media key block, the first media key corresponding to the first class; and the device belonging to a second class including means for calculating a first media key precursor using the common media key block, and means for calculating a second media key from the first media key precursor.
According to another embodiment of the present invention, a computer program product for broadcast encryption comprises: a computer usable medium having computer usable program code embodied therewith, the computer usable program code comprising: computer usable program code configured to: receive a common media key block in a device of a first class and in a device of a second class; calculate a first media key from the common media key block in the device of a first class; calculate a first media key precursor from the common media key block in the device of a second class; and calculate a second media key from the first media key precursor in the device of a second class.
Embodiments of the invention provides a broadcast encryption system having a single media key block in which all devices are not equally protected and all devices are not equally privileged. In contrast, in prior single-media-key-block systems, such as ASCCT, all content was equally protected, and all devices are equally privileged, by virtue of the fact that all devices process the same media key block and learn the same media key.
It may be noted that in order to provide different levels of protection and privilege to different devices, one approach might be to employ multiple media key blocks, one for each class of content. The problem with this approach is that the devices do need a common media key block for other reasons. For example, a common media key block is useful to securely form the cluster. A cluster might be, for example, a set of devices connected to a private network in a consumer's home. It is important to the content owners that all the devices in the network be compliant; in other words, all devices follow the same rules in protected content. Therefore, it is important that all the devices can calculate a common cryptographic key, so that each can verify that the others are compliant. (Non-compliant devices would be revoked in the media key block and would be unable to calculate the common key.)
Also, a common media key block is needed to enable the devices to remain in synchronization when new media key blocks revoke newly discovered circumvention devices. A cluster contains not just a common media key block, but also other data files, in particular the list of the authorized devices in the cluster. This authorization list must be cryptographically “signed” by the common key(s) in the cluster. Obviously, if there is more than one key in use in the cluster, synchronizing the signing when the new media key block is delivered is much more complicated.
Thus, having multiple media key blocks, although theoretically possible, would greatly complicate the synchronization process. The present invention retains a single media key block, with its straightforward synchronization, while still allowing different classes of devices to learn different keys from the same media key block.
Embodiments of the present invention accomplish this by using a one-way cryptographic function to define a hierarchy of keys. The highest security class devices initially calculate a media key precursor instead of a media key from their processing of the media key block. Then, these devices can execute a previously-defined one-way function on this precursor. The result is either the media key, or another precursor, if there are more than two security classes in the system. Likewise, executing the one-way function on that second precursor can produce another precursor. This chain of one-way functions can be defined to any depth, allowing a single system to have any number of security classes. The last one-way function in the chain yields the media key. The precursors then become keys that can be used to protect content.
In the example described above, where some devices in a home are high-definition and some are standard-definition, the immediate precursor of the media key may be used to protect the high definition content, and the media key itself may be used to protect the standard definition content.
Note that the high definition devices that calculate the precursor key from the media key block are also able to calculate the media key itself by using the one-way function. Thus, they can decrypt standard definition content, and, perhaps more importantly, have a key they can use to synchronize cryptographically with the standard definition devices. This is how the present invention provides the desired synchronization functionality.
Referring now to
System 10 comprises a unified media key block module 15, a traitor detection module 20, a media module 25, and a media player module 30. The media player module 30 comprises a device key set 35 that is uniquely associated with a media player 40. The media player 40 may comprise any one of a number of devices used to play digital media, including, but not limited to DVD players, personal computers, movie rental boxes which are allowed to play a move for a limited period of time, and others. The media player module 30 further comprises a software programming code or a computer program product that is typically embedded within, or installed on the media player 40.
The media module 25 comprises a unified media key block 45 (interchangeably reference herein as MKBu 45) and a variant key table 50. The unified media key block 45 comprises a subset of available device keys and a data part in which each of the subset of device keys individually encrypts a set of media key variants. For example, the subset of device keys may be organized in a tree structure, such as in the subset-difference broadcast encryption scheme, although all broadcast encryption schemes are within the scope of this invention. The media module 25 comprises a software programming code or a computer program product that is saved onto a media 55.
The unified media key block module 15 generates one or more unified media key blocks for use by a content provider 60 to place on the media 55 together with an encrypted digital content 65 (interchangeably referenced herein as encrypted content 65). The unified media key block module 15 comprises a software programming code or a computer program product that is typically embedded within, or installed on a server 70 that belongs to a separate facility, for example, a license agency 75. Alternatively, system 10 can be saved on a suitable memory or storage medium such as a diskette, a CD, a DVD, a hard drive, or like devices.
The traitor detection module 20 identifies the device keys that have been compromised by a traitor or have been pirated. The traitor detection module 20 passes the identified device keys to the unified media key block module 15 to revoke those identified device keys from any future unified media key blocks, preventing further piracy by that traitor or attacker. The traitor detection module 20 comprises a software programming code or computer program product that is shown, for illustration purposes only, as embedded within, or installed on server 70 of the license agency 75. Alternatively, the traitor detection module 20 may be installed in a separate facility other than the one that issues unified media key blocks to content providers.
The media player 40 can access a server 80 of the content provider 60 through a network 85 to obtain the encrypted digital content 65 and a title key 90. The title key 90 (interchangeably referenced herein as Kt 90) allows the media player 40 to decrypt and play the encrypted content 65 after the encrypted content 65 has been recorded to media 55. The title key 90 is encrypted, and requires the media player 40 to correctly process the unified media key block 45 to decrypt and use the unified media key block 45. The content provider 60 may record the encrypted content 65 and the encrypted title key 90 directly to the media 55 such as, for example, a CD or DVD. A user may then obtain the encrypted content 65 by, for example, purchasing the CD.
The media player 40 comprises any compliant module that can verify the physical presence of a media 55 such as, for example, a disk. A compliant module is one that follows the usage rules of the media module 25 that are cryptographically bound to media 55. For example, a compliant recorder does not record content encoded “do not copy”.
In this embodiment, class A content 106 requires the least amount of security, class B content 108 requires a higher level of security, and Class C requires the highest level of security. Media player 100 is configured to play only class A content 106. Media player 102 is configured to play class A content 106 and class B content 108. Media player 110 is configured to play class A content 106, class B content 108 and class C content 110. For example, Class A content may be standard definition content, Class B may be high definition content, and Class C may be content requiring even higher level of security than high-definition content.
The three classes of content are received by the media players 100, 102 and 104 through a network 112, which may comprise one or more of a variety of known ways of distributing digital content. Referring now to
Referring now to
Media player 102 also has the ability to process class A content 106. It does this by processing the encrypted class A content 106 to produce the first media key precursor 128 and then uses a one-way function 136 to calculate a media key 138. Decryption unit 132 may then use the media key 138 to output decrypted class A content 140.
Referring now to
Media player 104 may also process class B content by calculating a first media key precursor 154 from the second media key precursor 146 using a one-way function 156. This first media key precursor 154 may then be used by the decryption unit 150 to output decrypted class B content 155. Likewise, media player 104 may also process class A content 106 by calculating a media key 158 from the first media key precursor 154 using a one-way function 160. This media key 158 may then be used by the decryption unit 150 to output decrypted class A content 162.
The device of a second class calculates a first media key precursor using the common media key block, in step 172. This media key precursor may then be used by the second class device to decrypt encrypted content of a second class, in step 174. As described above, the second class device may also calculate a media key from the media key precursor to decrypt content of a first class.
It may be noted that the licensing agency 75, as shown in
Embodiments of the invention may utilize a variety of known one-way functions. In one embodiment, the following well-known one-way function, based on the Advanced Encryption Standard (AES) cipher, is used:
r=AES−D(k, d)XOR d
where r is the result, k is a key, d is data, AES-D is AES decryption in electronic code book mode, and XOR is exclusive-or. This function is one-way in the following sense: from r, it is intractable to calculate either k or d. In this embodiment, k would be a media key precursor and d would be a constant known to all devices. Note that d does not have to be a secret. It can be a published constant without hurting the security of this invention.
It will be appreciated by those skilled in the art that the various keys in the media key one-way chain protect the various classes of content. However, in practice, it is rare in content protection systems for keys from the media key block to directly encrypt the content. Instead, there is often at least one a level of indirection: the content is encrypted with a title key, and then the title key is encrypted with the key from the media key block. This encrypted title key is typically stored in a header associated with the content. Hence some embodiments of the invention may employ this technique of using one or more levels of indirection of keys to protect the content.
As can be seen from the above disclosure, embodiments of the invention provide a broadcast encryption system that employs a common media key block, while providing different levels of protection for different media and different devices.
As will be appreciated by one skilled in the art, the present invention may be embodied as a system, method or computer program product. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present invention may take the form of a computer program product embodied in any tangible medium of expression having computer usable program code embodied in the medium.
Any combination of one or more computer usable or computer readable medium(s) may be utilized. The computer-usable or computer-readable medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a non-exhaustive list) of the computer-readable medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CDROM), an optical storage device, a transmission media such as those supporting the Internet or an intranet, or a magnetic storage device. Note that the computer-usable or computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory. In the context of this document, a computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. The computer-usable medium may include a propagated data signal with the computer-usable program code embodied therewith, either in baseband or as part of a carrier wave. The computer usable program code may be transmitted using any appropriate medium, including but not limited to wireless, wire line, optical fiber cable, RF, etc.
Computer program code for carrying out operations of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
The present invention is described with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The computer system can include a display interface 206 that forwards graphics, text, and other data from the communication infrastructure 204 (or from a frame buffer not shown) for display on a display unit 208. The computer system also includes a main memory 210, preferably random access memory (RAM), and may also include a secondary memory 212. The secondary memory 212 may include, for example, a hard disk drive 214 and/or a removable storage drive 216, representing, for example, a floppy disk drive, a magnetic tape drive, or an optical disk drive. The removable storage drive 116 reads from and/or writes to a removable storage unit 218 in a manner well known to those having ordinary skill in the art. Removable storage unit 218 represents, for example, a floppy disk, a compact disc, a magnetic tape, or an optical disk, etc. which is read by and written to by removable storage drive 216. As will be appreciated, the removable storage unit 218 includes a computer readable medium having stored therein computer software and/or data.
In alternative embodiments, the secondary memory 212 may include other similar means for allowing computer programs or other instructions to be loaded into the computer system. Such means may include, for example, a removable storage unit 220 and an interface 222. Examples of such means may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 220 and interfaces 222 which allow software and data to be transferred from the removable storage unit 220 to the computer system.
The computer system may also include a communications interface 224. Communications interface 224 allows software and data to be transferred between the computer system and external devices. Examples of communications interface 224 may include a modem, a network interface (such as an Ethernet card), a communications port, or a PCMCIA slot and card, etc. Software and data transferred via communications interface 224 are in the form of signals which may be, for example, electronic, electromagnetic, optical, or other signals capable of being received by communications interface 224. These signals are provided to communications interface 224 via a communications path (i.e., channel) 226. This communications path 226 carries signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link, and/or other communications channels.
In this document, the terms “computer program medium,” “computer usable medium,” and “computer readable medium” are used to generally refer to media such as main memory 210 and secondary memory 212, removable storage drive 216, and a hard disk installed in hard disk drive 214.
Computer programs (also called computer control logic) are stored in main memory 210 and/or secondary memory 212. Computer programs may also be received via communications interface 224. Such computer programs, when executed, enable the computer system to perform the features of the present invention as discussed herein. In particular, the computer programs, when executed, enable the processor 202 to perform the features of the computer system. Accordingly, such computer programs represent controllers of the computer system.
From the above description, it can be seen that the present invention provides a system, computer program product, and method for implementing the embodiments of the invention. References in the claims to an element in the singular is not intended to mean “one and only” unless explicitly so stated, but rather “one or more.” All structural and functional equivalents to the elements of the above-described exemplary embodiment that are currently known or later come to be known to those of ordinary skill in the art are intended to be encompassed by the present claims. No claim element herein is to be construed under the provisions of 35 U.S.C. section 112, sixth paragraph, unless the element is expressly recited using the phrase “means for” or “step for.”
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Number | Name | Date | Kind |
---|---|---|---|
4041249 | Matz et al. | Aug 1977 | A |
4634807 | Chorley et al. | Jan 1987 | A |
4694491 | Horne et al. | Sep 1987 | A |
4864616 | Pond et al. | Sep 1989 | A |
5058162 | Santon et al. | Oct 1991 | A |
5065429 | Lang | Nov 1991 | A |
5081677 | Green et al. | Jan 1992 | A |
5177791 | Yeh et al. | Jan 1993 | A |
5247497 | Cohn | Sep 1993 | A |
5272752 | Myers et al. | Dec 1993 | A |
5345505 | Pires | Sep 1994 | A |
5412723 | Canetti et al. | May 1995 | A |
5592552 | Fiat | Jan 1997 | A |
5598470 | Cooper et al. | Jan 1997 | A |
5636276 | Brugger | Jun 1997 | A |
5651064 | Newell | Jul 1997 | A |
5668873 | Yamauchi | Sep 1997 | A |
5680457 | Bestler et al. | Oct 1997 | A |
5708632 | Totsuka et al. | Jan 1998 | A |
5734719 | Tsevdos et al. | Mar 1998 | A |
5754648 | Ryan et al. | May 1998 | A |
5754649 | Hasebe et al. | May 1998 | A |
5796824 | Hasebe et al. | Aug 1998 | A |
5910987 | Ginter et al. | Jun 1999 | A |
5949885 | Leighton | Sep 1999 | A |
6020833 | Herz et al. | Feb 2000 | A |
6061451 | Muratani et al. | May 2000 | A |
6118873 | Lotspiech | Sep 2000 | A |
6134201 | Sako et al. | Oct 2000 | A |
6209092 | Linnartz | Mar 2001 | B1 |
6285774 | Schumann et al. | Sep 2001 | B1 |
6289455 | Kocher et al. | Sep 2001 | B1 |
6347846 | Nakamura | Feb 2002 | B1 |
6370272 | Shimizu | Apr 2002 | B1 |
6381367 | Ryan | Apr 2002 | B1 |
6434535 | Kupka et al. | Aug 2002 | B1 |
6442108 | Kurihara et al. | Aug 2002 | B1 |
6442626 | Smola et al. | Aug 2002 | B1 |
6535858 | Blaukovitsch et al. | Mar 2003 | B1 |
6556679 | Kato et al. | Apr 2003 | B1 |
6563937 | Wendt | May 2003 | B1 |
6587949 | Steinberg | Jul 2003 | B1 |
6604072 | Pitman et al. | Aug 2003 | B2 |
6609116 | Lotspiech | Aug 2003 | B1 |
6636966 | Lee et al. | Oct 2003 | B1 |
6738878 | Ripley et al. | May 2004 | B2 |
6760445 | Schwenk et al. | Jul 2004 | B1 |
6760539 | Asada et al. | Jul 2004 | B2 |
6775779 | England et al. | Aug 2004 | B1 |
6802003 | Gross et al. | Oct 2004 | B1 |
6832319 | Bell et al. | Dec 2004 | B1 |
6839436 | Garay et al. | Jan 2005 | B1 |
6856997 | Lee et al. | Feb 2005 | B2 |
6857076 | Klein | Feb 2005 | B1 |
6888944 | Lotspiech et al. | May 2005 | B2 |
6901548 | Hattori et al. | May 2005 | B2 |
6912634 | Ripley et al. | Jun 2005 | B2 |
6947563 | Fagin et al. | Sep 2005 | B2 |
6993135 | Ishibashi | Jan 2006 | B2 |
6999947 | Utsumi et al. | Feb 2006 | B2 |
7007162 | Lotspiech | Feb 2006 | B1 |
7010125 | Lotspiech et al. | Mar 2006 | B2 |
7036024 | Watson | Apr 2006 | B2 |
7039803 | Lotspiech et al. | May 2006 | B2 |
7046808 | Petrovic et al. | May 2006 | B1 |
7057993 | Barnard et al. | Jun 2006 | B2 |
7082537 | Muratani | Jul 2006 | B2 |
7120901 | Ferri et al. | Oct 2006 | B2 |
7155591 | Ripley et al. | Dec 2006 | B2 |
7162646 | Wu et al. | Jan 2007 | B2 |
7215629 | Eppler | May 2007 | B2 |
7260834 | Carlson | Aug 2007 | B1 |
7283633 | Asano et al. | Oct 2007 | B2 |
7296159 | Zhang et al. | Nov 2007 | B2 |
7305711 | Ellison et al. | Dec 2007 | B2 |
7319752 | Asano et al. | Jan 2008 | B2 |
7346169 | Asano et al. | Mar 2008 | B2 |
7380132 | Sako et al. | May 2008 | B2 |
7380137 | Bell et al. | May 2008 | B2 |
7392392 | Levy | Jun 2008 | B2 |
7502933 | Jakobsson et al. | Mar 2009 | B2 |
7555129 | Yamamoto et al. | Jun 2009 | B2 |
7590238 | Kamijoh et al. | Sep 2009 | B2 |
20020003881 | Reitmeier et al. | Jan 2002 | A1 |
20020044320 | Pfeiffer et al. | Apr 2002 | A1 |
20020104001 | Lotspiech et al. | Aug 2002 | A1 |
20020141582 | Kocher et al. | Oct 2002 | A1 |
20030070083 | Nessler | Apr 2003 | A1 |
20030169885 | Rinaldi | Sep 2003 | A1 |
20030220921 | Fagin et al. | Nov 2003 | A1 |
20040034787 | Kitani | Feb 2004 | A1 |
20040098593 | Muratani | May 2004 | A1 |
20040111611 | Jin et al. | Jun 2004 | A1 |
20040128259 | Blakeley et al. | Jul 2004 | A1 |
20040133794 | Kochner et al. | Jul 2004 | A1 |
20040153941 | Muratani | Aug 2004 | A1 |
20050021568 | Pelly | Jan 2005 | A1 |
20050097110 | Nishanov et al. | May 2005 | A1 |
20050141704 | Van Der Veen | Jun 2005 | A1 |
20050283610 | Metios et al. | Dec 2005 | A1 |
20060056695 | Wu et al. | Mar 2006 | A1 |
20060085343 | Lisanke et al. | Apr 2006 | A1 |
20060136728 | Gentry et al. | Jun 2006 | A1 |
20060239503 | Petrovic et al. | Oct 2006 | A1 |
20060282676 | Serret-Avila et al. | Dec 2006 | A1 |
20070067242 | Lotspiech et al. | Mar 2007 | A1 |
20070067244 | Jin et al. | Mar 2007 | A1 |
20070165853 | Jin et al. | Jul 2007 | A1 |
20070174637 | Lotspiech et al. | Jul 2007 | A1 |
Number | Date | Country |
---|---|---|
WO 9919822 | Apr 1999 | WO |
WO 0048190 | Aug 2000 | WO |
WO 0122406 | Mar 2001 | WO |
Entry |
---|
U.S. Appl. No. 12/131,073, filed May 31, 2008, Bellwood et al. |
U.S. Appl. No. 12/131,074, filed May 31, 2008, Lotspiech. |
U.S. Appl. No. 12/131,076, filed May 31, 2008, Jin et al. |
U.S. Appl. No. 12/143,061, filed Jun. 20, 2008, Jin et al. |
U.S. Appl. No. 12/143,658, filed Jun. 20, 2008, Jin et al. |
U.S. Appl. No. 12/192,962, filed Aug. 15, 2008, Jin et al. |
Celik et al., “Collusion-resilient fingerprinting using random prewarping,” Image Processing, 2003, ICIP 2003, Proceedings, 2003 International Conference vol. 1, Sep. 14-17, 2003 pp. I-509-12, vol. 1. |
Deguillaume et al., “Countermeasures for unintentional and intentional video watermarking attacks,” Conference SPIE—Int. Soc. Opt. Eng. (USA), Jan. 24-26, 2000, vol. 3971, p. 346-357. |
Fernandez-Munoz et al., “Fingerprinting schemes for the protection of multimedia distribution rights,” Upgrade, Security in e-Commerce, v. III, n. 6, pp. 36-40, Dec. 2002, http://www.cepis-upgrade.org/issues/2002/6/upgrade-vIII-6.pdf. |
Hagiwara et al., “A short random fingerprinting code against a small number of pirates” Applied Algebra, Algebraic Algorithms and Error-Correcting Codes, 16th International Symposium, AAEECC-16. Proceedings (Lecture Notes in Computer Science vol. 3857) pp. 193-202 (Feb. 2-24, 2006). |
Seol et al., “A scalable fingerpriting scheme for tracing traitors/colluders in large scale contents distribution environments,” Intelligent Systems Design and Applications, 2005. ISDA 2005, Proceedings, 5th International Conference Sep. 8-10, 2005 pp. 228-223. |
Number | Date | Country | |
---|---|---|---|
20100040231 A1 | Feb 2010 | US |