The present invention relates to an encryption system for encrypting at least a portion of streamed digital content protected by a rights management (RM) system, whereby access to is provided only in accordance with a corresponding digital license. More particularly, the invention relates to an encryption system that allows the encrypted stream to be more easily manipulated.
Rights management (RM) and enforcement is highly desirable in connection with digital content such as digital audio, digital video, digital text, digital data, digital multimedia, etc., where such digital content is to be distributed to one or more users. Digital content could be static, such as a text document, for example, or it could be streamed, such as the streamed audio and video of a multimedia presentation. Typical modes of distribution of such streamed content include tangible and intangible forms such as an optical disk, a cable-access feed, a feed from an electronic network such as the Internet, a feed from an over-the-air broadcast, etc. Upon being received by a user at an appropriate computing device thereof, such user renders the streamed digital content with the aid of the computing device, appropriate rendering software, and appropriate output devices such as speakers, a video monitor, etc.
In one scenario, the streamed content is distributed by a distributor as part of a subscription service, such as for example a digital television service, and the streamed content as distributed is either protected, such as for example by being encrypted, or is unprotected. If it is the case that the streamed content is indeed distributed in an unprotected form, it may be the case that the distributor primarily intends for the streamed content to be immediately consumed and rendered, and not stored in any meaningful retrievable form. For example, the streamed content may be one of many streams of content in a digital cable television signal that is to be received by a digital cable set-top box and immediately rendered thereby, and is then to be forwarded to the aforementioned appropriate output devices.
However, it is to be appreciated that storage systems exist and/or are being developed that can indeed store the streamed content for later rendering and/or re-distribution to other computing devices. With regard to such storage systems, then, the distributor of the streamed unprotected content would rather not have such unprotected content stored in the unprotected form and without any ability to restrict such re-distribution, if so desired. In particular, the distributor or the like may wish to prohibit the user from copying such streamed content to another storage system or the like, may wish to allow the user to copy with temporal and/or count restrictions, or the like. As may be appreciated, by prohibiting unlimited copying of the streamed content, the distributor can avoid the unchecked dispersal of pristine digital copies of the streamed content, where such unchecked dispersal would encourage other users from foregoing from subscribing to the subscription service offered by such distributor.
In addition, the distributor may wish to provide various users with different rendering rights. For example, the distributor may offer different tiers of service, where higher-level tiers correspondingly command higher subscription fees, and where a user subscribing at a particular tier should not be allowed to access streamed content from higher tiers in an unprotected form.
Note, though, that after the streamed content has been distributed, the distributor has very little if any real control over the streamed content. This is especially problematic in view of the fact that most any personal computer includes the software and hardware necessary to make an exact digital copy of such streamed content, and to download such exact digital copy to a re-distribution medium such as an optical disk, or to send such exact digital copy over a network such as the Internet to any destination.
Of course, as part of a transaction wherein the streamed content is subscribed to, the distributor may require the user/recipient of the streamed content to promise not to re-distribute such content in an unwelcome manner. However, such a promise is easily made and easily broken. The distributor may attempt to prevent such re-distribution through any of several known security devices, usually involving encryption and decryption. However, such security devices if especially simple pose little problem to a mildly determined user who wishes to decrypt encrypted content, save such content in an un-encrypted form, and then re-distribute same.
RM and enforcement architectures and methods have thus been provided to allow the controlled rendering of arbitrary forms of digital content including streamed content, where such control is flexible and definable by the distributor or the like of such digital content. Such architectures allow and facilitate such controlled rendering in the scenario as set forth above.
In one particular arrangement, the streamed content is one of a plurality of streams of such content provided as a combined signal to a receiver. The receiver selects a particular one of the streams upon command from a media system, and provides the selected stream to such media system for further processing. Notably, the selected stream as provided to the receiver is unprotected, but prior to being provided to the media system the selected stream is in fact protected by the receiver according to a particular RM encryption system.
Typically, in an RM encryption system, the content is protected by being encrypted according to a content key (CK). Inasmuch as symmetric encryption and decryption is easier, faster, and less expensive than asymmetric encryption and decryption, such content key (CK) is typically symmetric. Also typically, the content key (CK) is provided by an encrypting entity such as the receiver to a decrypting entity such as the media system in an encrypted form and as part of a digital license or the like that specifies license rules that must be satisfied before such content is allowed to be decrypted and rendered by the decrypting entity/media system.
Typically, a particular stream of content includes multiple sub-streams. For example, a multimedia stream may include an audio sub-stream, a video sub-stream, a text sub-stream, a metadata sub-stream, and/or the like. In addition, such stream may include multiple variations of the same type of sub-stream. For example, such stream may include multiple audio sub-streams, each in a different spoken language, multiple text sub-streams, each in a different written language, and multiple video sub-streams, each from a different angle of view of a scene.
As is known, such a stream with multiple sub-streams is typically sent as a number data packets, where each packet includes one or more payloads, and where each payload corresponds to a contiguous portion of one of the sub-streams of the stream. Thus, a particular sub-stream is re-created by locating the payloads thereof from the packets of the stream and sequentially organizing such located payloads. Note that in the case where the stream is encrypted, and as may also be known, each payload is typically formed and then encrypted as a unit, and thus re-creating the sub-stream includes decrypting each encrypted payload as a unit.
As may be appreciated, each payload from a particular sub-stream has a start boundary and an end boundary. As may also be appreciated, each sub-stream is composed of a number of sequentially organized logical blocks of information. For example, a video sub-stream may be composed of video frames, a text stream may be composed of single- or multi-byte characters, an audio sub-stream may be composed of single- or multi-bit audio units, and the like.
In the prior art, the boundaries of any particular payload were determined rather arbitrarily, and typically based on external factors. For example, to achieve a particular bit rate for a stream, the boundaries of each payload of each sub-stream of the stream were selected to achieve such bit rate, and not based on any consideration of the composition and characteristics of the sub-stream from which the payload originated. Thus, if a particular stream included a video sub-stream based on sequential video frames, such video sub-stream as divided into payloads might be broken up into portions of some arbitrary size selected to achieve the particular bit rate of the stream, where the start boundary of each payload started at some point within a particular video frame, where the payload extended over zero, one or more complete video frames, and where the end boundary of the payload ended at some point within a particular video frame.
Such arbitrary boundaries on payloads are not especially troublesome during normal transmission and rendering of a stream. However, it is to be appreciated that such arbitrary boundaries can cause considerable difficulty when the stream is to be manipulated, such as for example when the above media system wishes to re-transmit the stream to another media system, or to perform other operations on the stream. As but one example, if the payloads in a transmitted stream are defined according to a first bit rate and the stream is to be re-transmitted at a second bit-rate, the payloads should be re-configured to support the second bit-rate. However, performing such re-configuration requires essentially decrypting each payload, forming the entire stream from the decrypted payloads, forming new payloads from the formed stream according to the second bit-rate, encrypting each new payload, and the like before such re-transmission at the second bit-rate can take place. As should be appreciated, such an operation requires expending a tremendous amount of effort as necessitated by the use of arbitrary boundaries for the payloads.
Likewise, if an operation is to be performed on a particular sub-stream on a logical block by logical block basis, performing the operation preliminarily requires decrypting each payload, forming the entire stream from the decrypted payloads, and dividing the formed stream into the logical blocks. As should be appreciated here, such preliminary steps would not be absolutely necessary if the payloads were formed based on the logical blocks of the sub-stream.
A need exists, then, for a method and mechanism by which payloads in a stream of content are defined according to non-arbitrary boundaries. In particular, a need exists for a method and mechanism by which payloads in a stream of content are defined according to rational boundaries that are intrinsic to the underlying sub-stream, and that allow the stream to be manipulated without necessarily requiring the stream to be decrypted and re-encrypted.
In the prior art, the entirety of the content in a stream of content was encrypted according to the content key (CK). However, encrypting all of the content in a stream of content is at times unnecessary and perhaps not even desired. For example, there may be little to be gained by encrypting a text sub-stream in a multimedia stream, and such encryption ay in fact not be desired by the content owner or the like. Moreover, it is to be recognized that it may be desirable to encrypt different sub-streams of a stream differently, for example according to different encryption systems and/or according to different content keys (CK).
A need exists, then, for an architecture that may be employed so that each sub-stream within a stream may be protected according to a particular rights management content protect system and a particular content key (CK). In particular, a need exists for such an architecture to specify within the stream the particular rights management content protection and the particular content key (CK) for each sub-stream of the stream. Specifically, a need exists for such an architecture that describes a header object to be included with the stream that may be interpreted and employed when rendering the stream.
The aforementioned needs are satisfied at least in part by the present invention in which a method is provided to transmit a stream of content having multiple sub-streams, where each sub-stream comprises a part of the content and is divisible into logical blocks bounded by intrinsic partitions. In the method, for each sub-stream, a specification of the logical blocks bounded by the intrinsic partitions is defined and the sub-stream is divided into the logical blocks bounded by the intrinsic partitions. Each divided logical block is encrypted and then divided into one or more portions to produce corresponding pieces of data, and each piece of data is placed into a data packet as a payload thereof. Each data packet is transmitted to a recipient thereof, and the recipient can retrieve the pieces of data from the payloads of the packets, reconstruct the encrypted logical blocks, and manipulate the sub-stream on a per-logical block basis without necessarily decrypting each encrypted logical block.
The aforementioned needs are also satisfied at least in part by the present invention in which a stream of content has multiple rights management (RM) protected sub-streams therein, where each RM-protected sub-stream is protected according to a different particular protection scheme. The stream includes a data object including data representative of each sub-stream and a header object including an RM description object. The RM description object includes at least one content encryption record, where each content encryption record corresponds to a particular protection scheme and includes with regard to the protection scheme thereof an identification of the protection scheme and at least one encrypted object records. Each encrypted object record relates to a particular sub-stream protected according to the identified protection scheme of the content encryption record thereof and includes an identification of the particular sub-stream. For each RM-protected sub-stream of the stream, an identification of the sub-stream is employed to find a corresponding encrypted object record, and the protection scheme of the content encryption record of the found encrypted object record is employed to render the sub-stream.
The foregoing summary, as well as the following detailed description of the embodiments of the present invention, will be better understood when read in conjunction with the appended drawings. For the purpose of illustrating the invention, there are shown in the drawings embodiments which are presently preferred. As should be understood, however, the invention is not limited to the precise arrangements and instrumentalities shown. In the drawings:
Although not required, the invention can be implemented via an application programming interface (API), for use by a developer, and/or included within the network browsing software which will be described in the general context of computer-executable instructions, such as program modules, being executed by one or more computers, such as client workstations, servers, or other devices. Generally, program modules include routines, programs, objects, components, data structures and the like that perform particular tasks or implement particular abstract data types. Typically, the functionality of the program modules may be combined or distributed as desired in various embodiments. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations. Other well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers (PCs), automated teller machines, server computers, hand-held or laptop devices, multi-processor systems, microprocessor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network or other data transmission medium. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
With reference to
Computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CDROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
A monitor 191 or other type of display device is also connected to the system bus 121 via an interface, such as a video interface 190. A graphics interface 182, such as Northbridge, may also be connected to the system bus 121. Northbridge is a chipset that communicates with the CPU, or host processing unit 120, and assumes responsibility for accelerated graphics port (AGP) communications. One or more graphics processing units (GPUs) 184 may communicate with graphics interface 182. In this regard, GPUs 184 generally include on-chip memory storage, such as register storage and GPUs 184 communicate with a video memory 186. GPUs 184, however, are but one example of a coprocessor and thus a variety of co-processing devices may be included in computer 110. A monitor 191 or other type of display device is also connected to the system bus 121 via an interface, such as a video interface 190, which may in turn communicate with video memory 186. In addition to monitor 191, computers may also include other peripheral output devices such as speakers 197 and printer 196, which may be connected through an output peripheral interface 195.
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
One of ordinary skill in the art can appreciate that a computer 110 or other client device can be deployed as part of a computer network. In this regard, the present invention pertains to any computer system having any number of memory or storage units, and any number of applications and processes occurring across any number of storage units or volumes. The present invention may apply to an environment with server computers and client computers deployed in a network environment, having remote or local storage. The present invention may also apply to a standalone computing device, having programming language functionality, interpretation and execution capabilities.
Distributed computing facilitates sharing of computer resources and services by direct exchange between computing devices and systems. These resources and services include the exchange of information, cache storage, and disk storage for files. Distributed computing takes advantage of network connectivity, allowing clients to leverage their collective power to benefit the entire enterprise. In this regard, a variety of devices may have applications, objects or resources that may interact to implicate authentication techniques of the present invention for trusted graphics pipeline(s).
It can also be appreciated that an object, such as 110c, may be hosted on another computing device 10 or 110. Thus, although the physical environment depicted may show the connected devices as computers, such illustration is merely exemplary and the physical environment may alternatively be depicted or described comprising various digital devices such as PDAs, televisions, MP3 players, etc., software objects such as interfaces, COM objects and the like.
There are a variety of systems, components, and network configurations that support distributed computing environments. For example, computing systems may be connected together by wire-line or wireless systems, by local networks or widely distributed networks. Currently, many of the networks are coupled to the Internet, which provides the infrastructure for widely distributed computing and encompasses many different networks.
In home networking environments, there are at least four disparate network transport media that may each support a unique protocol such as Power line, data (both wireless and wired), voice (e.g., telephone) and entertainment media. Most home control devices such as light switches and appliances may use power line for connectivity. Data Services may enter the home as broadband (e.g., either DSL or Cable modem) and are accessible within the home using either wireless (e.g., HomeRF or 802.11b) or wired (e.g., Home PNA, Cat 5, even power line) connectivity. Voice traffic may enter the home either as wired (e.g., Cat 3) or wireless (e.g., cell phones) and may be distributed within the home using Cat 3 wiring. Entertainment media may enter the home either through satellite or cable and is typically distributed in the home using coaxial cable. IEEE 1394 and DVI are also emerging as digital interconnects for clusters of media devices. All of these network environments and others that may emerge as protocol standards may be interconnected to form an intranet that may be connected to the outside world by way of the Internet. In short, a variety of disparate sources exist for the storage and transmission of data, and consequently, moving forward, computing devices will require ways of protecting content at all portions of the data processing pipeline.
The ‘Internet’ commonly refers to the collection of networks and gateways that utilize the TCP/IP suite of protocols, which are well-known in the art of computer networking TCP/IP is an acronym for “Transport Control Protocol/Interface Program.” The Internet can be described as a system of geographically distributed remote computer networks interconnected by computers executing networking protocols that allow users to interact and share information over the networks. Because of such wide-spread information sharing, remote networks such as the Internet have thus far generally evolved into an open system for which developers can design software applications for performing specialized operations or services, essentially without restriction.
Thus, the network infrastructure enables a host of network topologies such as client/server, peer-to-peer, or hybrid architectures. The “client” is a member of a class or group that uses the services of another class or group to which it is not related. Thus, in computing, a client is a process, i.e., roughly a set of instructions or tasks, that requests a service provided by another program. The client process utilizes the requested service without having to “know” any working details about the other program or the service itself. In a client/server architecture, particularly a networked system, a client is usually a computer that accesses shared network resources provided by another computer e.g., a server. In the example of
A server is typically a remote computer system accessible over a remote network such as the Internet. The client process may be active in a first computer system, and the server process may be active in a second computer system, communicating with one another over a communications medium, thus providing distributed functionality and allowing multiple clients to take advantage of the information-gathering capabilities of the server.
Client and server communicate with one another utilizing the functionality provided by a protocol layer. For example, Hypertext-Transfer Protocol (HTTP) is a common protocol that is used in conjunction with the World Wide Web (WWW). Typically, a computer network address such as a Universal Resource Locator (URL) or an Internet Protocol (IP) address is used to identify the server or client computers to each other. The network address can be referred to as a Universal Resource Locator address. For example, communication can be provided over a communications medium. In particular, the client and server may be coupled to one another via TCP/IP connections for high-capacity communication.
Thus,
In a network environment in which the communications network/bus 14 is the Internet, for example, the servers 10 can be Web servers with which the clients 110a, 110b, 110c, 110d, 110e, etc. communicate via any of a number of known protocols such as HTTP. Servers 10 may also serve as clients 110, as may be characteristic of a distributed computing environment. Communications may be wired or wireless, where appropriate. Client devices 110 may or may not communicate via communications network/bus 14, and may have independent communications associated therewith. For example, in the case of a TV or VCR, there may or may not be a networked aspect to the control thereof. Each client computer 110 and server computer 10 may be equipped with various application program modules or objects 135 and with connections or access to various types of storage elements or objects, across which files may be stored or to which portion(s) of files may be downloaded or migrated. Thus, the present invention can be utilized in a computer network environment having client computers 110a, 110b, etc. that can access and interact with a computer network/bus 14 and server computers 10a, 10b, etc. that may interact with client computers 110a, 110b, etc. and other devices 111 and databases 20.
Rights Management (RM) Overview
As is known, and referring now to
Typically, a content owner or developer or distributor (hereinafter ‘distributor’) distributing such digital content 32 wishes to restrict what the user can do with such distributed digital content 32, or at least ensure that the content 32 is not redistributed in an unwanted manner. For example, the content distributor may wish to restrict the user from copying and re-distributing such content 32 to a second user, or may wish to allow distributed digital content 32 to be rendered only a limited number of times, only for a certain total time, only on a certain type of machine, only on a certain type of rendering platform, only by a certain type of user, etc.
However, and as was set forth above, after distribution has occurred, such distributor has very little if any control over the digital content 32. An RM system 30, then, allows the controlled rendering of arbitrary forms of digital content 32, where such control is flexible and definable by the content distributor of such digital content. Typically, to protect the content 32, such content 32 is encrypted with a symmetric encryption/decryption key (KD), (i.e., (KD(CONTENT))), and is packaged with other information relevant to the content 32 in a package 33.
The trust-based RM system 30 allows a distributor of digital content 32 to specify at least some license rules that must be satisfied before such digital content 32 is allowed to be rendered by a computing device 34 of a user. Such license rules can include the aforementioned temporal requirement, and may be embodied within a digital license or use document (hereinafter ‘license’) 36 that the user/user's computing device 34 (hereinafter, such terms are interchangeable unless circumstances require otherwise) must be possess. Such license 36 also includes the decryption key (KD) for decrypting the digital content 32, perhaps encrypted according to a key decryptable by the user's computing device 34. As seen in
The content distributor for a piece of digital content 32 must trust that the user's computing device 34 will abide by the rules and requirements specified by such content owner in the license 36, i.e. that the digital content 32 will not be rendered unless the rules and requirements within the license 36 are satisfied. Preferably, then, the user's computing device 34 is provided with a trusted component or mechanism 38 that will not render the digital content 32 except according to the license rules embodied in the license 36 associated with the digital content 32 and obtained by the user.
The trusted component 38 typically has a license evaluator 40 that determines whether the license 36 is valid, reviews the license rules and requirements in such valid license 36, and determines based on the reviewed license rules and requirements whether the requesting user has the right to render the requested digital content 32 in the manner sought, among other things. As should be understood, the license evaluator 40 is trusted in the RM system 30 to carry out the wishes of the owner of the digital content 32 according to the rules and requirements in the license 36, and the user should not be able to easily alter such trusted element for any purpose, nefarious or otherwise.
As should be understood, the rules and requirements in the license 36 might specify whether the user has rights to render the digital content 32 based on any of several factors, including who the user is, where the user is located, what type of computing device the user is using, what rendering application is calling the RM system 30, the date, the time, etc. In addition, the rules and requirements of the license 36 may limit the license 36 to a pre-determined number of renderings, or pre-determined rendering time, for example. Thus, the trusted component 38 may need to refer to a clock 42 on the computing device 34. If such clock 42 is provided, such clock 42 may be a secure clock 42 that cannot be tampered with by a user in an effort to overcome a temporal restriction of a license 36.
The rules and requirements may be specified in the license 36 according to any appropriate language and syntax. For example, the language may simply specify attributes and values that must be satisfied (DATE must be later than X, e.g.), or may require the performance of functions according to a specified script (IF DATE greater than X, THEN DO . . . , e.g.).
Upon the license evaluator 40 determining that the license 36 is valid and that the user satisfies the rules and requirements therein, the digital content 32 can then be rendered. In particular, to render the content 32, the decryption key (KD) is obtained from the license 36 and is applied to (KD(CONTENT)) from the content package 33 to result in the actual content 32, and the actual content 32 is then in fact rendered. As set forth above, the license 36 with (PU-C(KD)) in effect authorizes an entity in possession of (PR-C) to access (KD) and thereby access the content 32 encrypted according to such (KD), presuming of course that the entity abides by all conditions as set forth in the license 36.
Note that a license 36 typically includes a digital signature for authentication/validation purposes. Likewise, other forms of digital constructs such as a piece of digital content 32 may also have such a digital signature for authentication/validation purposes. As should be known, such a digital signature may be constructed based on a first key from a pair of asymmetric keys or from a symmetric integrity key, for example by performing some sort of hash on the underlying data to which the signature is attached and then encrypting the hash with the key. Thereafter, the signature is validated by applying the second key from the pair of asymmetric keys or the integrity key, again for example by decrypting the encrypted hash and comparing the decrypted hash to another hash of the underlying data to which the signature is attached. If the hashes match, it can be presumed that the underlying data has not been altered and the underlying construct therefore can be authenticated. Typically, an RM system 30 will not honor a license 36 or the like that is not authenticated.
System for Receiving and Handling Streamed Multimedia Content 32
Turning now to
In the system 44, the aforementioned input signal as provided by the distributor thereof is applied to a receiver 46 which may be any appropriate receiver without departing from the spirit and scope of the present invention, presuming of course such receiver can performs the functions set forth herein. For example, the receiver 46 may be a Uni-Directional Cable Receiver (UDCR) such as is being developed to receive a digital cable television signal and forward same for further digital processing including rendering of content 32 therein. As may be appreciated, the receiver 46 upon being so commanded tunes one of the multiple streams of multimedia content 32 from the input signal and forwards same for further processing. In addition, the receiver 46 prior to forwarding the tuned stream of content 32 may if necessary convert such stream 32 from a native format to a format more amenable for such further processing.
As envisioned, each of the multiple streams of multimedia content 32 in the input signal may or may not be encrypted. Upon tuning a particular stream of content 32 within the input signal, then, the receiver 46 decrypts such stream if encrypted and re-encrypts same in a manner that will be set forth in more detail below, or merely encrypts the stream if not encrypted, again in a manner that will be set forth in more detail below. As was alluded to above, the receiver 46 encrypts the stream of content 32 as part of ensuring that the stream is RM-protected. Thus, the stream of content 32 is not available to be redistributed in an unprotected form.
As also shown in
Inasmuch as the stored stream 32 is in the RM-protected form, the media system 48 includes RM components such as the trusted component 38, license evaluator 40, and clock 42 of
As should be understood, though, it may be the case that the first media system 48 can issue a sub-license 36 for the copied stream 32 to the second media system 48, presuming the first media system 48 is in fact capable of doing so and the license 36 so allows. If so, the sub-license 36 as tied to the second media system 48 can in fact be employed by the second media system 48 to render the stream 32.
Still referring to
Payloads in Stream 32 Formed on Intrinsic Partitions
Turning now to
As should be appreciated, with such packets 62, the media system 48 or the like recreates the stream 32 from the packets 62 by essentially reversing the process of packet formation. In essence, then, each sub-stream 32s is re-created by locating the payloads 60 thereof from the packets 62 of the stream 32, decrypting the located payloads 60, and sequentially organizing such decrypted payloads 60. As each sub-stream 32s is re-created, the stream 32 is rendered by rendering each sub-stream 32s in a synchronous manner. As before, re-creating such stream 32 from such packets 62 is known or should be apparent to the relevant public and therefore need not be set forth herein in any detail. Accordingly, any appropriate method of so re-creating such stream 32 from such packets 62 may be employed without departing from the spirit and scope of the present invention.
As was set forth above, each payload 60 from a particular sub-stream 32s has a start boundary and an end boundary, and each sub-stream 32s is composed of a number of sequentially organized digital blocks of information, such as for example, frames of video in a video sub-stream 32s, bytes of text in text sub-stream 32s, etc. As was also set forth above, in the prior art, during formation of the payloads 60, the boundaries of any particular payload 60 were determined rather arbitrarily, and typically based on external factors such as a determined bit-rate for the stream 32. Thus, and for example, it typically was the case that a video sub-stream 32s was divided into payloads 60 such that each of the start boundary and end boundary of each payload 60 was as some point in the middle of a video frame, and not at a partition between video frames.
Again, although such arbitrary boundaries for payloads 60 are not especially troublesome during normal transmission and rendering of a stream 32 by the media system 48 or the like, it is to be appreciated that such arbitrary boundaries can cause considerable difficulty when the stream 32 is to be manipulated, such as for example when a first media system 48 re-transmits the stream 32 to a second media system 48, or when a media system 48 is being operated to perform an operation on each logical block of a sub-stream 32s of the stream 32.
Accordingly, and in one embodiment of the present invention, each payload 60 is not formed from a sub-stream 32s of a stream 32 by defining an arbitrarily bounded portion of the sub-stream 32s and then encrypting the portion to produce the data for the payload 60. Instead, in one embodiment of the present invention, a non-arbitrarily bounded logical block of the sub-stream 32s is defined and encrypted, and the encrypted logical block may then be divided into portions to produce the corresponding data for each of one or more payloads 60. Thus data of the payloads 60 of the logical blocks need not necessarily be decrypted to manipulate such logical blocks, unless of course such manipulation requires the data to be in a decrypted form.
The size and definition of each logical block of a particular sub-stream 32s can be any size and definition without departing from the spirit and scope of the present invention. Significantly, though, each logical block is based on partitions intrinsic to the sub-stream 32s. Again, such intrinsic partitions are specific to the type of content in a sub-stream 32s, and can be the dividers between frames in the case of video, bytes in the case of text, audio samples in the case of audio, etc.
Likewise, the number of payloads 60 produced from a particular encrypted logical block can be any number without departing from the spirit and scope of the present invention. For example, in the case of a text sub-stream 32s with bytes of text, the logical block may be a byte, 50 bytes, 512 bytes, a kilobyte, 10 kilobytes, or the like, and the number of payloads 60 produced from such a logical block can be 1, 10, 40, 128, 1024, or the like. Similarly, in the case of a video sub-stream 32s with frames of video, the logical block may be a frame, a pair of frames, 10 frames, or the like, and the number of payloads 60 produced from such a logical block can be 1, 3, 7, 10, 40, or the like.
Turning now to
At any rate, once a logical block is defined as at step 601, the sub-stream 32s is divided into such logical blocks (step 603), and each logical block is then encrypted (step 605). Thereafter, each encrypted logical block may itself be divided into a number of portions if so desired (step 607). As maybe appreciated, the number of portions that an encrypted logical block is divided into can be any number without departing from the spirit and scope of the present invention, if indeed such division takes place, and may indeed vary from block to block. For example, if it is deemed advisable that each payload 60 should have about 1 kilobyte of data or so and a particular encrypted logical block is about 10 kilobytes, then it may be that such block is divided into 9, 10, or 11 pieces of data.
Once divided, each portion of the encrypted logical block is then incorporated into a payload 60 as the data thereof (step 609). Of course, each payload 60 is then incorporated into a particular packet 62 (step 611), and the packets 62 may then be delivered as part of a stream 32 including the sub-stream 32s (step 613).
To reconstitute a particular sub-stream 32s of the stream 32 from the packets 62, and as should now be appreciated, each payload 60 for the sub-stream 32s is removed from the packets 62 (step 615), and each encrypted logical block portion from the sub-stream 32s is removed from each payload 60 (step 617). The encrypted logical block portions may then be correctly sequenced and combined to form the encrypted logical blocks (step 619), and each such encrypted logical block may then be decrypted as appropriate (step 621). Note that re-constituting a particular sub-stream 32 from packets 62 is known or should be apparent to the relevant public and therefore need not be set forth herein in any detail. Accordingly, any appropriate method of so re-constituting such sub-stream 32 from such packets 62 may be employed without departing from the spirit and scope of the present invention.
Note that it may not always be necessary for a media system 48 or the like to perform all of steps 615-621 when manipulating a stream 32. For example, decrypting as at step 621 may not be necessary, and sequencing and combining the encrypted logical block portions as at step 619 may also not be necessary in all circumstances. Critically, inasmuch as each logical block of a sub-stream 32s is encrypted prior to being (possibly) divided into portions that are formed into payloads 60, such sub-stream 32s may be manipulated by manipulating the encrypted logical block portions thereof, and decryption of such encrypted logical block portions can be avoided in at least some instances.
Architecture for Defining Protection of Multiple Sub-Streams 32s in Stream 32
As was pointed out above, and with regard to a stream 32 of content comprised of multiple sub-streams 32s, it would be advantageous to be able to apply different rights management and protection schemes to each sub-stream 32s of the stream 32. For example, in a stream 32 with a video sub-stream 32s, an audio sub-stream 32s, a text sub-stream 32s, and a metadata sub-stream 32s, it may be advantageous to have the video sub-stream 32s protected by a first scheme and according to a first license 36, to have the audio sub-stream 32s protected by the first scheme but according to a second license 36, to have the text sub-stream 32s protected by a second scheme, and to not have the metadata sub-stream 32s protected by any scheme whatsoever.
Presumably, the mechanics of in fact applying such schemes to the sub-streams 32s of the stream 32 in the manner desired are known or should be apparent to the relevant public and therefore need not be set forth herein in any detail. However, and significantly, an architecture describing the particular application of such schemes to such sub-streams 32s is necessary so that such a description can be provided to an entity such as a media system 48 or the like that is to reconstitute or at least manipulate such sub-streams 32s.
In one embodiment of the present invention, then, and turning now to
In one embodiment of the present invention, the RM description is set forth within the header object 64h as an RM description object 64r. As seen, the RM description object 64r principally includes for each protection scheme employed in connection with the stream 32 a content encryption record 66 describing such protection scheme. Thus, with regard to the aforementioned example where a stream 32 has a video sub-stream 32s protected by a first scheme and according to a first license 36, an audio sub-stream 32s protected by the first scheme but according to a second license 36, a text sub-stream 32s protected by a second scheme, and an unprotected metadata sub-stream 32s, it would be the case that the RM description object 64r for such stream 32 includes a first content encryption record 66 describing the first scheme and a second content encryption record 66 describing the second scheme. Such RM description object 64r might also have a third content encryption record 66 relating to the unprotected metadata sub-stream 32s, although such a third content encryption record 66 is likely unnecessary since such metadata sub-stream 32s is indeed unprotected.
In one embodiment of the present invention, each content encryption record 66 principally includes with regard to the protection scheme thereof an identification of the protection scheme and a number of encrypted object records 68, where each encrypted object record 68 relates to a particular object protected according to the identified protection scheme of the content encryption record 66, such as for example a particular sub-stream 32s, a portion of a particular sub-stream 32s, or the like. Thus, with regard to the aforementioned example where the stream 32 has the video sub-stream 32s protected by the first scheme and according to a first license 36, the audio sub-stream 32s protected by the first scheme but according to a second license 36, the text sub-stream 32s protected by the second scheme, and the unprotected metadata sub-stream 32s, it would be the case that the first content encryption record 66 describing the first scheme would include an identification of the first scheme, a first encrypted object record 68 relating to the video sub-stream 32s as protected by the identified first scheme, and a second encrypted object record 68 relating to the audio sub-stream 32s as protected by the identified first scheme. Likewise, the second content encryption record 66 describing the second scheme would include an identification of the second scheme and only a single encrypted object record 68 relating to the text sub-stream 32s as protected by the identified second scheme.
As seen in
As may now be appreciated, with the architecture set forth in
The programming necessary to effectuate the processes performed in connection with the present invention is relatively straight-forward and should be apparent to the relevant programming public. Accordingly, such programming is not attached hereto. Any particular programming, then, may be employed to effectuate the present invention without departing from the spirit and scope thereof.
In the present invention, a method and mechanism are provided by which payloads 60 from a sub-stream 32s of content are defined according to non-arbitrary boundaries. Thus, the payloads 60 are defined according to rational boundaries that are intrinsic to the underlying sub-stream 32s, and the sub-stream 32s can be manipulated without necessarily requiring the stream 32 to be decrypted and re-encrypted.
Also in the present invention, an architecture is provided that may be employed so that each sub-stream 32s within a stream 32 may be protected according to a particular rights management content protect system and a particular content key (CK). The architecture allows specifying within the stream 32 the particular rights management content protection scheme for each sub-stream 32s of the stream 32 with a header object 64h that is included with the stream 32 and that may be interpreted and employed when rendering the stream 32.
It should be appreciated that changes could be made to the embodiments described above without departing from the inventive concepts thereof. It should be understood, therefore, that this invention is not limited to the particular embodiments disclosed, but it is intended to cover modifications within the spirit and scope of the present invention as defined by the appended claims.
This application is a division of U.S. patent application Ser. No. 11/139,956, (now U.S. Pat. No. 7,684,566), filed May 27, 2005, which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
3718906 | Lightner | Feb 1973 | A |
4255811 | Adler | Mar 1981 | A |
4323921 | Guillou | Apr 1982 | A |
4528643 | Freeny, Jr. | Jul 1985 | A |
4658093 | Hellman | Apr 1987 | A |
4683553 | Mollier | Jul 1987 | A |
4827508 | Shear | May 1989 | A |
4916738 | Chandra et al. | Apr 1990 | A |
4926479 | Goldwasser et al. | May 1990 | A |
4953209 | Ryder, Sr. et al. | Aug 1990 | A |
4977594 | Shear | Dec 1990 | A |
5005170 | Nelson | Apr 1991 | A |
5050213 | Shear | Sep 1991 | A |
5103392 | Mori | Apr 1992 | A |
5103476 | Waite et al. | Apr 1992 | A |
5109413 | Comerford et al. | Apr 1992 | A |
5117457 | Comerford et al. | May 1992 | A |
5193573 | Chronister | Mar 1993 | A |
5222134 | Waite et al. | Jun 1993 | A |
5224166 | Hartman, Jr. | Jun 1993 | A |
5261002 | Perlman et al. | Nov 1993 | A |
5319705 | Halter et al. | Jun 1994 | A |
5410598 | Shear | Apr 1995 | A |
5410698 | Danneels et al. | Apr 1995 | A |
5473692 | Davis | Dec 1995 | A |
5490216 | Richardson, III | Feb 1996 | A |
5506932 | Holmes et al. | Apr 1996 | A |
5509070 | Schull | Apr 1996 | A |
5629980 | Stefik et al. | May 1997 | A |
5634012 | Stefik et al. | May 1997 | A |
5638443 | Stefik et al. | Jun 1997 | A |
5673316 | Auerbach et al. | Sep 1997 | A |
5691768 | Civanlar et al. | Nov 1997 | A |
5710887 | Chelliah et al. | Jan 1998 | A |
5715403 | Stefik | Feb 1998 | A |
5765152 | Erickson | Jun 1998 | A |
5805700 | Nardone et al. | Sep 1998 | A |
5809144 | Sirbu et al. | Sep 1998 | A |
5845281 | Benson et al. | Dec 1998 | A |
5892900 | Ginter et al. | Apr 1999 | A |
5917912 | Ginter et al. | Jun 1999 | A |
5953420 | Matyas, Jr. et al. | Sep 1999 | A |
6073124 | Krishnan et al. | Jun 2000 | A |
6078909 | Knutson | Jun 2000 | A |
6094487 | Butler et al. | Jul 2000 | A |
6094684 | Pallman | Jul 2000 | A |
6133912 | Montero | Oct 2000 | A |
6134243 | Jones et al. | Oct 2000 | A |
6189146 | Misra et al. | Feb 2001 | B1 |
6205140 | Putzolu et al. | Mar 2001 | B1 |
6219652 | Carter et al. | Apr 2001 | B1 |
6226618 | Downs et al. | May 2001 | B1 |
6233567 | Cohen | May 2001 | B1 |
6269368 | Diamond | Jul 2001 | B1 |
6275531 | Li | Aug 2001 | B1 |
6278478 | Ferriere | Aug 2001 | B1 |
6289452 | Arnold et al. | Sep 2001 | B1 |
6330670 | England et al. | Dec 2001 | B1 |
6343280 | Clark | Jan 2002 | B2 |
6456967 | Yeom | Sep 2002 | B1 |
6476802 | Rose et al. | Nov 2002 | B1 |
6512778 | Jones et al. | Jan 2003 | B1 |
6549922 | Srivastava et al. | Apr 2003 | B1 |
6574609 | Downs et al. | Jun 2003 | B1 |
6574612 | Baratti et al. | Jun 2003 | B1 |
6587837 | Spagna et al. | Jul 2003 | B1 |
6609130 | Saulpaugh et al. | Aug 2003 | B1 |
6654389 | Brunherolo et al. | Nov 2003 | B1 |
6681017 | Matias et al. | Jan 2004 | B1 |
6700895 | Kroll | Mar 2004 | B1 |
6742176 | Million et al. | May 2004 | B1 |
6754349 | Arthan | Jun 2004 | B1 |
6757913 | Knox | Jun 2004 | B2 |
6832319 | Bell et al. | Dec 2004 | B1 |
6856997 | Lee et al. | Feb 2005 | B2 |
6885748 | Wang | Apr 2005 | B1 |
6918034 | Sengodan et al. | Jul 2005 | B1 |
6934467 | Herz | Aug 2005 | B1 |
6944296 | Liu et al. | Sep 2005 | B1 |
6961430 | Gaske et al. | Nov 2005 | B1 |
6965646 | Firestone | Nov 2005 | B1 |
6983049 | Wee et al. | Jan 2006 | B2 |
6993137 | Fransdonk | Jan 2006 | B2 |
7010032 | Kikuchi et al. | Mar 2006 | B1 |
7039643 | Sena et al. | May 2006 | B2 |
7065787 | Ganesan et al. | Jun 2006 | B2 |
7080043 | Chase, Jr. et al. | Jul 2006 | B2 |
7093277 | Perlman | Aug 2006 | B2 |
7120250 | Candelore | Oct 2006 | B2 |
7124303 | Candelore et al. | Oct 2006 | B2 |
7136577 | Falco | Nov 2006 | B1 |
7136945 | Gibbs et al. | Nov 2006 | B2 |
7145919 | Krishnarajah et al. | Dec 2006 | B2 |
7174452 | Carr | Feb 2007 | B2 |
7200668 | Mak et al. | Apr 2007 | B2 |
7203316 | Nolte | Apr 2007 | B1 |
7209892 | Galuten et al. | Apr 2007 | B1 |
7231516 | Sparrell et al. | Jun 2007 | B1 |
7242766 | Lyle | Jul 2007 | B1 |
7243366 | Medvinsky et al. | Jul 2007 | B2 |
7257641 | VanBuskirk et al. | Aug 2007 | B1 |
7325139 | Ishiguro et al. | Jan 2008 | B2 |
7336791 | Ishiguro | Feb 2008 | B2 |
7337320 | Tada et al. | Feb 2008 | B2 |
7346160 | Michaelsen | Mar 2008 | B2 |
7350238 | Abe et al. | Mar 2008 | B2 |
7401100 | Jung et al. | Jul 2008 | B2 |
7434052 | Rump | Oct 2008 | B1 |
7437771 | Alkove et al. | Oct 2008 | B2 |
7483532 | Alkove et al. | Jan 2009 | B2 |
7536418 | Buchsbaum et al. | May 2009 | B2 |
7561696 | Oliveira et al. | Jul 2009 | B2 |
7574747 | Oliveira et al. | Aug 2009 | B2 |
7581255 | Alkove et al. | Aug 2009 | B2 |
7634816 | Alkove et al. | Dec 2009 | B2 |
7636738 | Shibata et al. | Dec 2009 | B2 |
7684566 | Oliveira et al. | Mar 2010 | B2 |
7693280 | Evans et al. | Apr 2010 | B2 |
7720096 | Klemets | May 2010 | B2 |
7738778 | Agnihotri et al. | Jun 2010 | B2 |
7769880 | Paka et al. | Aug 2010 | B2 |
7801847 | Kiilerich et al. | Sep 2010 | B2 |
7876896 | Alkove et al. | Jan 2011 | B2 |
7882257 | Kerr et al. | Feb 2011 | B2 |
20010052077 | Fung et al. | Dec 2001 | A1 |
20010052135 | Balakrishnan et al. | Dec 2001 | A1 |
20010056539 | Pavlin et al. | Dec 2001 | A1 |
20020002674 | Grimes et al. | Jan 2002 | A1 |
20020004773 | Xu et al. | Jan 2002 | A1 |
20020013772 | Peinado | Jan 2002 | A1 |
20020082845 | Sato | Jun 2002 | A1 |
20020088136 | Tseng | Jul 2002 | A1 |
20020107806 | Higashi et al. | Aug 2002 | A1 |
20020138619 | Ramaley et al. | Sep 2002 | A1 |
20020152393 | Thoma et al. | Oct 2002 | A1 |
20020157002 | Messerges et al. | Oct 2002 | A1 |
20020164018 | Wee et al. | Nov 2002 | A1 |
20020174135 | Pellegrin et al. | Nov 2002 | A1 |
20020194010 | Bergler et al. | Dec 2002 | A1 |
20020198846 | Lao | Dec 2002 | A1 |
20030001978 | Smith et al. | Jan 2003 | A1 |
20030041257 | Wee et al. | Feb 2003 | A1 |
20030056118 | Troyansky et al. | Mar 2003 | A1 |
20030065918 | Willey | Apr 2003 | A1 |
20030068040 | Wee et al. | Apr 2003 | A1 |
20030070081 | Wee et al. | Apr 2003 | A1 |
20030081592 | Krishnarajah et al. | May 2003 | A1 |
20030081776 | Candelore | May 2003 | A1 |
20030084306 | Abburi et al. | May 2003 | A1 |
20030103243 | Watanabe et al. | Jun 2003 | A1 |
20030126608 | Safadi et al. | Jul 2003 | A1 |
20030131353 | Blom et al. | Jul 2003 | A1 |
20030152223 | Yamada | Aug 2003 | A1 |
20030159140 | Candelore | Aug 2003 | A1 |
20030161473 | Fransdonk | Aug 2003 | A1 |
20030182450 | Ong et al. | Sep 2003 | A1 |
20030185542 | McVeigh et al. | Oct 2003 | A1 |
20030194094 | Lampson et al. | Oct 2003 | A1 |
20030217011 | Peinado et al. | Nov 2003 | A1 |
20040001592 | Akiwumi-Assani et al. | Jan 2004 | A1 |
20040003268 | Bourne et al. | Jan 2004 | A1 |
20040010469 | Lenard et al. | Jan 2004 | A1 |
20040042451 | Takaku | Mar 2004 | A1 |
20040054930 | Walker et al. | Mar 2004 | A1 |
20040064500 | Kolar et al. | Apr 2004 | A1 |
20040078822 | Breen et al. | Apr 2004 | A1 |
20040088557 | Malcolm et al. | May 2004 | A1 |
20040098583 | Weber | May 2004 | A1 |
20040123094 | Sprunk | Jun 2004 | A1 |
20040125757 | Mela et al. | Jul 2004 | A1 |
20040125791 | Hoffman | Jul 2004 | A1 |
20040139336 | McLean et al. | Jul 2004 | A1 |
20040143736 | Cross et al. | Jul 2004 | A1 |
20040170277 | Iwamura et al. | Sep 2004 | A1 |
20040181490 | Gordon et al. | Sep 2004 | A1 |
20040186854 | Choi | Sep 2004 | A1 |
20040193680 | Gibbs et al. | Sep 2004 | A1 |
20040237750 | Smith et al. | Dec 2004 | A1 |
20040242269 | Fadell | Dec 2004 | A1 |
20040249759 | Higashi et al. | Dec 2004 | A1 |
20040249815 | Lee | Dec 2004 | A1 |
20040260786 | Barile | Dec 2004 | A1 |
20050002402 | Fairman | Jan 2005 | A1 |
20050002525 | Alkove et al. | Jan 2005 | A1 |
20050005760 | Hull et al. | Jan 2005 | A1 |
20050008240 | Bamerji et al. | Jan 2005 | A1 |
20050033967 | Morino et al. | Feb 2005 | A1 |
20050069039 | Crinon | Mar 2005 | A1 |
20050071278 | Simelius | Mar 2005 | A1 |
20050099869 | Crinon et al. | May 2005 | A1 |
20050108746 | Futagami et al. | May 2005 | A1 |
20050114664 | Davin | May 2005 | A1 |
20050144470 | Takashima et al. | Jun 2005 | A1 |
20050157727 | Date et al. | Jul 2005 | A1 |
20050163052 | Savage et al. | Jul 2005 | A1 |
20050163093 | Garg et al. | Jul 2005 | A1 |
20050169303 | Toma et al. | Aug 2005 | A1 |
20050169444 | Inon | Aug 2005 | A1 |
20050177875 | Kamperman et al. | Aug 2005 | A1 |
20050187879 | Zigmond et al. | Aug 2005 | A1 |
20050216413 | Murakami | Sep 2005 | A1 |
20050246451 | Silverman et al. | Nov 2005 | A1 |
20050254526 | Wang et al. | Nov 2005 | A1 |
20050265555 | Pippuri | Dec 2005 | A1 |
20050286497 | Zataut et al. | Dec 2005 | A1 |
20050289617 | Safadi et al. | Dec 2005 | A1 |
20060007479 | Henry et al. | Jan 2006 | A1 |
20060020636 | Murotani | Jan 2006 | A1 |
20060031889 | Bennett et al. | Feb 2006 | A1 |
20060069803 | Clark et al. | Mar 2006 | A1 |
20060104356 | Crinon | May 2006 | A1 |
20060123064 | Kim et al. | Jun 2006 | A1 |
20060130104 | Budagavi | Jun 2006 | A1 |
20060161635 | Lamkin et al. | Jul 2006 | A1 |
20060167985 | Albanese et al. | Jul 2006 | A1 |
20060184573 | Koori | Aug 2006 | A1 |
20060184790 | Oliveira et al. | Aug 2006 | A1 |
20060190408 | Cook et al. | Aug 2006 | A1 |
20060227965 | Zhu et al. | Oct 2006 | A1 |
20060242078 | Evans et al. | Oct 2006 | A1 |
20060242079 | Evans et al. | Oct 2006 | A1 |
20060242080 | Van Dyke et al. | Oct 2006 | A1 |
20060262732 | Joutsenvirta et al. | Nov 2006 | A1 |
20060268099 | Potrebic et al. | Nov 2006 | A1 |
20060291475 | Cohen | Dec 2006 | A1 |
20070003064 | Wiseman et al. | Jan 2007 | A1 |
20070016594 | Visharam et al. | Jan 2007 | A1 |
20070016784 | Vauclair | Jan 2007 | A1 |
20070067242 | Lotspiech et al. | Mar 2007 | A1 |
20070073747 | Jung et al. | Mar 2007 | A1 |
20070078898 | Hayashi et al. | Apr 2007 | A1 |
20070088727 | Kindig | Apr 2007 | A1 |
20070104105 | MeLampy et al. | May 2007 | A1 |
20070106814 | Son et al. | May 2007 | A1 |
20070143346 | Matsutani | Jun 2007 | A1 |
20070171903 | Zeng et al. | Jul 2007 | A1 |
20070185909 | Kelin et al. | Aug 2007 | A1 |
20070220024 | Putterman et al. | Sep 2007 | A1 |
20070220048 | Ott | Sep 2007 | A1 |
20070248073 | Pattavina et al. | Oct 2007 | A1 |
20070260615 | Shen | Nov 2007 | A1 |
20070274393 | Toma et al. | Nov 2007 | A1 |
20080046466 | Yun | Feb 2008 | A1 |
20080052751 | Cromarty et al. | Feb 2008 | A1 |
20080075168 | Toma et al. | Mar 2008 | A1 |
20080126812 | Ahmed et al. | May 2008 | A1 |
20080187284 | Ikeda et al. | Aug 2008 | A1 |
20080216116 | Pekonen et al. | Sep 2008 | A1 |
20090070438 | Bartholomew | Mar 2009 | A1 |
20090202079 | Puputti et al. | Aug 2009 | A1 |
20090216776 | Carol et al. | Aug 2009 | A1 |
20100138647 | Oliveira et al. | Jun 2010 | A1 |
Number | Date | Country |
---|---|---|
1498479 | May 2004 | CN |
1643474 | Jul 2005 | CN |
0715246 | Jun 1996 | EP |
0715247 | Jun 1996 | EP |
1041823 | Oct 2000 | EP |
1271830 | Jan 2003 | EP |
1298518 | Apr 2003 | EP |
1175750 | Oct 2003 | EP |
1494425 | Jan 2005 | EP |
H-11-219329 | Aug 1999 | JP |
2000-134193 | May 2000 | JP |
2000-287192 | Oct 2000 | JP |
2001-075871 | Mar 2001 | JP |
2002-044135 | Feb 2002 | JP |
2002-175084 | Jun 2002 | JP |
2002-342518 | Nov 2002 | JP |
2003-124927 | Apr 2003 | JP |
2003-152544 | May 2003 | JP |
2003-224556 | Aug 2003 | JP |
2003-319322 | Nov 2003 | JP |
2004-046833 | Feb 2004 | JP |
2004-158936 | Jun 2004 | JP |
2004-282731 | Oct 2004 | JP |
2004-287937 | Oct 2004 | JP |
2004-328706 | Nov 2004 | JP |
2004-537191 | Dec 2004 | JP |
2005-109861 | Apr 2005 | JP |
2005-513664 | May 2005 | JP |
2001-51534 | Jun 2001 | KR |
1020030011837 | Feb 2003 | KR |
2003-19398 | Mar 2003 | KR |
2003-27066 | Apr 2003 | KR |
2144736 | Jan 2000 | RU |
2159507 | Nov 2000 | RU |
2163745 | Feb 2001 | RU |
2201036 | Mar 2003 | RU |
2003133468 | May 2005 | RU |
536893 | Jun 2003 | TW |
200301635 | Jul 2003 | TW |
WO 9301550 | Jan 1993 | WO |
WO 9613013 | May 1996 | WO |
WO 9624092 | Aug 1996 | WO |
WO 9627155 | Sep 1996 | WO |
WO 9725798 | Jul 1997 | WO |
WO 9743761 | Nov 1997 | WO |
WO 9809209 | Mar 1998 | WO |
WO 9810381 | Mar 1998 | WO |
WO 9821679 | May 1998 | WO |
WO 9824037 | Jun 1998 | WO |
WO 9837481 | Aug 1998 | WO |
WO 0011849 | Mar 2000 | WO |
WO 0015221 | Mar 2000 | WO |
WO 0058811 | Oct 2000 | WO |
WO 0059150 | Oct 2000 | WO |
WO 0116900 | Mar 2001 | WO |
WO 0152021 | Jul 2001 | WO |
WO 0251096 | Jun 2002 | WO |
WO 03028293 | Apr 2003 | WO |
WO 2004006559 | Jan 2004 | WO |
2004014037 | Feb 2004 | WO |
WO 2004023717 | Mar 2004 | WO |
2004030311 | Apr 2004 | WO |
WO 2004030364 | Apr 2004 | WO |
WO 2004097605 | Nov 2004 | WO |
WO 2005027404 | Jan 2005 | WO |
Number | Date | Country | |
---|---|---|---|
20100138647 A1 | Jun 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11139956 | May 2005 | US |
Child | 12702148 | US |