GB2500614A - Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets - Google Patents

Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets Download PDF

Info

Publication number
GB2500614A
GB2500614A GB1205294.0A GB201205294A GB2500614A GB 2500614 A GB2500614 A GB 2500614A GB 201205294 A GB201205294 A GB 201205294A GB 2500614 A GB2500614 A GB 2500614A
Authority
GB
United Kingdom
Prior art keywords
data
programme
packets
stream
packetized data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Withdrawn
Application number
GB1205294.0A
Other versions
GB201205294D0 (en
Inventor
Paul Szucs
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Corp
Original Assignee
Sony Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sony Corp filed Critical Sony Corp
Priority to GB1205294.0A priority Critical patent/GB2500614A/en
Publication of GB201205294D0 publication Critical patent/GB201205294D0/en
Priority to PCT/EP2013/055858 priority patent/WO2013143951A1/en
Publication of GB2500614A publication Critical patent/GB2500614A/en
Withdrawn legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • H04N21/4405Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs involving video stream decryption
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/434Disassembling of a multiplex stream, e.g. demultiplexing audio and video streams, extraction of additional data from a video stream; Remultiplexing of multiplex streams; Extraction or processing of SI; Disassembling of packetised elementary stream
    • H04N21/4343Extraction or processing of packetized elementary streams [PES]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/418External card to be used in combination with the client device, e.g. for conditional access
    • H04N21/4181External card to be used in combination with the client device, e.g. for conditional access for conditional access
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/426Internal components of the client ; Characteristics thereof
    • H04N21/42607Internal components of the client ; Characteristics thereof for processing the incoming bitstream
    • H04N21/4263Internal components of the client ; Characteristics thereof for processing the incoming bitstream involving specific tuning arrangements, e.g. two tuners
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/434Disassembling of a multiplex stream, e.g. demultiplexing audio and video streams, extraction of additional data from a video stream; Remultiplexing of multiplex streams; Extraction or processing of SI; Disassembling of packetised elementary stream
    • H04N21/4344Remultiplexing of multiplex streams, e.g. by modifying time stamps or remapping the packet identifiers
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/434Disassembling of a multiplex stream, e.g. demultiplexing audio and video streams, extraction of additional data from a video stream; Remultiplexing of multiplex streams; Extraction or processing of SI; Disassembling of packetised elementary stream
    • H04N21/4345Extraction or processing of SI, e.g. extracting service information from an MPEG stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/435Processing of additional data, e.g. decrypting of additional data, reconstructing software from modules extracted from the transport stream
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/436Interfacing a local distribution network, e.g. communicating with another STB or one or more peripheral devices inside the home
    • H04N21/43607Interfacing a plurality of external cards, e.g. through a DVB Common Interface [DVB-CI]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/43Processing of content or additional data, e.g. demultiplexing additional data from a digital video stream; Elementary client operations, e.g. monitoring of home network or synchronising decoder's clock; Client middleware
    • H04N21/44Processing of video elementary streams, e.g. splicing a video clip retrieved from local storage with an incoming video stream or rendering scenes according to encoded video stream scene graphs
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/45Management operations performed by the client for facilitating the reception of or the interaction with the content or administrating data related to the end-user or to the client device itself, e.g. learning user preferences for recommending movies, resolving scheduling conflicts
    • H04N21/462Content or additional data management, e.g. creating a master electronic program guide from data received from the Internet and a Head-end, controlling the complexity of a video stream by scaling the resolution or bit-rate based on the client capabilities

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Databases & Information Systems (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

A method of operating an audio/video (AV) content receiver (e.g. set-top box (STB)) having a decoder for an audio/video programme from a packetized data stream, using data packets defining decryption information, comprises: receiving encoded content as packetized data streams comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers (PIDs) and identification data mapping programmes to respective sets of packet identifiers; selecting data packets from the stream for each required programme according to the set of packet identifiers defined by the identification data for that stream in respect of the required programme; selecting further, additional data packets from each packetized data stream from which a programme is selected which contain programme clock reference (PCR) data relating to the selected programme, in the case that programme clock reference (PCR) data is not included in the packets relating to the selected programme; generating a composite packetized data stream from selected packets; generating composite stream identification data defining the packet identifiers of data packets in the composite packetized data stream; and supplying the composite packetized data stream for decoding according to the PCR and packet identifiers in the composite stream identification data.

Description

RECEIVING AUDIO/VIDEO CONTENT This invention relates to receiving audio/video content.
As background technology, the DVB Common Interface ("Cl") specification allowed a television receiver or set top box (a "host") to interact with a secure hardware module (a conditional access module or "CAM") to allow the host to decrypt access-controlled content.
The Cl specification defines an interface between the host and the CAM, so that the two will work together if both conform to the Cl specification. This interoperability provided a significant benefit of the Cl system, as, in principle, it allowed consumers a choice of compatible products from different manufacturers.
In the Cl specification the CAM interacts with a smart card and/or a user's personal identification number (FIN") to provide user authentication.
However, a disadvantage of the original Cl specification is that it gave the potential for the decrypted digital content to be copied. This problem arises from the way in which the host and CAM interact. In use, the host sends encrypted data to the CAM. The CAM checks the user authentication and, assuming that the user is authenticated, it decrypts the access- controlled content. The CAM then sends the decrypted content back to the host over the CAM-host interface, which is generally a PCMCIA (Personal Computer Memory Card International Association) interface, though it is not limited to this interface -for example, a USB interface could be used. This connection from the CAM to the host represents a security weakness, in that the decrypted digital content can in principle be intercepted and unlawfully copied. This security weakness meant that some content providers preferred integrated devices, which have the host and CAM as a single unit, because this allowed them better security over the transfer of unencrypted data from the CAM to the host. However, this of course acted against the advantage associated with Cl, relating to the potential interoperability of different CAMs and hosts.
The Cl Plus specification was drafted to address these problems, by two main routes.
Cl Plus provides a secure interface between the CAM and the host, so that decrypted content data is not sent in clear form between the two devices. Also, Cl Plus provides for the authentication of both the host and the CAM, rather than the Cl technique of authenticating only the CAM.
The authentication system uses certificate hierarchy so that the host and the CAM must both have been issued certificates by an authority (such as Cl Plus LLP).
The PCMCIA interface between a host and a CAM is protected by encrypting the decrypted content data before it is sent from the CAM to the host, and then decrypting it at the host. This encryption is separate to the access control encryption-decryption established by the content provider, and is specific to each particular CAM-host pair. Keys are exchanged between the CAM and host by the Diffie-Heliman key exchange technique. The keys are also cycled from time to time, so that even if a key was compromised, it would in any event be changed a few seconds later.
The Cl Plus specification also allows CAMs to be connected in series, or daisychained.
This invention provides an arrangement as defined in claim 1.
Various further respective aspects and features of the invention are defined in the appended claims.
Embodiments of the invention will now be described, by way of example only, with reference to the accompanying drawings, in which: Figure 1 is a schematic diagram of a host device with a CAM and a smart card; Figure 2 is a schematic diagram of a conditional access (CA) system incorporating the host device of Figure 1; Figure 3 is a schematic diagram illustrating the operation of the system of Figure 2; Figure 4 is a schematic diagram of the host device having multiple tuners; Figure 5 schematically illustrates a multiplexer-demultiplexer arrangement; Figure 6a schematically illustrates a so-called M card; Figure 6b schematically illustrates a so-called S card; Figure 7 schematically illustrates a transport stream (IS) packet; Figure 8 schematically illustrates a data packet of a composite packetized data stream; Figure 9 schematically illustrates a multiplexer arrangement in more detail; Figure 10 schematically illustrates TS packets of two services; Figure 11 schematically illustrates a set comprising a succession of CAMs; Figure 12 schematically illustrates a succession of CAMs with interface units between them; Figure 13 is a schematic flowchart illustrating the handling of so-called ghost PIDs; Figure 14 schematically illustrates a PID mapping table; Figure 15 schematically illustrates operations involved in detecting which CAM of a succession of CAMs is capable of decoding the required programme service; Figure 16 schematically illustrates control of multiple tuners by the host device; Figure 17 schematically illustrates the multiplexing of two separate programme services; Figure 18 schematically illustrates a packet having an augmented packet header; Figure 19 schematically illustrates a packet timing data table; Figure 20 schematically illustrates the generation of the packet header of Figure 18; Figure 21 schematically illustrates the use of the packet header of Figure 18; Figure 22 schematically illustrates the generation of the table of Figure 19; Figure 23 schematically illustrates the use of the table of Figure 19; and Figure 24 schematically illustrates an SDT signature and signature checking system.
To establish the technical context of the present embodiments, a broadcast system having a single tuner and decoder arrangement will first be described with reference to Figures 1 to3.
Referring now to Figure 1, a host device 10 is shown here as a television set but could be, for example, a set top box (noting that the expression set top" does not imply, to the skilled person, any requirement for a particular physical position of the device in use). The host device receives an access-controlled television signal 15 via a broadcast data path. This could be, for example, a satellite television signal received by a satellite dish (not shown), a terrestrial television signal, a cable television signal or the like, although other types of television signal include a television signal broadcast or transmitted by an internet protocol (IP) packet signal.
One technique is to encode an MPEG transport stream (IS) into IP packets so that an IP packet carries a number (for example 7 Di 8) TS packets. Another technique encodes the television signal as a so-called ISO (International Standards Organisation) BMFF (Base Media File Format) arrangement described in the reference: http://en.wikipedia.org/wiki/lSO_base_media_tile_format, the contents of which are incorporated into the present description by reference. In such arrangements the IP interface at a host device is generally considered within the art as a "tuner" even though it may have no radio frequency circuitry or functionality. It does however act in a similar way to a radio frequency tuner in that it selects an IP stream from a multitude of possible IP streams. It may also provide buffering of the received IP stream.
The host device 10 has a PCMCIA slot 20 which includes electrical connections and a physical space for a plug-in module, both according to the PCMCIA standard. In other embodiments, a universal serial bus (USB) or other electrical interface can be used instead of the PCMCIA interface.
A Cl Plus conditional access module, referred to as a CICAM 30, is a PCMCIA module which can be plugged into the PCMCIA slot 20. When the CICAM 30 is fully plugged into the slot 20, electrical connections are made between connectors on the CICAM 30 and cooperating connectors within the slot 20.
The CICAM itself may be a cardless module or may have a slot 40 into which a so-called smart card 50 may be inserted. The smart card is removable and carries information defining a current user of the content receiver in a tamper-proof, secure and non-volatile form.
When the smart card is fully inserted in the slot 40, a data connection is formed between the smart card 50 and the CICAM 30, either by using cooperating electrical connectors on the smart card 50 and within the slot 40, or by using a known contactless connection technique in which data is transferied wirelessly over a very shoit range such as 1-2 cm.
Figure 2 schematically illustrates the host device 10 in the context of a conditional access system. A so-called head end 60 represents the source of the access-controlled television signal 15. The head end may represent, for example, an uplink station of a satellite broadcaster or a signal distribution centre of a terrestrial or cable broadcaster. The CA system scrambles content at the head end using a CA system encryption. The head end can also introduce other CA-related information into the encrypted data stream which enables the CICAM to descramble the content and to manage the subscriber's (user's) access and entitlements.
The head end 60 sends the television signal 15 to the host 10 which in turn passes the signal to the CICAM 30 for decryption of the access control encryption. The CICAM 30 then re-encrypts the signal using a local encryption and sends the re-encrypted signal back to the host 10 via the PCMCIA connection. The host decrypts the signal received from the CICAM 30 for display on a display screen or for supply to another device 70 such as a hard disk based video recorder.
Figure 3 is a schematic diagram illustrating the operation of the system of Figure 2. The detailed operation of the system of Figure 3 is described in the Cl Plus Specification 1.3 (2010- 01), available (at the time of filing) at http:Jlwww.ci-plus.com/data/ci-plus_specification_vl.3.pdf.
This document is incorporated by reference into the present description. The present description of Figure 3 simply provides an overview of that detailed operation, for the purposes of placing the subsequent description into the appropriate technical context.
As before, Figure 3 shows the head end 60 (which receives a content signal from a content provider 90), the host device 10, the CICAM 30 and the smart card 50. The signal 15 is shown passing from the head end 60 to the host device 10. The secure interface 80 between the host device 10 and the CICAM 30 is referred to as the common interface.
Conditional Access Known CA systems provide techniques by which a user can be denied or allowed access to a digital television stream. Access is provided only to those subscribers or users with valid payment accounts. In practical terms, a user is provided with a smart card 50 identifying that user in (ideally) a tamper-free way, and the system is set up so that only users with valid smart cards are able to obtain access to the access-controlled content.
Access control is provided by the use of scrambling and encryption. The content signal is scrambled with an 8-byte control word, which is changed frequently (up to several times per minute) to avoid the CA system being compromised by outside knowledge of the control word.
The control words are transmitted to the receiver's CICAM, for descrambling of the scrambled content, in an encrypted form as an entitlement control message (ECM). The CICAM decrypts the control word to allow descrambling of the access-controlled content only when it is authorised to do so by receipt of an entitlement management message (EMM). EMMs are specific to each user or group of users; the CICAM confirms the rights which an EMM provides by comparing the user identification provided in the EMM with user information provided in the smart card 50. The EMMs can be sent less frequently than the ECMs, with intervals between successive EMMs in current commercial systems varying between 12 minutes and six weeks.
ECMs and EMMs themselves are well known message types in MPEG television distribution systems. The format of their payloads can be specific to the CA system in use, with the differences between formats often being semantic rather than having technical significance.
Head End The head end 60 comprises a CA encryptor 61, a key generator 62, an entitlement control unit 63 and a multiplexer and modulator 64.
The content provider 90 supplies content (such as television signals) to the head end 60. The head end 60 applies conditional access (CA) sciambling and enclyption to the content.
More specifically, the CA encryptor 61 encrypts or scrambles the content using a CA key as a control word. The CA key is generated by the CA key generator 62. The scrambled content generated by the CA encryptor is supplied to the multiplexer and modulator 64.
The CA key is also provided to the entitlement control unit 63, which generates ECMs based on the CA keys and EMM5 based on subscriber data defining which subscribers are entitled to descramble which content streams. The ECMs and EMMs are supplied to the multiplexer and modulator 64. One or more scrambled content streams from the CA encryptor 61, one or more unscrambled (open access or "ree to air") content streams and the entitlement control messages are multiplexed together to form a transport stream such as an MPEG2 transport stream. Known formats are used to carry the content data, the ECMs and the EMMs.
The ECMs, EMMs and data defining the type of scrambling used on each elementary stream (corresponding to individual scrambled content streams) are provided in a known format and are referenced using known techniques in a programme map table (PMT and/or in a conditional access table (CAT) which has a predetermined programme identifier (PlO) of OxOOl, so that the CAT can be recognised at the CICAM.
The multiplexed transport stream is then modulated by the multiplexer and modulator 64 for transmission as a cable, satellite or terrestrial broadcast signal 15.
Host Device The host device 10 comprises a tuner 11, a demodulator and demultiplexer 12, a demultiplexer ("demux") 13 and a CC (content control) decryptor 14. Note that the host device may have other additional functions; for example, a host device may provide two or more of satellite broadcast leception, cable broadcast leception, terrestiial broadcast reception and network (IPTV) television reception.
Depending on the type of broadcast signal 15, the tuner acts to transform the received signal back to baseband, so that the demodulator and demultiplexer 12 can select and demultiplex a single elementary content stream and associated CAT data from the received signal. The content stream and ECM / EMM data are passed via the common interface 80 to theCICAM3O.
In the case of access-controlled content data, at this stage the content data is still scrambled as it is passed via the common interface 80 to the CICAM 30. This part of the transmission over the common interface 80 is therefore secure by virtue of the CA encryption.
Assuming the ECM and EMM allow it, the CICAM 30 descrambles the content data and re-encrypts it using a content control (CC) encryption. The way in which this is done will be described below. The CC encrypted data is returned to the host device 10 where it is demultiplexed by the demux 13 and decrypted by the CC decryptor 14. so that it can be displayed or passed to another device 70 as clear content.
The host device therefore operates to receive audio/video content and has a content decoder (the CAM module for example) capable of decoding an audio/video programme from a packetized data stream (such as a TS) by using data packets (such as EMM/ECM) defining decryption information. The received TS may comprise one or more programmes having data packets identified by respective sets of packet identifiers (such as PIDs) and comprising identification data (PAT, PMT, CAT and the like) mapping programmes to respective sets of the PIDs.
CICAM
The CICAM 30 comprises a CA decryptor 31, a CA key generator 32, a CC encryptor 33 and a CC key generator 34.
The CA decryptor 31 and the CA key generator 32 may be considered as an access control unit for decoding access-controlled broadcast content or other data. The CC key generator 34 and the CC encryptor 33 of the CICAM 30, and the demultiplexer 13 and the CC decryptor 14 of the host device 10 cooperate to provide an encrypted communication link (the common interface 80) for decoded access-controlled encoded broadcast content, between the CICAM and the host device.
The CA decryptor 31 uses keys generated from received ECMs and EMMs by the CA key generator 32, using checks of the user's identity from the smart card 50, to descramble the received access-controlled content. This part of the operation of the CICAM uses known CA techniques to retrieve and apply the CA keys.
Clear content data is passed from the CA decryptor 31 to the CC encryptor 33.
However, as this data transfer is entirely internal to the CICAM, it can be rendered secure and tamper proof by known techniques such as by providing the CA decryptor 31, the CC encryptor 33 and the clear content interface within a single integrated circuit device.
The CC encryptor 33 encrypts the descrambled content using a CC key supplied by the CC key generator 34. This key is established by a secure interchange between the CICAM 30 and the host device 10, and is specific to that CICAM-host device pair. The CC-encrypted content is passed over the common interface 80 to the host device 10. Therefore, this part of the common interface is also secure, as the content data is CC-encrypted as it passes to the host device.
Key Exchange The CICAM 30 and the host device 10 both contain logic, firmware or software providing algorithms for Diffie-Hellman (OH) secure key exchange, hashing and encryption using the known algorithms SHA-256, DES and AES, respective certificates issued by a certifying authority such as Cl Plus LLP, and private keys with the corresponding public keys.
When the CICAM 30 is first associated with the host device 10, the CICAM 30 initiates an authentication process with the host device 10. In this process, each device verifies the other's certificate, and the DH key exchange process takes place so as to securely share keys between the two devices. In particular, the CICAM first requests that the host device provides its certificate data. The CICAM verifies the signature on the host device's certificate. The same process is then carried out by the host requesting and verifying the CICAM's certificate. The CICAM and the host then each demonstrate that they possess the private key corresponding to the public key in the certificate by signing a DH public key and sending it to the other device for validation. The CICAM then obtains and verifies an authentication key AKH from the host. The CICAM and host start to compute and exchange key data for the encryption and authentication of data sent over the common interface 80. In this way, the key, key pair or other key information established by the CICAM and the host for communication over the common interface 80 is specific to that CICAM-host pair.
After authentication, the CICAM also starts to compute the CC key. The CICAM can also instruct the host device to compute the CC key. The CC key is then used as described above to encrypt content data passed from the CICAM 30 to the host device 10, according to the AES algorithm. Therefore, it will be understood that the keys used for the secure common interface 80 are specific to a particular CICAM-host pair.
Example embodiments will now be described in which multiple tuners are used, though many of the techniques are also applicable to arrangements in which just one tuner is provided.
Figure 4 is a schematic diagram of a host device 100 having multiple tuners illustrated as tuner A 102 and tuner B 104, each receiving a radio-frequency (RE) input signal. The RE input signal may be a common signal 106 processed by each of the multiple tuners, for maybe a different respective signal for different tuners (for example, one tuner may operate in respect of terrestrial broadcast television and another tuner may operate in respect of satellite broadcast television). The system is not limited to two tuners; the principles to be described may be extended to more than two tuners, but only two are shown in Figure 4 for clarity of the diagram.
Each of the tuners 102, 104 supplies an output to a respective demodulator 108, 110.
The demodulators operate as described above (in respect of the demodulator 12 of Figure 3) to demodulate a packetized data signal from the output of the respective tuner. The packetized data signals from the multiple demodulators 108, 110 are multiplexed together by a Cl controller 112 for handling by a set of one or more CAMs 114 as a series-connected set of content decoders. . Different options for implementing the set of CAMs 114 will be discussed below, but at a basic technical level, the set of CAMs 114 is capable of concurrently decoding more than one programme service for output. For example, the set of CAMs may be arranged to decode the same number of programme services concurrently as there are tuners provided in the host device 100.
Decoded data received back from the set of CAMs 114 is demultiplexed by the Cl controller 112 into respective signals 116, 118 representing the required programme services.
These are passed to programme demultiplexers 120, 122 similar in function to the demultiplexer 13 of Figure 3.
Finally, each programme service is prepared for output by a respective decoder 124, 126 corresponding in function to the CC decryptor 14 of Figure 3. The decoders 124, 126 generate respective audio/video output signals 128, 130.
The host device of Figure 4 operates under the control of a central processing unit (CPU) 132 which in turn may be a programmable processor device operating according to software or firmware stored in a memory 134 (which may in turn be a non-transitory machine-readable memory such as a magnetic or optical disk store or a non-volatile semiconductor memory).
Figure 5 schematically illustrates a multiplexer-demultiplexer arrangement forming pad of the functionality of the Cl controller 112 of Figure 4.
In basic terms, as part of the functionality of the Cl controller 112, at least respective portions of the packetized data signals from the demodulators 108, 110 are combined by a multiplexer 140 into a composite packetized data signal to be passed to the set of one or more CAMs 114, and a decoded version of the composite packetized data signal is received by a demultiplexer 142 which demultiplexes it into the respective signals 116, 118 for decoding.
There are, however, different ways in which this may be achieved.
The packetized data signals output by the two demodulators 108, 110 may represent so-called transport streams (TS) and would normally include data packets relating to several audio/video programme services along with various housekeeping and control packets. For example, a single packetized data signal may include packets relating to between 3 and 10 programme services, although the choice of how many programme services are represented by an individual TS is as much a commercial choice as a technical choice; a TS provides a certain amount of data bandwidth, but it is then a commercial choice by the broadcaster as to how many programme services should be fitted within that available bandwidth. In order to encode a higher number of programme services within a given bandwidth, the coding quality (which relates to the output quality of the reproduced audio and video signals as experienced by a viewer) of each programme service must be lowered. But in any event, it is likely in normal use that each one of the packetized data signals generated by one of the demodulators 108, 110 will contain packets of data other than those required to decode a particular desired programme service.
A technical choice then arises, in that it is possible, at least in principle, for the Cl controller 112 simply to combine the multiple packetized data signals output by the demodulators 108, 110 such that all of the information contained in each packetized data signal is retained. This would give a composite packetized data signal having a data bandwidth of the order of n x the bandwidth of an individual TS, where n is the number of individual TS5 being multiplexed together by the multiplexer 140. A potential problem with this type of arrangement is that the CAMs 114 may not be able to handle such a high data rate packetized data signal.
One potential reason is that the CAMs may be designed for compatible use in respect of just a single packetized data signal.
Accordingly, in other arrangements, a respective subset of data packets is extracted from each of the packetized data signals output by the demodulators 108, 110, and the composite packetized data signal to be supplied to the set of one or more CAMs 114 is formed from a combination of these respective subsets. Techniques for forming this combination in order to generate the composite packetized data signal will be discussed further below.
Two types of CAM are relevant to the present discussion. Figure 6a schematically illustrates a so-called M (multi-stream) card 150, and Figure 6b schematically illustrates a so-called S (single stream) card 160.
A main technical difference between these two types of CAM is as follows. The M card is a single unit capable of concurrently decrypting more than one encrypted programme service. This represents a more modern implementation of the CAM system than the S card, which is more of a legacy device capable of decrypting only one programme service from a TS.
Note that an M card can operate in either a multi-stream or a single stream (S card) mode. An S card can operate only in a single stream mode.
Figure 7 schematically illustrates a transport stream (TS) packet 170. The packets comprise a 4-byte header portion 172 and a 184-byte payload portion 174. This is a standard format for IS packets, and a TS is formed of a succession of packets of this form. The header portion 172 includes a packet identifier or PID. Each audio/video programme service has an associated set of two or more PIDs. For example, one PID may be associated with video packets of a programme service, another PID may be associated with audio packets of the programme service and a further PID may be associated with encryption control packets of the service. Therefore, within a single TS, many different PIDs may be in use. The allocation of RIDs to different types of packets is handled by a programme allocation table (PAT) and a programme map table (PMI). The RAT itself has a RID of 0 and functions so as to indicate the PID of the packets carrying the PMT. The PMT indicates the PIDs of packets carrying video and audio data as well as the RID of packets carrying the ECM data for a service. For completeness, a conditional access table (CAT) has a PlO of 1 and indicates which packets carry the EMM data for one or more access control systems.
The RIDs are uniquely defined within a single TS, in a 13 bit range (0 to 8191 in decimal). However, from TS to TS, the data represented by a particular PlO value may be ambiguous. That is to say, PID values may be reused across different TSs. In the case that multiple ISs are multiplexed together by the multiplexer 140, a mechanism is needed to overcome this potential ambiguity in the allocation of RID values.
One technique for achieving this is described in US-B-7,394,834, the contents of which are incorporated into the present description by reference. In this document, packets representing desired services are extracted from multiple input TSs, and the PIDs for packets extracted from at least one of the TSs are re-mapped to new RID values which are not used in respect of any data extracted from the other TS. The re-mapping process involves replacing a RID value with another PID value, with a record or a re-mapping table being maintained so that the desired service can be identified from the new (re-mapped) RID values. This arrangement can be used to generate a pseudo-IS, which is to say an artificially produced TS, present only within the host device, but which appears (from the point of view of an S card) to fulfil all the format requirements of a broadcast TS. That is to say, the pseudo-IS can be decoded by an S card as though it had been broadcast in that form, even though it is in fact generated within the host device by combining parts of multiple broadcast TSs.
Another technique is to use a pre-header which is inserted at the beginning of each TS packet and which provides further information as to the origin of that packet. This technique is used when sending data to M cards operating in multi-stream mode. An example of a TS packet with a pre-header 176 is shown schematically in Figure 8.
The pre-header 176 comprises 12 bytes of additional data and is pre-pended by the host to each packet sent to an M card. That is to say, it is added before the beginning of each packet. Ihe 12 bytes of additional data comprise various fields including a local transport stream identifier, which identifies the TS from which the packets was derived, a local timestamp, error detecting data for detecting errors within the pre-header, and reserved data fields for later or proprietary use. Importantly for the present purposes, the local transport stream identifier means that even in the situation where packets in a composite packetized data stream have conflicting PID values, they can still be distinguished by their local transport stream identifier value in the pre-header.
Note that an M card requires the additional pre-header to be present. An S card cannot operate with the additional pre-header present.
So, in another arrangement, the multiplexer 140 combines packets taken from multiple TSs into a composite packetized data stream suitable for use by an M card, pre-pending the additional pre-header to each such packet in dependence upon at least the identity of the TS from which that packet originated.
Figure 9 schematically illustrates a multiplexer arrangement in more detail. The multiplexer arrangement of Figure 9 is relevant to an arrangement in which a pseudo-TS is generated for decoding by S cards and by M cards operating in single-stream mode.
Each input transport stream is passed to a respective PID selector 180, 182 which refers to the programme allocation table 184, 186 associated with that TS and to data 188, 190 defining a required programme service, to establish the PID5 which are required to be passed for decoding as part of the composite packetized data signal.
In embodiments of the invention, the selectors 180.182 are operable to do one or more of the following: to select data packets from the packetized data stream for a required programme according to the set of packet identifiers defined by the identification data for that stream in respect of the required programme; to select further data packets from the packetized data stream from which a programme is selected which have packet identifiers not included in the identification data for that packetized data stream; and to select further data packets from each packetized data stream from which a programme is selected which contain programme clock reference data relating to the selected programme.
These features of the selectors' operation will be described further below.
The data 188, 190 defining a required programme service may be provided by the CPU 132, for example, possibly in response to a user control of a remote commander (not shown) or other user interface control (not shown), or possibly in response to a machine control, for example from a video recording device operating in a timer mode and requiring a certain programme service to be received during a pre-set time interval for recording. A unit 192, 194 for each TS discards "unwanted" packets, that is to say, packets which do not have PIDs defined by the selection made and the selectors 180, 182. A PID re-mapper 196, 198 is used to re-map the FIDs of one of the TSs to new FID values so as to avoid any potential overlap with PID values of the other TS. Note that the re-mapping operation does not need to be carried out in respect of both TSs, and indeed in embodiments of the present invention one of the TSs is treated as a so-called "primary" TS for which PID re-mapping does not take place. For flexibility, however, a re-mapper 196, 198 as provided in respect of each TS for possible use when required. Note also that only those PIDs which exhibit a conflict (the same PID number as a PID form another IS) need to be re-mapped, although other PIDs may be re-mapped as well.
In embodiments of the invention, RIDs from one or more secondary" TSs are candidates for re-mapping, but RIDs from a primary TS are not candidates for re-mapping.
In further embodiments, the selectors 180 can be arranged to include in their selection so-called programme clock reference packets so that these packets are included within the composite packetized data stream.
As background, programme clock reference (PCR) data are used to provide timing information for the decoding of audio and video data within a IS. The PCR data are relatively small and in fact are included within IS packets in a so-called adaptation field. The adaptation field is positioned within the 184 byte payload 174 (Figure 7) but in terms of function, acts more like an extension (into the payload area 174) of the header. To signal the presence of an adaptation field, the header carries a flag indicator (such as a one bit flag). There is then a further signalling arrangement associated with an adaptation field, to indicate in turn that the adaptation field includes PCR data. So, the selectors 180 can detect a packet that carries PCR data by first checking the "is an adaptation field present" flag in the packet header, and then checking the "does the adaptation field carry PCR data" flag associated with the adaptation
field.
The timing information indicated by the PCR data is generally common across all programme services in a TS. So, there is generally a need only to provide one set of PCR data within a TS. It is common in the art for the PCR data for a TS to be carried by adaptation fields in packets relating to an arbitrary one of the programme services. The RID of the packets carrying the PCR data for a TS may be indicated in a field PCR_PID in the PMT.
In arrangements where a whole TS is passed to a CAM for decryption (as in a single tuner: single CAM arrangement, or an arrangement with a dedicated CAM for each tuner or TS source), the fact that the PCR data may be in packets relating to a programme service other than the currently viewed or decoded programme service is not a problem, because the PCR data will still be available to the CAM and then to the decoder.
But in the present embodiments, where a composite packetized data stream is formed as a combination of subsets of multiple input TSs, with each subset relating to a required programme service, there may be situations in which the PCR data for a programme service is missing, because it is carried by packets relating to a programme service other than the selected programme service for that TS.
To address this, the selectors 180 can examine the so-called adaptation field of each packet and (if an adaptation field is present) the PCR data flag, so that if the packet is a packet containing programme clock reference data then the packet is selected whether or not it relates to a selected programme service. The packet containing PCR data is included within the selection and so included within the composite packetized data stream.
The selected and, where appropriate, re-mapped packets are then combined into a single composite data stream by a combiner 200. For example, this may be by a process of concatenation, which in general terms simply means putting side by side in the composite data stream. It does not necessarily imply that the packets are directly adjacent (there could be gaps), nor does it necessarily imply any particular packet order.
In the packetized data stream assembled using these techniques may therefore contain multiple sources of PCR data. In general, there may be data packets containing PCR data which originate from each IS from which a programme service is selected for inclusion in the composite packetized data stream. However, the decoder in respect of each programme service will be able to access the correct PCR data. If the PCR data is included within packets of the programme service to be decoded, then the decoder will use that PCR data. If the PCR data in the original IS was included in packets relating to another programme service, then these packets will be included in the composite packetized data stream by the mechanism described above. In either case, even if PID re-mapping is used, the PCR_PID data (as re-mapped if necessary) is carried for each programme service in the composite packetized data stream. Indeed, a set of data from the PAT and/or PMT is carried into the composite packetized data stream as composite stream identification data in respect of each selected programme service, for example to indicate the packets containing audio, video and CA data, as well as to indicate the PCRPID.
Accordingly, when the receiving step comprises receiving two or more packetized data streams; the selecting steps discussed above are applied to each packetized data stream from which a programme is selected; the composite packetized data stream comprises programme data from two or more of the packetized data streams; and generating the composite packetized data stream comprises concatenating the selected packets to form the composite packetized data stream.Figure 10 schematically illustrates TS packets 205 of two programme services, service 1 and service 2, combined into a single composite packetized data stream.
Figure 11 schematically illustrates a succession of CAMs, forming an example of the set of CAMs 114 discussed above. The CAMs are arranged in series, as a so-called daisy chain, so that the composite packetized data stream from the Cl controller 112 is supplied as an input 210 to a first CAM 212 in the series, and is routed from the first CAM 212 to a second CAM 214, from where it is passed to a third CAM 216 before being returned, with the required services decrypted on the basis of the packet identifiers passed with or as pad of the composite data stream identification data, to the Cl controller 112. The CAMs in the daisy chain can be arranged to provide decryption of different conditional access services, so that whichever service (within the range of services and CA systems handled by the set 114) is selected for decryption by user or machine control, one of the set of CAMs 114 is capable of decrypting it. A technique by which the host can select the appropriate CAM for a particular programme service to be decrypted will be described below with reference to Figure 15.
Accordingly, the content decoder when formed as a set of CAMs or a M card CAM is capable of concurrently decoding two or more audio/video programmes from a single packetized data stream; and in such cases the step of generating the composite packetized data stream comprises forming the composite packetized data stream from packets representing two or more programmes.
Note that there are two main interfaces to each CAM. Audio, video and some control data can be passed to the CAMs as part of the composite packetized bit stream supplied at the input 210 and passed from CAM to CAM. An additional, much lower data rate, control interface 218 is provided between the Cl controller and each CAM. Control signals to be discussed below can be multiplexed into the composite packetized data stream or carried by the control interface.
In general terms, only one CAM acts to decrypt a particular programme service, and the CAM cannot decrypt a programme service unless it receives an instruction from the host to do so.
In embodiments of the invention, the arrangement of Figure 11 can be operated when all of the CAMs in the daisy chain arrangement are S cards (or M cards operating in single-stream mode), or when all of the CAMs in the daisy chain arrangement are M cards, because in either case the data format for the composite packetized data stream is the same across the whole of the daisy chain arrangement of CAMs. For use in situations where this is not the case, Figure 12 schematically illustrates a succession of CAMs 220, 222, 224 with interface units 226, 228 between them.
In an example arrangement, assume that the CAM 220 is an M card, the CAM 222 is an S card and the CAM 224 is an M card. A composite packetized data signal 230 received from the Cl controller 112 is in the M card format, which is to say it includes the additional pre-header discussed above. This signal is handled in a conventional way by the M card 220 but instead of being passed directly to the next card 222 in the daisy chain arrangement, it is instead passed to the interface unit 226 where the additional header information relating to the pre-header is stripped off the packets and, if necessary, PID values are re-mapped, before the composite packetized data stream is passed to the S card 222. The interface unit 226 retains the stripped data and any FID re-mapping data relating to the original composite packetized data stream, and passes this retained information to the interface unit 228 which receives the output data stream from the S card 222. The interface unit 228 re-inserts the pre-header onto each packet and performs an inverse PID re-mapping process to return the PID values to their original form.
The output data stream from the interface unit 228 is then passed to the M card 224 in order to be processed.
Figure 13 is a schematic flowchart illustrating the handling of so-called ghost PIDs.
Ghost PIDs relate to so-called ghost packets in an MPEG transport stream. In some instances, ghost packets may be used by contributors to the broadcast system such as host device manufacturers, receiver manufacturers, broadcasters, CA system vendors and so on to provide confidential control information (as a "private data" field, for example) to various parts of the host device and in particular the CAM or CAMs in use at a host device.
In general terms, it is considered desirable to keep such packets secret, or at least not to advertise their presence, because they may contain information which could be useful to an unauthorised user or hacker to undertake unauthorised decryption of one or more services.
In a simple example, the ghost packets may include a firmware update for a CAM device, which in turn represents data which the CA vendor or the CAM manufacturer would normally prefer to keep away from potential hackers. To achieve a degree of confidentiality, packets containing such data may be transmitted using PIDs which are derivable by the CAM according to (for example) a predetermined algorithm based on the current time or other conditions, but which are not indicated as part of any of the allocation tables forming part of that TS. So, the ghost packets are potentially important for use by the CAM devices, but as they are not included within any of the allocation tables then unless specific action is taken to avoid this, they may in fact be discarded by the units 192, 194 in Figure 9 and may not be present in a composite packetized data stream which is actually supplied to the CAM.
To address this potential problem, the selectors 180, 182 and the discarding units 192, 194 of Figure 9 can operate according to the following steps shown in Figure 13.
At a step 250, the selectors 180, 182 select the PID5 for the required programme services. This represents a mode of operation corresponding to that already described with reference to Figure 9. A difference with respect to Figure 9, however, is that at a step 252, the selectors also select all PIDs which are not specified by the PMT, PAT or CAT for that TS. So, at this stage, the selectors do not know what technical meaning may be attached to the ghost PID5, but they are selecting all PIDs which are present in the TS and which do not specifically correspond to programme services other than the required programme service. A step 254 represents the re-mapping operation carried out by the re-mappers 196, 198. but noting that the re-mapping operation refers not only to the PIDs for the selected service but also to the ghost PIDs selected at the step 252. Finally, at a step 256, the re-mapping data, which is to say, the relationship between the PIDs before re-mapping and the PIDs after re-mapping, is sent to the set of CAMs 114 so that if a CAM within the set requires access to a packet defined by a ghost PID, the CAM may identify that packet within the re-mapped data by referring to the re-mapping information.
Note that the PID5 used to indicate ghost packets can change from time to time.
Indeed, this might be part of the security procedure associated with those packets. Also, the ghost packets may not be broadcast very often. So, when the system of Figure 9 first operates in respect of a particular programme service from a particular TS, it may not be aware of the current set of ghost PIDs. It may become aware of them by one of two techniques: by the detection (by a selector 180, 182) of a PID in the data stream which is not referenced in any of the reference tables, or by a CAM requesting a particular PlO (for example, via the control interface) which the CAM considers it requires but which is not in the composite packetized data stream. The first of these may be considered as a pre-emptive selection, the second as a reactive selection. In either case, the selector 180, 182 can act to select that PID for inclusion in the composite packetized data stream. This may in principle happen straight away, such that the first instance of such a PID is included in the composite packetized data stream. Or there may be a delay, particularly if the inclusion of the PID is in response to a request from a CAM querying the absence of the PID. This is a potential occurrence because of the relatively slow data rate of the control interface. But a small delay (for example, less than one second) is not considered a problem, because it is common practice to transmit multiple times any important packets which are not part of the audio/video stream. This is to cope with the fact that the user may switch on or switch off his receiver at any time, so it would be bad practice to transmit a critical packet on just a single occasion, at a time when the user may be unlucky enough just to miss that transmission.
Figure 14 schematically illustrates a PlO mapping table as an example of the type of re-mapping information which may be transmitted from the multiplexer 140 to the set of CAMs 114 at the step 256, either as control data or multiplexed into the composite data stream. The PID mapping table refers to an identification 260 of the TS from which the PID was taken, an identification 262 of the programme service derived from that TS, an identification 264 of the "old" PID (before re-mapping) and an identification 266 of the "new" PID (after re-mapping).
The PID mapping table may be multiplexed into the composite packetized data stream and/or transmitted to the CAMs by the control interface 218.
Note that for any TS, there may well be several different entries in the PID mapping table of Figure 14, relating to the various PIDs of the required programme service and the various other ghost PIDs present in that TS.
Note also that the PID mapping table may change in time, so it is either repeatedly transmitted to the CAMs by the Cl controller or is at least re-transmitted in response to a change in the mapping. One reason that the re-mapping may change is that a newly identified ghost packet has a PID which corresponds to another PID in the composite packetized data stream, leading to a requirement to re-map one or both of them.
Figure 15 schematically illustrates operations involved in detecting which CAM of a succession of CAMs is capable of decoding the required programme service.
The operations shown in Figure 15 represent an interaction or handshake between the host and each CAM in the set of CAMs 114. Operations relating to only one CAM of the set will be described, but it will be understood that corresponding operations would be carried out in respect of other ones of the set.
A step 300 is carried out when the system starts up or boots, in that each CAM sends data (a so-called CA_SYS_ID) to identify the type of CA system(s) which that CAM is capable of decrypting, subject to receiving the appropriate ECM/EMM data for the service.
A step 310 takes place when a new programme service is selected for decryption, for example by operation of the user control or under the control of a timed recording device, or when the CA parameters associated with a programme service change (for example, from clear" to encrypted" or the other way around). The host sends an identification of the PIDs relating to the required programme service to a CAM in the set 114. Each CAM detects the ECM and EMM data relating to that service at a step 320 and, at a step 330 detects (with reference to the ECM and EMM data, as well as the CAM's own capabilities) whether that service is decodable by that CAM. Of course, at the step 310, the host might elect to send the PIDs in question only to those CAMs which indicated, at the step 300, a basic capability (in principle) to decode that type of data.
At a step 340, the host checks the response from the current CAM which is being queried. If the CAM can decode the programme service then at a step 350 the host allocates a decoding task for that programme service to the currently queried CAM. If not, then if there remains a further CAM which has not yet been queried, then the host returns control to the step 310 to query that next CAM. Otherwise, if no further CAMs remain to be queried, and the process is aborted and, optionally, the user is notified that the required programme service cannot be decrypted by the set of CAMs 114 present in the system.
Figure 16 schematically illustrates control of multiple tuners 102, 104 by the host device, and in particular example by the CPU 132 of the host device. In Figure 16, the left-hand region of the diagram relates to operations carried out at the host, and the right-hand region relates to operations carried out at a CAM of the set 114.
This process introduces the concept of a "primary" and a "secondary" tuner, though this may be considered as being equivalent to a designation of a "primary" and a "secondary" TS, since there is a one-to-one correspondence in the present embodiments between the operation of a tuner and the reception of a TS, or in other words, each tuner receives a single TS in the present embodiments.
At a step 360, a default position is established such that the tuner 102 (tuner A) and the TS received by the tuner 102 are designated as "primary", and the tuner 104 (tuner B) and the TS received by the tuner 104 are designated as "secondary". It is noted that in a normal mode of operation, only one tuner is required to watch so-called "live" television; one function of having another tuner is that a second service can be recorded while a first service is being watched live. Alternatively, the first of the tuners or TSs to be initially required for use can form the initial definition of the primary TS or tuner.
At a step 362 the CPU 132 detects whether the secondary tuner (TS) is in use, for example to record a programme service for later viewing. If the secondary tuner is not in use, then at a step 364 the CPU 132 or the Cl controllei communicates the availability of the secondary tuner to the set of CAMs 114, in response to which one of the set may elect to use the secondary tuner for non-viewing reception at a step 366.
Here, the term "non-viewing reception" may relates to the reception, by a CAM, of housekeeping data, firmware or software updates or the like, which may require the exclusive use by that CAM of a tuner for a period of time.
Another example relates to so-called "push video on demand" or push-VOD. In this arrangement, a CAM can, pre-emptively or under instruction from the head end, cause the reception of data to be stored on, for example, a hard disk recorder, relating to video programmes which the user might wish to watch. The received data could relate to the whole programme or could relate to a trailer or advertisement for the programme, or could provide enough buffer data to allow an instant initiation of replay (at the user's command) even when the programme is being streamed. Reception of this type of data is not specifically requested or instructed by the user; it is received at the initiation of the CAM or another part of the system as a background process, and is considered as "non-viewing data" because (a) it is often transmitted at a data rate lower than a decoding or viewing data rate, and (b) the user must generally take other steps (such as requesting access to the data on a hard disk recorder) before even a viewable portion may be viewed.
During a period when the housekeeping data or other for non-viewing data is being received at the step 366, any further instances of the step 362 will show that the secondary tuner is in use. Of course, if the user requires use of the secondary tuner, for example to record a programme service, then use by the CAM for non-viewing background reception can be cancelled. This can take place in such a way that the user need not know that the CAM was evei making use of the secondary tuner.
Returning to the step 362, if the secondary tuner is required for use, then at a step 368 the PIDs for the programme service to be received by the secondary tuner (and, optionally, the PIDs for any ghost packets in that IS) are selected. This corresponds to the steps 250 and 252 in Figure 13. At a step 370 the PIDs for the secondary TS, as selected above, are re-mapped (corresponding to the step 254 in Figure 13) and the packets corresponding to the selected PIDs for the primary and secondary tuners are multiplexed together to form the composite packetized data signal. Note that as discussed above, it is necessary only to re-map a PID if a collision or conflict with another PID 9from another IS) has occurred. The system may re-map all PIDs of those packets selected from the secondary TS, or may just re-map those exhibiting a conflict of RID number. But a significant feature is that the secondary TS defines a TS having PIDs which are at least candidates for re-mapping, if re-mapping proves necessary.
This then represents the arrangement until a channel (programme service) change is detected at a step 372. A channel change may be initiated by user operation of a user control or by machine operation of a channel control, foi example by a timed recording process requiring access to a particular programme service. The operations in response to the detection of a channel change vary according to whether it is the secondary or the primary tuner which is being changed.
If the secondary TS is being changed, then control returns to the step 362, but no changes made to the designation of primary and secondary.
If, however, the channel is being changed at the primary tuner (IS) then control passes to a step 374 at which the designation of primary and secondary is reversed and control also returns to the step 362. That is to say, in a system having two tuners each receiving a respective IS, the one which was previously designated the primary is now designated the secondary, and the one that was previously designated the secondary is now designated the primary.
The effect of this is that the previous primary is now treated as a secondary, and so is subject to a re-mapping process in respect of its PIDs at the step 370, or at least its RIDs become candidates for re-mapping. In turn, this means that there is no need to carry out any further re-mapping or alteration of the previous secondary TS's PIDs, because that previous secondary is now treated as a primary. As far as the user is concerned, this means that viewing is not interrupted on the channel which is not being changed, because the tuner receiving that channel (or the TS carrying that channel) is now designated as a primary and so there is no need for any further re-mapping of that tuner's PIDs.
The change from primary to secondary is, in embodiments of the invention, carried out straight away, but the change from secondary to primary can be deferred until a detection that a secondary TS is to be retuned when no primary currently exists, in which case the change is applied to that secondary TS.
If the present system were not in place, then a channel change by the primary tuner could require a new re-mapping operation by the secondary tuner. This is because the re-mapping carried out in respect of the secondary TS's PIDs is performed in order to avoid any conflict between the primary tuner's PIDs and the re-mapped secondary tuner's PIDs. If there were no change in designation of primary and secondary, then a change in the programme service for the primary tuner could lead to a conflict of PIDs and so a further need to re-map the secondary PIDs, even though no channel change was being executed at the secondary.
Accordingly, in the absence of the present technique, a channel change at the primary tuner could result in a temporary interruption in service for the programme received by the secondary tuner, which would in turn be subjectively disturbing for the user.
The step 374 can be discussed further as follows. In response to a detection that the channel received by the primary is being changed, the primary can be redesignated as a secondary and the previous secondary as primary. However, this does not imply that the re-mapping operation carried out at the step 370 in respect of the previous secondary (now the primary) needs to be undone, and in fact this would be undesirable as it would cause a potential interruption in received service by that tuner. But it does mean that there is no need to do any re-mapping of the newly-designated primary's PIDs to avoid a conflict with the previous primary (now secondary) PIDs after retuning.
Figure 17 schematically illustrates the multiplexing of two separate programme services.
Using the techniques described above, a mechanism has been provided to amalgamate selected packets from two or more TSs into a single composite packetized data stream. The packets can be multiplexed together in the right order, which is to say for any individual received TS, the packets appropriate to the required programme service will appear in the composite packetized data stream in the correct order relative to one another. However, the mechanism does not necessarily guarantee that the multiplexed packets appeared in the concert packetized data stream at the correct time positions. At a simple level, this can be a problem when two packets intended to be included in the composite packetized data stream will have overlapping time positions; in the generation of the composite packetized data stream, one of them must be delayed in order to be included in the composite packetized data stream after the other. These time errors can lead to corresponding errors when the audio/video signal represented by the packets is decoded or rendered.
Figure 17 is a schematic illustration of an example of this potential problem. A subset of packets is selected from each of two transport streams, TS1 and TS2. The selected subset of packets are those packets which are drawn along a time axis running from left to right in the diagram. Unselected packets are simply not illustrated, to assist in the clarity of the diagram. As an example of a timing clash, it can be seen that a packet 400 from TS1 overlaps in time with a packet 402 from TS2.
A third row of Figure 17 (labelled "to/from module") schematically represents the composite packetized data stream. It will be seen that the packet 400 has substantially retained its original time position, but the packet 402 has been delayed in order to occur, in the composite packetized data stream, after the packet 400.
Fourth and fifth rows of Figure 17 represent the individual packetized data stream is which are reconstructed after decrypting by the set of CAMs 114 and demultiplexing. Again, it will be seen that the decrypted packet 400' has retained its original time position, where is the decrypted version of the packet 402 (the decrypted packet 402') has undergone a time shift by a shift amount 404. A similar time shift 406 applies to a later packet in 152.
This change in time positions within transport streams makes the programme clock reference (PCR) timestamps within the packetized data stream is no longer accurate. As a result, the receiver clock needed for decoding the MPEG programme service would not be accurate enough and this may cause subjectively disturbing issues such as lip synchronisation errors.
Two possible techniques will be discussed for addressing this problem. Figure 18 schematically illustrates a packet 410 (which may or may not include a pre-pended header as described above) which also includes an augmented packet header 412 including at least a packet arrival time which represents a timestamp allocated to each IS packet coming from the respective demodulator, or in other words is related to a time at which the composite stream is generated.
Figure 19 schematically illustrates a packet timing data table which stores similar data, though not in the form of a packet header, allowing the original timing of the TS packets to be regenerated at the final decoder stage. The table may be passed to the CAMs via the control interface or, for example, as DVB private data or as a data table. Such data can be transmitted as a private data packet adjacent in the composite stream to the packet to which it refers. This links the data to the respective packet.
Referring first to Figure 19 in detail, the packet timing data table comprises five data fields for each TS packet. These are: a sequence number 420 assigned by the host as part of a sequence to each incoming IS packet in a transport stream, a PID value 422 taken from the packet's header, a packet arrival time 424 which represents a timestamp allocated by the host or the Cl controller to each TS packet coming from its respective demodulator, a "sent" flag 426 indicating whether the TS packet has been sent to the set of CAMs 114 for decryption, and a "received" flag 428 indicating whether the packet has been received back from the set of CAMs after decryption.
Using the information maintained in the packet timing data table, the Cl controller can insert the decrypted packets received back from the set of CAMs 114 at their original time positions according to the packet arrival times stored in the table. Of course, there may be a consistent short delay for all packets in a reconstructed TS (because packets cannot be reinserted into a IS earlier than the time at which they are received back from the set of CAMs), but the relative timings of all the packets in the reconstructed TS can be made correct by use of the arrival time data stored in the packet timing data table.
A similar function can be carried out using the augmented header data 412 shown in Figure 18.
Figure 20 schematically illustrates the generation of the packet of Figure 18, and Figure 21 schematically illustrates the use of the packet of Figure 18.
Referring to Figure 20, at a step 430, the Cl controller detects a current time when a TS packet arrives at the Cl controller, and adds at least the arrival time data to the augmented header 412 at a step 432.
Referring to Figure 21, when the packet is received back from the set of CAMS after decryption, the Cl controller detects the timing information previously inserted into the augmented header 412 at a step 434 and at a step 436 either generates control information to control the decoding of that packet at the correct time or reinserts the packet back into a reconstituted TS at the correct time (or, as described above, at least at the correct relative time with respect to other packets in the reconstituted IS).
Figure 22 schematically illustrates the generation of the table of Figure 19 and Figure 23 schematically illustrates the use of the table of Figure 19.
Referring to Figure 22, at a step 440, the Cl controller detects the arrival time of a TS packet from its respective demodulator, and at a step 442 stores that arrival time as part of a table such as the table shown in Figure 19, along with a sequence number and the PID extracted from the packet's header. If the Cl controller is sending that packet for decryption, the Cl controller sets the "sent" flag 426 to indicate that this has taken place.
Referring to Figure 23, when a packet is received back from the decryption process, the Cl controller sets the "received" flag 428 in the table at a step 444, and then, at a step 446 accesses timing information from the arrival time field 424 in the table, using the PlO 422 and the sequence number 420 to index the data for the correct packet. Optionally, once a line of data has been accessed for a packet, it can be deleted from the table of Figure 19 to avoid too great a proliferation of data within the table. As before, at a step 448, the Cl controller either controls the decoding process for that packet to be carried out at the correct time or controls the reinsertion of the packet into a reconstituted TS at the correct time or at least the correct relative time with respect to other packets in that reconstituted IS.
Two features of some conditional access systems that can increase the security of the system are so-called shunning and so-called revocation procedures.
Shunning data is included within the so-called service description table (SOT) within broadcast data. Shunning allows a host to be instiucted not to use a pirate oi otherwise unauthorised CAM, or to receive and decrypt certain services. The unauthorised module or services are defined within the service description table data. Accordingly, shunning imposes a requirement on a host not to use a CAM.
Revocation involves a head end telling a host to pass data to a CAM instructing that module not to interact with a particular manufacturer's model number as a host. Again, this can be used in situations where the security of a particular model has been compromised, in order to protect the integrity of the overall conditional access system. So, revocation imposes a requirement on a CAM not to provide decryption services to a host. Revocation data is signalled by an entry in the EMM telling the CAM where to find a revocation signalling data (RSD) file in the CIplus data carousel.
In either a shunning or a revocation situation, the host may optionally signal the incident to the user, for example by an on-screen display (not shown).
Revocation data is generally signed by an operator certificate which in turn is signed by a root certificate, and so the precautions to be described below are more relevant to shunning data than to revocation data.
All of this data is contained within the TS. In a single tuner and single CAM system, the integrity of the shunning and/or revocation data can be substantially guaranteed by the tuner bypassing the CAM module, checking the SDT data for any shunning or revocation data relevant to the current host and/or CAM, and passing the shunning all revocation data to the CAM for action. These measures can avoid the CAM manipulating the data in the TS before that data is checked by the host. (This is a risk in a situation where the security of the CAM has been compromised).
The situation is more complicated in a multiple tuner and multiplexed composite packetized data stream arrangement. Here, it is not straightforward to bypass the set of CAMs in the context of the composite packetized data stream. So, there is the danger that one or more of the set of CAMs could corrupt or manipulate the shunning or revocation data contained in the SDT before it is acted upon by the host as part of a detection of whether the host is authorised to work with a CAM, for example to shun or refuse to interact with a particular CAM.
Figure 24 schematically illustrates an arrangement which can at least alleviate this problem in the context of, for example, the host device of Figure 4.
Referring to Figure 24, the multiplexed data stream generated by the Cl controller 112 is digitally signed by a signing unit 460 using a secret cryptographic key. The digitally signed multiplexed data stream is then passed to the set of CAMs 114. After decryption, the signature is checked by a signature checker 462 before the data is passed back to the demultiplexer 142.
Known techniques relating to signature using a private key and checking using a public key may be used here. Such a key may be unique to the receiver. Ths digital signature is an example of a digital security indicator.
The secret key may be communicated between the signing unit 460 and the checking unit 462 by a secure data link 464. The public-private key pair may be different from host to host to increase the potential integrity of the checking system.
The digital signature can be applied to the entire packetized composite data stream or just to the SDT data within the data stream. The digital signature can be inserted into the data stream or can be communicated separately between the units 460 and 462.
If the host finds that the digital signature has been corrupted, it can carry out various different actions. It can indicate the fact to the user, for example as an on-screen display. It can enable and disable each CAM in turn, using the control interface 218, to detect which CAM is causing the corruption, and then permanently or semi-permanently disable that CAM. In any event, the CIplus specification indicates that the host is not allowed to present content decrypted by a corrupt or shunned CAM to the screen for viewing by a user, or for recording by a user.
It will be understood that some of the techniques described above, such as those relating to the generation of the composite packetized data stream, relate to systems using at least two TSs. Others of the techniques relate to systems using one or more input TSs.
Embodiments of the invention also include a data signal, being a signal within the apparatus as described, in particular (though not exclusively) a signal as passed from the host to the CAM or set of CAMs, or the return signal. A storage medium such as a memory by which such a signal is stored is also considered as an embodiment of the invention. The storage medium may be, for example, a non-transitory machine-readable storage medium.
Insofar as embodiments of the invention have been implemented, at least in part, using the software-controlled data processing apparatus, it will be appreciated that such software, and a medium by which the software is provisioned (such as a non-transitory machine-readable storage medium, for example a magnetic or optical disc or a non-volatile memory) are also considered as embodiments of the present invention.
The following embodiments relate to the features discussed above, in various combinations.
Embodiments of the invention can provide a method of operation of an audio/video content receiver having a content decoder capable of decoding an audio/video programme from a packetized data stream by using data packets defining decryption information, the method comprising the steps of: receiving encoded audio/video content as a packetized data stream comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers and comprising identification data mapping programmes to respective sets of the packet identifiers; selecting data packets from the packetized data stream for a required programme according to the set of packet identifiers defined by the identification data for that stream in respect of the required programme; selecting further data packets from the packetized data stream from which a programme is selected which have packet identifiers not included in the identification data for that packetized data stream; generating a composite packetized data stream from the selected packets; generating composite stream identification data indicating packet identifiers of packets included in the composite packetized data stream; and supplying the composite packetized data stream to the content decoder for decoding the programme from the composite packetized data stream according to the packet identifiers in the composite stream identification data.
Embodiments of the invention can provide a method of operation of an audio/video content receiver having a content decoder capable of concurrently decoding two or more audio/video programmes from a single packetized data stream, the method comprising the steps of: receiving encoded audiolvideo content as two or more packetized data streams, each data stream comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers, each packetized data stream comprising identification data mapping programmes to respective sets of the packet identifiers; generating a composite packetized data stream having programme data from two or more of the packetized data streams by: defining one of the packetized data streams from which programme data is to be decoded as a primary packetized data stream and other packetized data streams from which programme data is to be decoded as secondary packetized data streams; selecting data packets from a packetized data stream for each required programme according to the sets of packet identifiers defined by the identification data for that stream in respect of the required programme; remapping the packet identifiers of at least those packets which have been selected from the secondary packetized data stream(s) and which have identical packet identifiers to packet identifiers from another packetized data stream to different respective packet identifiers, and not remapping the packet identifiers of the packets which have been selected from the primary packetized data stream; and generating composite stream identification data defining the packet identifiers of data packets in the composite packetized data stream; decoding two or programmes from the composite packetized data stream according to the packet identifiers in the composite stream identification data; in response to detecting the selection of a different programme for decoding from the primary packetized data stream or the selection of a different packetized data stream for reception in place of the primary packetized data stream, changing the designation of the primary packetized data stream to be a secondary packetized data stream.
Embodiments of the invention can provide a method of operation of an audio/video content receiver having a content decoder capable of concurrently decoding two or more audio/video programmes from a single packetized data stream by using data packets defining decryption information, the method comprising the steps of: receiving encoded audio/video content as two or more packetized data streams, each data stream comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers, each packetized data stream comprising identification data mapping programmes to respective sets of the packet identifiers and service data including security authorisation information for content receivers; generating a composite packetized data stream having programme data and the service data from two or more of the packetized data streams; applying a digital security indicator to at least the service data included in the composite packetized data stream; supplying the composite packetized data stream to the content decoder for decoding two or programmes from the composite packetized data stream according to the packet identifiers in the composite stream identification data; receiving the service data from the content decoder; detecting the validity of the digital security indicator applied to the service data; and in response to the service data, detecting whether the content receiver is authorised to decode received programme data.
Embodiments of the invention can provide a method of operation of an audio/video content receiver having a content decoder capable of concurrently decoding two or more audio/video programmes from a single packetized data stream of encoded audio/video data packets, the method comprising the steps of: receiving encoded audio/video content as two or more packetized data streams, each data stream comprising one or more programmes having respective encoded audio/video data packets; generating a composite packetized data stream having programme data from two or more of the packetized data streams by selecting a subset of data packets from the two or more received packetized data streams, the subset including those audio/video data packets relating to those programmes to be decoded; storing timing data indicating at least an arrival time of those audio/video data packets included in the composite packetized data stream; and decoding and outputting audio/video programme data from the composite packetized data stream according to the timing information stored in respect of each decoded audio/video packet.
Embodiments of the invention can provide an audio/video content receiver for receiving and decoding audio/video data signals modulated onto transmission channels, at least one transmission channel carrying non-viewing information) the receiver comprising: a tuner arrangement capable of concurrently tuning to two or more transmission channels; a multiplexer configured to generate a composite data signal from received audio/video signals relating to required programmes for decoding; a content decoder capable of concurrently decoding two or more audio/video programmes from the composite data signal; a detector configured to detect whether one or more of the transmission channels tuned by the tuner arrangement are not currently in use in respect of providing a programme for decoding; a controller, responsive to a detection that a transmission channel is not currently in use, for controlling the tuner to tune that channel to a transmission channel carrying non-viewing information; and a non-viewing information decoder for decoding the received non-viewing information.
Embodiments of the invention can provide a method of operation of an audio/video content receiver having a content decoder capable of decoding an audio/video programme from a packetized data stream by using data packets defining decryption information, the method comprising the steps of: receiving encoded audio/video content as a packetized data streams comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers and identification data mapping programmes to respective sets of the packet identifiers; selecting data packets from the packetized data stream for each required programme according to the set of packet identifiers defined by the identification data for that stream in respect of the required programme; selecting further data packets from each packetized data stream from which a programme is selected which contain programme clock reference data relating to the selected programme, in the case that programme clock reference data is not included in the packets relating to the selected programme; generating a composite packetized data stream from the selected packets; and generating composite stream identification data defining the packet identifiers of data packets in the composite packetized data stream; and supplying the composite packetized data stream to the content decoder for decoding according to the programme clock references and the packet identifiers in the composite stream identification data.

Claims (14)

  1. CLAIMS1. A method of operation of an audio/video content receiver having a content decoder capable of decoding an audio/video programme from a packetized data stream by using data packets defining decryption information, the method comprising the steps of: receiving encoded audio/video content as a packetized data streams comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers and identification data mapping programmes to respective sets of the packet identifiers; selecting data packets from the packetized data stream for each required programme according to the set of packet identifiers defined by the identification data for that stream in respect of the required programme; selecting further data packets from each packetized data stream from which a programme is selected which contain programme clock reference data relating to the selected programme, in the case that programme clock reference data is not included in the packets relating to the selected programme; generating a composite packetized data stream from the selected packets; and generating composite stream identification data defining the packet identifiers of data packets in the composite packetized data stream; and supplying the composite packetized data stream to the content decoder for decoding according to the programme clock references and the packet identifiers in the composite stream identification data.
  2. 2. A method according to claim 1, comprising: selecting further data packets from the packetized data stream from which a programme is selected which have packet identifiers not included in the identification data for that packetized data stream.
  3. 3. A method according to claim 1 or claim 2, comprising: including the composite stream identification data within the composite packetized data stream.
  4. 4. A method according to any one of the preceding claims, in which: the content decoder is capable of concurrently decoding two or more audio/video programmes from a single packetized data stream; and the step of generating the composite packetized data stream comprises forming the composite packetized data stream from packets representing two or more programmes.
  5. 5. A method according to claim 4, in which: the receiving step comprises receiving two or more packetized data streams; the selecting steps are applied to each packetized data stream from which a programme is selected; the composite packetized data stream comprises programme data from two or more of the packetized data streams; and the step of generating the composite packetized data stream comprises concatenating the selected packets to form the composite packetized data stream.
  6. 6. A method according to claim 5, comprising: for at least one of the packetized data streams) remapping the packet identifiers of the packets which have been selected from that packetized data stream to different packet identifiers.
  7. 7. A method according to claim 6, comprising: defining one of the received packetized data streams as a primary packetized data stream and other received packetized data streams as secondary data streams; and remapping the packet identifiers for packets from the secondary packetized data streams, and not remapping the packet identifiers for packets from the primary packetized data stream.
  8. 8. Computer software which, when executed by a computer, causes the computer to implement the method of any one of the preceding claims.
  9. 9. A storage medium which stores computer software according to claim 8.
  10. 10. An audio/video content receiver comprising: a content decoder capable of decoding an audio/video programme from a packetized data stream by using data packets defining decryption information; a tuner arrangement configured to receive encoded audio/video content as a packetized data streams comprising one or more programmes having data packets identified by respective sets of one or more packet identifiers and identification data mapping programmes to respective sets of the packet identifiers; a selector configured to select data packets from the packetized data stream for each required programme according to the set of packet identifiers defined by the identification data for that stream in respect of the required programme and to select further data packets from each packetized data stream from which a programme is selected which contain programme clock reference data relating to the selected programme) in the case that programme clock reference data is not included in the packets relating to the selected programme; and a generator configured to generate a composite packetized data stream from the selected packets and to generate composite stream identification data defining the packet identifiers of data packets in the composite packetized data stream; the content decoder being configured to decode the composite packetized data stream according to the programme clock reference data and the packet identifiers in the composite stream identification data.
  11. 11. An audio/video data signal comprising a composite packetized data stream comprising: data packets from a packetized data stream for a required audio/video programme according to the set of packet identifiers defined by an identification data for that stream in respect of the required programme; and data packets from each packetized data stream from which a programme is selected which contain programme clock reference data relating to the selected programme, in the case that programme clock reference data is not included in the packets relating to the selected programme.
  12. 12. A data signal according to claim 11, comprising a composite stream identification data indicating packet identifiers of packets included in the composite packetized data stream.
  13. 13. A data signal according to claim 11 or claim 12, comprising data packets relating to respective programmes selected from two or more respective packetized data streams.
  14. 14. A storage medium which stores a data signal according to any one of claims 11 to 13.
GB1205294.0A 2012-03-26 2012-03-26 Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets Withdrawn GB2500614A (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
GB1205294.0A GB2500614A (en) 2012-03-26 2012-03-26 Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets
PCT/EP2013/055858 WO2013143951A1 (en) 2012-03-26 2013-03-20 Conditional access method and apparatus for simultaneously handling multiple television programmes

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
GB1205294.0A GB2500614A (en) 2012-03-26 2012-03-26 Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets

Publications (2)

Publication Number Publication Date
GB201205294D0 GB201205294D0 (en) 2012-05-09
GB2500614A true GB2500614A (en) 2013-10-02

Family

ID=46087135

Family Applications (1)

Application Number Title Priority Date Filing Date
GB1205294.0A Withdrawn GB2500614A (en) 2012-03-26 2012-03-26 Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets

Country Status (2)

Country Link
GB (1) GB2500614A (en)
WO (1) WO2013143951A1 (en)

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6122123A (en) * 1997-03-12 2000-09-19 U.S. Philips Corporation Method and apparatus for recording digital information signals in which, in order to preserve timing, each packet is checked for the presence of program clock reference signal

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB0007870D0 (en) * 2000-03-31 2000-05-17 Koninkl Philips Electronics Nv Methods and apparatus for making and replauing digital video recordings, and recordings made by such methods
GB0208373D0 (en) * 2002-04-11 2002-05-22 Nokia Corp Digital video broadcasting receiver
GB2399972A (en) 2003-03-26 2004-09-29 Sony Uk Ltd Common interface controller and method of descrambling transport stream channels
KR100688089B1 (en) * 2005-09-27 2007-03-02 한국전자통신연구원 Apparatus for multiplexing and demultiplexing in cable tv receiver

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6122123A (en) * 1997-03-12 2000-09-19 U.S. Philips Corporation Method and apparatus for recording digital information signals in which, in order to preserve timing, each packet is checked for the presence of program clock reference signal

Also Published As

Publication number Publication date
WO2013143951A1 (en) 2013-10-03
GB201205294D0 (en) 2012-05-09

Similar Documents

Publication Publication Date Title
US9973804B2 (en) Conditional access method and apparatus for simultaneously handling multiple television programmes
AU2013372516B2 (en) Receiving audio/video content
US20140375892A1 (en) Receiving audio/video content
US9467736B2 (en) Receiving audio/video content
GB2500612A (en) Receiving and Selectively Decoding Received Audio/Video Content According to a Security Indicator
GB2500617A (en) Re-mapping packet identifiers (PIDs) in an audio/Visual (AV) receiver
GB2500614A (en) Method of processing received audio/visual data stream when programme clock reference (PCR) data is not included in selected programme-related packets
GB2500616A (en) Concurrent decoding of a composite packetized audio-video data stream according to packet arrival times
RU2575242C1 (en) Conditional access method and apparatus for simultaneous handling of multiple television programmes

Legal Events

Date Code Title Description
WAP Application withdrawn, taken to be withdrawn or refused ** after publication under section 16(1)