Information is a valuable commodity in today's age of knowledge. Some information is used for educational purposes and other information is intended to be informative, e.g. news, whether and sports information. Yet other information is intended to be used for entertainment, for example audio and video content. In order to protect the individuals and entities that may have copyright interests, information is normally protected through some form of encryption.
In the age of digital information distribution, many copyright owners have unilaterally decided that information protected by encryption mechanisms should only be viewed when the copyright owner so authorizes. This, despite the fact that a licensee has paid good and valuable consideration for the right to utilize or otherwise enjoy the content.
One major problem with this convention for distributing information can be readily seen in the realm of audio and video distribution. Such audio and video is often referred to as “content”. Up until very recently, audio and video content was customarily distributed to a licensee on magnetic tape. Magnetic tape was not the most ideal media because the quality of analog and video information was usually compromised through the analog encoding used to store the content on the medium. Magnetic tape, though, had one major advantage—it was extremely durable.
Audio and video content is now distributed in digital form using optical medium—e.g. compact disk (CD) and digital versatile disk (DVD), respectively. The quality of the information imparted onto optical medium is so high that copyright owners have resorted to encryption as a means of deterring unauthorized, high-quality reproduction of the content. This unauthorized distribution is known in many parts of the world as “piracy”.
Legitimate licensees are unable to reproduce the content even for proper purposes, for example backups. This is a very frustrating situation because the optical medium used to distribute encrypted content is exceptionally susceptible to damage. Optical medium can be scratched to the point that the content stored thereon can no longer be retrieved. In this situation, the licensee has no choice but to conform with a copyright holders restrictions and purchase the content again and again every time the medium is damaged.
No doubt that the copyright holder has the right to sell a license under any terms. Optical medium is cheaper to produce than its analog tape predecessor. Optical medium, however, is less durable than analog tape (e.g. VHS video tape). When optical medium is damaged, it forces the consumer to pay for new medium even though that consumer is already authorized to enjoy the content. Because there is simply no bargaining power on the part of the licensee, such contractual terms are adhesive in nature. The fact that the contract is adhesive and the medium so fragile results in a complete and unconscionable windfall for the copyright owner.
Presently disclosed is a method, apparatus and software for capturing decrypted information by receiving such decrypted information in a presentation device and then directing the decrypted information to a computer readable medium.
Several alternative embodiments will hereinafter be described in conjunction with the appended drawings and figures, wherein like numerals denote like elements, and in which:
The present method may be applied in a situation where encrypted content is received by an authorized content player. In one example use scenario, an authorized content player decrypts the information prior to directing the decrypted information to a presentation device. The presentation device is then able to receive the decrypted information according to the present method. An authorized content player can include, but is not necessary limited to a software program executed on a computer platform. For example, such a software program may be executed in a personal computer or some dedicated computing platform. One example of a dedicated computing platform includes a set-top box used to receive content from a distribution system prior to presentation to a user. Such set-top boxes are often used in cable television systems and direct broadcast satellite television systems.
An authorized content player can interact either directly with a presentation device or through a presentation device driver. An authorized content player or a presentation device driver may seek certification from the presentation device prior to delivering decrypted information to the presentation device. In order to function properly, one alternative method provides that reception of decrypted content is to be accomplished by providing such certification to an executing process (e.g. an authorized content player or a presentation device driver) and then receiving decrypted content from the executing process. According to one variation of the present method, an executing process does not require certification per se, but finds an implied certification by recognizing a certain hardware profile known to be associated with an authorized presentation device. Accordingly, one variation of the present method provide for receiving decrypted content by interaction with an executing process in a pre-defined manner that implies certification as an authorized presentation device. It should be noted that the present method may be utilized in many different applications and the scope of the claims appended hereto is not intended to be limited to any particular application herein described.
According to one alternative example method, the decrypted information is received in a presentation device in a compressed form (step 25), e.g. a compressed content stream. According to yet another alternative example method, a compressed content stream is received in a form that includes at least one of a display frame and an update frame. A display frame is a frame of information that depicts a complete presentation frame. An update frame is a collection of information that may be used to update a previously received display frame. Accordingly, once a display frame is received, it can be amended according to one or more subsequently received update frames.
According to one variation of this method, information is received in a format that is compatible with the Moving Pictures Expert Group (MPEG) video compression standard (e.g. MPEG-I, MPEG-II or MPEG IV). It should be noted that the MPEG standard is constantly evolving and the scope of the appended claims is intended to include all such natural evolutionary revisions of the MPEG video compression standard. The MPEG video compression standard provides for compression of video information through the use of initial frame data. Initial frame data, according to the MPEG standard, comprises an I-Frame. An I-Frame may be updated on a periodic basis using update frames. According to the MPEG standard, an update frame can include a B-Frame and a P-Frame. It should be noted that the present method and any and all variations thereof may be applied in situations were content is received in other forms. Accordingly, the scope of the claims appended hereto is not intended to be limited to any particular compression format (e.g. MPEG) which may be suitable for compressing audio or video content. Accordingly, the scope of the appended claims is to included any content stream that initializes a frame and then subsequently updates the frame.
According to one variation of this method, an update to the instruction sequence completely supplants an existing instruction sequence (e.g. an instruction sequence ordinarily supplied with a hardware component such as a display adapter). According to yet another variation of this method, the update to the instruction sequence supplants only a portion of an existing instruction sequence. According to yet another alternative variation of this method, an update to the instruction sequence augments an existing instruction sequence, wherein the existing instruction sequence provides the ability to call upon such a “plug-in” instruction sequences. For example, an execution unit in a hardware component may recognize a trap facility that provides basic addressing for subroutines in an existing instruction sequence. The trap facility can be altered so as to cause the execution unit to call upon a subroutine included in the update that augments the existing instruction sequence. According to one illustrative use case, the present method may be utilized to supplant an instruction sequence known as a “pixel-shader”. A pixel-shader is an instruction sequence ordinarily included, for example, in a display adapter capable of converting a compressed content stream into a presentable representation of the content stream, for example in the form of pixels or pixel clusters. In at least one alternative method, the update to the instruction sequence results in a pipelined processing of a content stream. Such pipelined processing results in placing of the content stream as compressed information in a memory. In yet another example method, such pipelined processing results in decoding (i.e. decompressing) of the content stream resulting in a presentable representation thereof stored in a memory.
In an embodiment where the information port 205 is configured to receive a presentable representation of the decrypted content, a presentation unit 210 included in an apparatus for capturing decrypted information converts the presentable representation into a presentation signal 215. The presentation signal 215, according to one alternative embodiment, comprises at least one of a composite video signal, red-green-blue (RGB) monitor drive signals and digital video interface (DVI) signals used to drive a digital display device (e.g. a liquid crystal display device). According to yet another variation of the present method, the presentation signal comprises an analog audio signal. It should be noted that the claims appended hereto are not intended to be limited to any particular type of presentation signal generated by the presentation unit 210.
According to yet another alternative embodiment, the information port 205 included in an apparatus for capturing decrypted information is configured to receive a compressed content stream. According to this alternative embodiment, some external process decrypts information and makes the decrypted information available on the system bus 200 as a compressed content stream. Generally, this external process makes information available on the system bus 200 for the purpose of directing decrypted content to a presentation device. The information port 205 directs 221 the compressed content stream to the capture unit 225. According to one alternative embodiment, the compressed content stream includes at least one of a display frame and an update frame. Accordingly, the capture unit 225 of this alternative embodiment directs 230 at least one of a display frame and an update frame to computer readable medium 250.
According to yet another alternative embodiment, a compressed content stream is directed to the presentation unit 210. The presentation unit 210 generates a presentable representation 220 of decrypted content according to the compressed content stream. The presentable representation 220 is directed to the capture unit 225. The capture unit 225 directs 230 the presentable representation to the system bus 200 from whence it is directed 240 to the computer readable medium 240.
A modern presentation device, for example a display adapter used in a personal computer or any specialized hardware apparatus such as a set-top-box, typically includes some form of an execution unit 335. In the present apparatus, the execution unit 335 can be configured as a specialized coprocessor by one or more functional modules (i.e. instruction sequences) stored in the instruction memory 360. For example, a functional module for decoding a compressed content stream can be stored in the instruction memory 360. Such a functional module is often referred to as a decode module 380. Another example of a functional module that can be used to configure the present apparatus includes a pixel shader sequence, a.k.a. a pixel shader module 390. A pixel shader module 390 configures the execution unit 335 as a pixel shading coprocessor. The present apparatus can be enabled with various types of instruction sequences that are used in conjunction with each other to configure the execution unit as a highly specialized coprocessor. For example, the execution unit 335 can be used to execute a decode module 380 for the purposes of decoding a compressed content stream. Once the compressed content stream is decoded, the execution unit 335 can be made to execute a pixel shader module 390 for the purpose of generating a blended pixel image according to the decompressed content stream. It should be understood that the execution unit 335 in the present apparatus can be configured for any number of specialized purposes and the claims appended hereto are not intended to be limited in scope by any examples described thus far.
According to one example embodiment, the execution unit 335 executes instructions stored in the instruction memory 360. The host port 322, according to one alternative embodiment, enables a system bus to store instruction sequences in the instruction memory 360. The host port 322, according to yet another example embodiment, allows the system bus to communicate decrypted information directly to the execution unit 335. According to yet another example embodiment, the execution unit 335 generates a notification signal (NOTIFY 355) that can be used to notify a host system upon completion of a particular task or process. Typically, the NOTIFY signal 355 is used to interrupt a processor in the host system. Upon such interruption, the processor in the host system executes an interrupt service routine. The interrupt service routine, when executed by the processor in the host system, minimally causes the processor in the host system to service the presentation device in some manner. Again, a presentation device can include a device that emulates a presentation device (e.g. a device that emulates a graphics adapter).
According to yet another alternative embodiment, the host port 322 enables the execution unit 355 to communicate with computer readable medium included in the host system. For example, one alternative embodiment of a host port 322 includes a direct memory access mechanism that enables the execution unit 335 to store and retrieve information from a system memory included in the host system. In yet another alternative embodiment, the direct memory access mechanism enables the execution unit 335 to store and retrieve information from other computer readable medium included in the host system. For example, such other computer readable medium can include, but is not limited to random access memory, read-only memory (ROM), compact disk ROM (CD ROM), Digital Versatile Disks (DVD), floppy disks, hard disk drives and magnetic tape. It is intended that the scope of the claims appended hereto not be limited to any particular example of computer readable medium herein described.
According to one alternative embodiment, an apparatus for capturing decrypted information further comprises a video random access memory (RAM) 325. According to yet another example embodiment, an apparatus for capturing decrypted information further comprises a signal generator 345. According to this alternative embodiment, the execution unit 335 stores a video image (e.g. the form of pixels) in the video RAM 325. When provided, the signal generator 345 generates a video signal 315 according to a video image stored in the video RAM 325. The video signal 350, according to one exemplary embodiment, includes, but is not limited to at least one of a composite video signal, separate drive signals for red-green-blue colors and a digital video interface (DVI) signal capable of driving a digital display device (e.g. a liquid crystal display). It should be noted that the host port 322 in this alternative embodiment enables a host system to access the video RAM 325.
The decrypted information, according to one of alternative embodiment, comprises a presentable representation of decrypted information. According to this alternative embodiment, the capture module 370, when executed by the execution unit 335, further minimally causes the execution unit 335 to direct 405 the presentable representation of decrypted information to the host port 322. According to one variation of this alternative embodiment, the host port 322 directs the presentable representation of decrypted information to the system bus from whence it may be directed to computer readable medium.
According to yet another alternative embodiment, the decrypted information comprises a compressed content stream. According to this alternative embodiment, the capture module 370, when executed by the execution unit 335, further minimally causes the execution unit 335 to direct 405 the compressed content stream to the host port 322. In a further variation of this alternative embodiment, the compressed content stream includes at least one of a display frame and an update frame. Accordingly, when executed by the execution unit 335, a variation of the capture module 370 minimally causes the execution unit 335 to direct at least one of a display frame and an update frame to the host port 322. The compressed content stream, which according to at least one alternative embodiment comprises at least one of a display frame and an update frame, is directed by the host port 322 to the system bus from whence it may be directed to computer readable medium.
According to one alternative embodiment, decrypted information directed to the system bus needs to be directed to computer readable medium with support from a system processor. In such case, the capture module 370 further minimally causes the execution unit 335 to generate a NOTIFY signal 355. The NOTIFY signal 355 is used to signal a system processor (e.g. by means of an interrupt) that the host port 322 needs to be serviced. Such service typically includes operation by the system processor to retrieve decrypted information from the host port and storage of the decrypted information, e.g. by directing the decrypted information to computer readable medium. It should be noted that, according to this alternative embodiment, the capture module 370 does not cause the execution unit 335 to interact with a video RAM 325. Accordingly, the signal generator 345 does not generate a video signal 350.
In yet another embodiment, the decode module 380 further minimally causes the execution unit 335 to decode the compressed content stream into a presentable representation (e.g. partially formed pixels). The execution unit 335 further minimally directs 455 the presentable representation to the pixel shader module 390. The pixel shader module, when executed by the execution unit 355, minimally causes the execution unit 335 to generate and store 465 in the video RAM 325 one or more pixels that are used as a basis for a video output 350 generated by the signal generator 345.
This alterative example embodiment comprises various functional modules each of which comprises an instruction sequence that can be executed by the one or more processors 500 or by the execution unit 555 included in the display adapter 550. For purposes of this disclosure, a functional module and its corresponding instruction sequence is referred to by a process name. The instruction sequence that implements the process name, according to one alternative embodiment, is stored either in the memory 501 or the instruction memory 570. The reader is advised that the term “minimally causes the processor” and variants thereof is intended to serve as an open-ended enumeration of functions performed by the processor 500 (or the execution unit 555 in the display adapter 550) as it executes a particular functional process (i.e. instruction sequence). As such, an embodiment where a particular functional process causes the processor (or the execution unit 555 in the display adapter 550) to perform functions in addition to those defined in the appended claims is to be included in the scope of the claims appended hereto.
Stored in the memory are one or more instruction sequences including, but not limited to a reception manager 505 and an authorized player 510. The instruction sequences stored in the display adapter's 550 instruction memory 570 include, but are not limited to a capture module 575. In one alternative embodiment, the instruction memory 570 has stored therein a pixel shader module 590. In yet another alternative embodiment, the instruction memory 570 has stored therein a decode module 580.
According to yet another alternative embodiment, the system further comprises a capture utility module 520 stored in the memory 501. In yet another alternative embodiment, the system comprises an encode module 522. And, according to yet another alternative embodiment, the system further comprises an audio decompression module 515 stored in the memory 501 and an audio converter 600. The audio decompression module 515, when executed by the host processor 500, minimally causes the host processor 500 to convert a compressed audio content stream into a decompressed audio content stream. The decompressed audio content stream is directed to the audio converter 600, which converts a series of digital values included in the decompressed audio content stream into an audio presentation signal 605.
The authorized player 510, when executed by the processor 500, minimally causes the processor 500 to decrypt the encrypted information and direct the decrypted information to at least one of the display adapter 550 and an audio decompression module 515, also included in one alternative embodiment of a system for capturing decrypted information. When the decrypted information is received in the display adapter 550, the execution unit 555 captures the decrypted content by directing the content to the computer readable medium 525. The decrypted audio information is typically in a compressed form. Accordingly, the processor 500, as it executes the decompression module 515, minimally decompresses the audio information and directs the decompressed audio information to the audio converter 600 as a series of digital values. The audio converter 600 generates a presentation signal 605 according to series of digital values.
According to one alternative embodiment, the capture module 575, when executed by the execution unit 555, minimally causes the execution unit 555 to receive decrypted video content from the authorized player 510. According to one alternative example embodiment, the capture module 575 minimally causes the execution unit 555 to interact with the authorized player 510 in a manner wherein the authorized player 510 perceives the capture module 575 to be an authorized recipient of decrypted content. According to one alternative embodiment, this is accomplished by providing explicit certification to the authorized player 510. According to yet another alternative embodiment, this is accomplished by providing implicit certification to the authorized player (e.g. by emulating an authorized display adapter at a hardware level). The capture module 575 further minimally causes the execution unit 555 to direct the decrypted video content to the capture utility 520.
According to one example alternative embodiment, the capture module 575 captures decrypted video information in the form of a compressed content stream from at least one of the authorized player 510 or from the decode module 580. A compressed content stream, according to one alternative embodiment, is captured in a form that includes at least one of a display frame and an update frame. According to yet another alternative embodiment, the compressed content stream is captured in a format compatible with the MPEG standard. In either case, the capture module 575 further minimally causes the execution unit 555 to direct the compressed content stream to the capture utility 520. The capture utility 520, when executed by the processor 500, minimally causes the processor 500 to direct the compressed content stream to computer readable medium 525.
According to one alternative embodiment, the decode module 580, when executed by the execution unit 555, minimally causes the execution unit 555 to generate a presentable representation according to the decrypted video information and to direct the presentable representation to the pixel shader module 590. The pixel shader module 590, when executed by the execution unit 555, minimally causes the execution unit 555 to generate one or more pixels. According to one alternative embodiment, the capture module 575, when executed by the execution unit 555, minimally causes the execution unit 555 to receive the pixel data directly from the pixel shader module 590. According to yet another alternative embodiment, the capture module 575 minimally causes the execution unit 555 to receive the pixel data from the display memory 560 after the pixel shader module 590 causes the execution unit 555 to store one or more generated pixels therein. In either case, the capture module 575 further minimally causes the execution unit 555 to direct the pixel data to the capture utility 520.
According to one alternative example embodiment, the capture utility 520, when executed by the processor 500, minimally causes the processor 500 to direct the pixel data to the computer readable medium 525. According to one alternative embodiment, the processor 500 further executes the encode module 522. Accordingly, the encode module 522, when executed by the processor 500,minimally causes the processor 500 to retrieve pixel data from the computer readable medium 525, generate a compressed content stream according to the retrieved pixel data and then direct the compressed content stream back to the computer readable medium 525. In accordance with the teachings provided herein, the compressed content stream can be in a form that includes at least one of a display frame and an update frame. For example, according to one alternative embodiment of the encode module 522, the encode module 522 minimally causes the processor 500 to generate a compressed content stream that is compatible with the MPEG standard (e.g. MPEG I, MPEG II and MPEG IV).
The functional processes (and their corresponding instruction sequences) described thus far that enable the capture of decrypted information are, according to one alternative embodiment, imparted onto computer readable medium. Examples of such medium include, but are not limited to, random access memory, read-only memory (ROM), CD ROM, floppy disks, hard disk drives and magnetic tape. Another example of a computer readable medium is a computer network. In this case, the computer network can be used to convey an instruction sequence to a computer. A computer network can include a serial data interface, a parallel data interface or a computer network such as an 802.11 interface. This enumeration of computer networks is intended to illustrate, but not limit the scope of the claims appended hereto. This computer readable medium, which alone or in combination can constitute a stand-alone product, can be used to convert at least one of a general-purpose computing platform and a display presentation device into a device for capturing decrypted information according to the techniques and teachings presented herein. Accordingly, the claims appended hereto are to include such computer readable medium imparted with such instruction sequences that enable execution of the present method and all of the teachings herein described.
While the present method, hardware, software and system have been described in terms of several alternative embodiments, it is contemplated that alternatives, modifications, permutations, and equivalents thereof will become apparent to those skilled in the art upon a reading of the specification and study of the drawings. It is therefore intended that the true spirit and scope of the appended claims include all such alternatives, modifications, permutations, and equivalents.