vdr/libsi/headers.h
Klaus Schmidinger 716c03a47e Version 2.1.3
VDR developer version 2.1.3 is now available at

       ftp://ftp.tvdr.de/vdr/Developer/vdr-2.1.3.tar.bz2

A 'diff' against the previous version is available at

       ftp://ftp.tvdr.de/vdr/Developer/vdr-2.1.2-2.1.3.diff

MD5 checksums:

054f80e0045aa6fad118e9285b52f4f2  vdr-2.1.3.tar.bz2
3c5ab05d5c4d0b984b34e84190e80949  vdr-2.1.2-2.1.3.diff

WARNING:
========

This is a *developer* version. Even though *I* use it in my productive
environment, I strongly recommend that you only use it under controlled
conditions and for testing and debugging.

Originally I intended to release this version only after the new DiSEqC
configuration dialog was finished. But in the meantime quite a few other things
have come up, so I decided to postpone that dialog and first release what has
piled up so far.

From the HISTORY file:
- Changed the return value of cPositioner::HorizonLongitude() to 0 in case the
  latitude of the antenna location is beyond +/-81 degrees.
- Updated the Finnish OSD texts (thanks to Rolf Ahrenberg).
- Fixed some compiler warnings with gcc-4.6.3 (thanks to Rolf Ahrenberg).
- Changed the name of the SVDRP command RENR to MOVR (suggested by Rolf Ahrenberg).
- When cutting a recording it is now checked whether there is already an edited
  version of this recording (with the same name, but starting with '%'), and the
  user is prompted for confirmation to overwrite it (suggested by Rolf Ahrenberg).
- Revoked "Added maximum signal strength value for TechniSat SkyStar 2 DVB-S rev 2.3P"
  because it broke things for the "TechniSat AirStar 2" DVB-T card.
- The LIRC remote control now connects to the socket even if it doesn't yet exist when
  VDR is started (thanks to Lars Hanisch).
- Changed the absolute latitude limit for visible satellites to 81.2 degrees.
- Added code for parsing LCN and AVC descriptors to libsi (thanks to Rolf Ahrenberg).
- In the "Select folder" menu pressing Ok now selects the folder, even if this is a
  folder that contains sub folders (marked with "..."). To open such a folder you
  can press the Red key.
- Fixed a possible access to uninitialized data in cEIT::cEIT() (reported by Dominik
  Strasser).
- The new menu category mcRecordingEdit is now used to mark menus that edit recording
  properties (suggested by Stefan Braun).
- Changes in the teletext PID no longer cause retuning (and thus interrupting a
  recording).
- Removed '_' from the FileNameChars and CharMap translations in uk_UA.po.
- Updated the Italian OSD texts (thanks to Diego Pierotto).
- Fixed a missing initialization in the c'tor of cSkinLCARSDisplayChannel (thanks to
  Marko Mäkelä).
- Simplified some conditional expressions in skinlcars.c and skinsttng.c (suggested
  by Marko Mäkelä).
- Fixed uninitialized item area coordinates in cSkinLCARSDisplayMenu (reported by
  Marko Mäkelä).
- Fixed a possible crash if the recordings list is updated externally while the
  Recordings menu is open (reported by Lars Hanisch).
- Added a missing closing ')' in the help and man page entry of the --vfat option
  (reported by Lars Hanisch).
- Fixed setting the name of the video directory to avoid a crash when using --genindex,
  and also to use the correct directory with --edit (the latter reported by Marko
  Mäkelä).
- The Recordings menu can now be called with a cRecordingFilter, which allows the
  caller to have it display only a certain subset of the recordings (thanks to Lars
  Hanisch).
- Added handling UTF-8 'umlaut' characters to cKbdRemote (thanks to Lars Hanisch).
- Made it clear that the Data parameter in cDevice::StillPicture() may point to a
  series of packets, not just a single one (thanks to Thomas Reufer).
- cDevice::TrickSpeed() now has an additional parameter named Forward, which indicates
  the direction in which replay is being done (suggested by Thomas Reufer). This
  information may be necessary for some output devices in order to properly implement
  trick modes. Authors of plugins that implement output devices will need to add this
  parameter to their derived cDevice class, regardless of whether they will make use
  of it or not.
- Added a note to ePlayMode in device.h that VDR itself always uses pmAudioVideo when
  replaying a recording (suggested by Thomas Reufer).
- Fixed some spellings in positioner.h and Doxyfile (thanks to Ville Skyttä).
- Changed '%a' to the POSIX compliant '%m' in all scanf() calls (thanks to Ville
  Skyttä).
- The new function cCamSlot::Decrypt() can be used by derived classes to implement a
  CAM slot that can be freely assigned to any device, without being directly inserted
  into the full TS data stream in hardware. A derived class that implements Decrypt()
  will also need to set the new parameter ReceiveCaPids in the call to the cCamSlot
  base class constructor to true, in order to receive the CA pid TS packets that
  contain data necessary for decrypting.
- Many member functions of cCamSlot have been made virtual to allow for easier
  implementation of derived classes.
- cTSBuffer now provides the number of available bytes in its Get() function.
- cDvbDevice::GetTSPacket() now calls CamSlot()->Decrypt() in order to allow CAM slots
  that can be freely assigned to any device access to the TS data stream.
- Added a check to avoid a possible NULL pointer dereference in cCiSession::SendData()
  (reported by Ville Skyttä).
- Deleted a superfluous assignment in cPipe::Open() (reported by Ville Skyttä).
- The script given to VDR with the '-r' option is now also called after the recording
  process has actually started (thanks to Christian Kaiser).
- Avoiding unnecessary pkg-config warnings in plugin Makefiles (thanks to Ville Skyttä).
  Plugin authors may want to apply the following change to their Makefile:
  -PKGCFG = $(if $(VDRDIR),$(shell pkg-config --variable=$(1) $(VDRDIR)/vdr.pc),$(shell pkg-config --variable=$(1) vdr || pkg-config --variable=$(1) ../../../vdr.pc))
  +PKGCFG = $(if $(VDRDIR),$(shell pkg-config --variable=$(1) $(VDRDIR)/vdr.pc),$(shell PKG_CONFIG_PATH="$$PKG_CONFIG_PATH:../../.." pkg-config --variable=$(1) vdr))
- Eliminated MAXDVBDEVICES (suggested by Oliver Endriss).
- Channels that are no longer contained in the current SDT of a transponder are now
  marked with the keyword OBSOLETE in their name and provider fields. That way you can
  identify obsolete channels when you switch to them, and you can get the complete
  overview of all obsolete channels by sorting the Channels list by provider (by
  pressing the 0 key twice). Automatic deletion of obsolete channels may follow later.
2014-01-06 18:37:32 +01:00

2163 lines
72 KiB
C++

/***************************************************************************
* *
* (C) 2001-03 Rolf Hakenes <hakenes@hippomi.de>, under the *
* GNU GPL with contribution of Oleg Assovski, *
* www.satmania.com *
* Adapted and extended by Marcel Wiesweg *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* $Id: headers.h 3.1 2013/10/30 10:16:18 kls Exp $
* *
***************************************************************************/
#ifndef LIBSI_HEADERS_H
#define LIBSI_HEADERS_H
#include <endian.h>
namespace SI {
typedef unsigned char u_char;
struct SectionHeader {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
};
struct ExtendedSectionHeader {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char table_id_extension_hi :8;
u_char table_id_extension_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
};
struct DescriptorHeader {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/*
*
* ETSI ISO/IEC 13818-1 specifies SI which is referred to as PSI. The PSI
* data provides information to enable automatic configuration of the
* receiver to demultiplex and decode the various streams of programs
* within the multiplex. The PSI data is structured as four types of table.
* The tables are transmitted in sections.
*
* 1) Program Association Table (PAT):
*
* - for each service in the multiplex, the PAT indicates the location
* (the Packet Identifier (PID) values of the Transport Stream (TS)
* packets) of the corresponding Program Map Table (PMT).
* It also gives the location of the Network Information Table (NIT).
*
*/
#define PAT_LEN 8
struct pat {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char dummy :1; // has to be 0
u_char :2;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :2;
u_char dummy :1; // has to be 0
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
};
#define PAT_PROG_LEN 4
struct pat_prog {
u_char program_number_hi :8;
u_char program_number_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :3;
u_char network_pid_hi :5;
#else
u_char network_pid_hi :5;
u_char :3;
#endif
u_char network_pid_lo :8;
/* or program_map_pid (if prog_num=0)*/
};
/*
*
* 2) Conditional Access Table (CAT):
*
* - the CAT provides information on the CA systems used in the
* multiplex; the information is private and dependent on the CA
* system, but includes the location of the EMM stream, when
* applicable.
*
*/
#define CAT_LEN 8
struct cat {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char dummy :1; // has to be 0
u_char :2;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :2;
u_char dummy :1; // has to be 0
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char reserved_1 :8;
u_char reserved_2 :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
};
/*
*
* 3) Program Map Table (PMT):
*
* - the PMT identifies and indicates the locations of the streams that
* make up each service, and the location of the Program Clock
* Reference fields for a service.
*
*/
#define PMT_LEN 12
struct pmt {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char dummy :1; // has to be 0
u_char :2;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :2;
u_char dummy :1; // has to be 0
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char program_number_hi :8;
u_char program_number_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :3;
u_char PCR_PID_hi :5;
#else
u_char PCR_PID_hi :5;
u_char :3;
#endif
u_char PCR_PID_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char program_info_length_hi :4;
#else
u_char program_info_length_hi :4;
u_char :4;
#endif
u_char program_info_length_lo :8;
//descriptors
};
#define PMT_INFO_LEN 5
struct pmt_info {
u_char stream_type :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :3;
u_char elementary_PID_hi :5;
#else
u_char elementary_PID_hi :5;
u_char :3;
#endif
u_char elementary_PID_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char ES_info_length_hi :4;
#else
u_char ES_info_length_hi :4;
u_char :4;
#endif
u_char ES_info_length_lo :8;
// descriptors
};
/*
*
* 4) Transport Stream Description Table (TSDT):
*
* - The TSDT carries a loop of descriptors that apply to
* the whole transport stream. The syntax and semantics
* of the TSDT are defined in newer versions of ISO/IEC 13818-1.
*
*/
#define TSDT_LEN 8
struct tsdt {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char dummy :1; // has to be 0
u_char :2;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :2;
u_char dummy :1; // has to be 0
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char :8;
u_char :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
};
/*
*
* 5) Network Information Table (NIT):
*
* - the NIT is intended to provide information about the physical
* network. The syntax and semantics of the NIT are defined in
* ETSI EN 300 468.
*
*/
#define NIT_LEN 10
struct nit {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char network_id_hi :8;
u_char network_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char network_descriptor_length_hi :4;
#else
u_char network_descriptor_length_hi :4;
u_char :4;
#endif
u_char network_descriptor_length_lo :8;
/* descriptors */
};
#define SIZE_NIT_MID 2
struct nit_mid { // after descriptors
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char transport_stream_loop_length_hi :4;
#else
u_char transport_stream_loop_length_hi :4;
u_char :4;
#endif
u_char transport_stream_loop_length_lo :8;
};
#define SIZE_NIT_END 4
struct nit_end {
long CRC;
};
#define NIT_TS_LEN 6
struct ni_ts {
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char transport_descriptors_length_hi :4;
#else
u_char transport_descriptors_length_hi :4;
u_char :4;
#endif
u_char transport_descriptors_length_lo :8;
/* descriptors */
};
/*
*
* In addition to the PSI, data is needed to provide identification of
* services and events for the user. In contrast with the PAT, CAT, and
* PMT of the PSI, which give information only for the multiplex in which
* they are contained (the actual multiplex), the additional information
* defined within the present document can also provide information on
* services and events carried by different multiplexes, and even on other
* networks. This data is structured as nine tables:
*
* 1) Bouquet Association Table (BAT):
*
* - the BAT provides information regarding bouquets. As well as giving
* the name of the bouquet, it provides a list of services for each
* bouquet.
*
*/
/* SEE NIT (It has the same structure but has different allowed descriptors) */
/*
*
* 2) Service Description Table (SDT):
*
* - the SDT contains data describing the services in the system e.g.
* names of services, the service provider, etc.
*
*/
#define SDT_LEN 11
struct sdt {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char :8;
};
#define GetSDTTransportStreamId(x) (HILO(((sdt_t *) x)->transport_stream_id))
#define GetSDTOriginalNetworkId(x) (HILO(((sdt_t *) x)->original_network_id))
#define SDT_DESCR_LEN 5
struct sdt_descr {
u_char service_id_hi :8;
u_char service_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :6;
u_char eit_schedule_flag :1;
u_char eit_present_following_flag :1;
u_char running_status :3;
u_char free_ca_mode :1;
u_char descriptors_loop_length_hi :4;
#else
u_char eit_present_following_flag :1;
u_char eit_schedule_flag :1;
u_char :6;
u_char descriptors_loop_length_hi :4;
u_char free_ca_mode :1;
u_char running_status :3;
#endif
u_char descriptors_loop_length_lo :8;
};
/*
*
* 3) Event Information Table (EIT):
*
* - the EIT contains data concerning events or programmes such as event
* name, start time, duration, etc.; - the use of different descriptors
* allows the transmission of different kinds of event information e.g.
* for different service types.
*
*/
#define EIT_LEN 14
struct eit {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char service_id_hi :8;
u_char service_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char segment_last_section_number :8;
u_char last_table_id :8;
};
#define EIT_EVENT_LEN 12
struct eit_event {
u_char event_id_hi :8;
u_char event_id_lo :8;
u_char mjd_hi :8;
u_char mjd_lo :8;
u_char start_time_h :8;
u_char start_time_m :8;
u_char start_time_s :8;
u_char duration_h :8;
u_char duration_m :8;
u_char duration_s :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char running_status :3;
u_char free_ca_mode :1;
u_char descriptors_loop_length_hi :4;
#else
u_char descriptors_loop_length_hi :4;
u_char free_ca_mode :1;
u_char running_status :3;
#endif
u_char descriptors_loop_length_lo :8;
};
/*
*
* 4) Running Status Table (RST):
*
* - the RST gives the status of an event (running/not running). The RST
* updates this information and allows timely automatic switching to
* events.
*
*/
struct rst {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
};
struct rst_info {
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char service_id_hi :8;
u_char service_id_lo :8;
u_char event_id_hi :8;
u_char event_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :5;
u_char running_status :3;
#else
u_char running_status :3;
u_char :5;
#endif
};
/*
*
* 5) Time and Date Table (TDT):
*
* - the TDT gives information relating to the present time and date.
* This information is given in a separate table due to the frequent
* updating of this information.
*
*/
#define TDT_LEN 8
struct tdt {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char utc_mjd_hi :8;
u_char utc_mjd_lo :8;
u_char utc_time_h :8;
u_char utc_time_m :8;
u_char utc_time_s :8;
};
/*
*
* 6) Time Offset Table (TOT):
*
* - the TOT gives information relating to the present time and date and
* local time offset. This information is given in a separate table due
* to the frequent updating of the time information.
*
*/
#define TOT_LEN 10
struct tot {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char utc_mjd_hi :8;
u_char utc_mjd_lo :8;
u_char utc_time_h :8;
u_char utc_time_m :8;
u_char utc_time_s :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char descriptors_loop_length_hi :4;
#else
u_char descriptors_loop_length_hi :4;
u_char :4;
#endif
u_char descriptors_loop_length_lo :8;
};
/*
*
* 7) Stuffing Table (ST):
*
* - the ST is used to invalidate existing sections, for example at
* delivery system boundaries.
*
*/
/* TO BE DONE */
/*
*
* 8) Selection Information Table (SIT):
*
* - the SIT is used only in "partial" (i.e. recorded) bitstreams. It
* carries a summary of the SI information required to describe the
* streams in the partial bitstream.
*
*/
/* TO BE DONE */
/*
*
* 9) Discontinuity Information Table (DIT):
*
* - the DIT is used only in "partial" (i.e. recorded) bitstreams.
* It is inserted where the SI information in the partial bitstream may
* be discontinuous. Where applicable the use of descriptors allows a
* flexible approach to the organization of the tables and allows for
* future compatible extensions.
*
*/
/* TO BE DONE */
/*
*
* 3) Application Information Table (AIT):
*
* - the AIT contains data concerning MHP application broadcast by a service.
*
*/
#define AIT_LEN 10
struct ait {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char :3;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :3;
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char application_type_hi :8;
u_char application_type_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char common_descriptors_length_hi :4;
#else
u_char common_descriptors_length_hi :4;
u_char :4;
#endif
u_char common_descriptors_length_lo :8;
};
#define SIZE_AIT_MID 2
struct ait_mid { // after descriptors
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char application_loop_length_hi :4;
#else
u_char application_loop_length_hi :4;
u_char :4;
#endif
u_char application_loop_length_lo :8;
};
#define SIZE_AIT_END 4
struct ait_end {
long CRC;
};
#define AIT_APP_LEN 9
struct ait_app {
//how to deal with 32 bit fields?
u_char organisation_id_hi_hi :8;
u_char organisation_id_hi_lo :8;
u_char organisation_id_lo_hi :8;
u_char organisation_id_lo_lo :8;
//long organisation_id :32;
u_char application_id_hi :8;
u_char application_id_lo :8;
u_char application_control_code :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char application_descriptors_length_hi :4;
#else
u_char application_descriptors_length_hi :4;
u_char :4;
#endif
u_char application_descriptors_length_lo :8;
/* descriptors */
};
/* Premiere Content Information Table */
#define PCIT_LEN 17
struct pcit {
u_char table_id :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char section_syntax_indicator :1;
u_char dummy :1; // has to be 0
u_char :2;
u_char section_length_hi :4;
#else
u_char section_length_hi :4;
u_char :2;
u_char dummy :1; // has to be 0
u_char section_syntax_indicator :1;
#endif
u_char section_length_lo :8;
u_char :8;
u_char :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :2;
u_char version_number :5;
u_char current_next_indicator :1;
#else
u_char current_next_indicator :1;
u_char version_number :5;
u_char :2;
#endif
u_char section_number :8;
u_char last_section_number :8;
u_char contentId_hi_hi :8;
u_char contentId_hi_lo :8;
u_char contentId_lo_hi :8;
u_char contentId_lo_lo :8;
u_char duration_h :8;
u_char duration_m :8;
u_char duration_s :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :4;
u_char descriptors_loop_length_hi :4;
#else
u_char descriptors_loop_length_hi :4;
u_char :4;
#endif
u_char descriptors_loop_length_lo :8;
};
/*
*
* The following describes the different descriptors that can be used within
* the SI.
*
* The following semantics apply to all the descriptors defined in this
* subclause:
*
* descriptor_tag: The descriptor tag is an 8-bit field which identifies
* each descriptor. Those values with MPEG-2 normative
* meaning are described in ISO/IEC 13818-1. The values of
* descriptor_tag are defined in 'libsi.h'
* descriptor_length: The descriptor length is an 8-bit field specifying the
* total number of bytes of the data portion of the
* descriptor following the byte defining the value of
* this field.
*
*/
#define DESCR_GEN_LEN 2
struct descr_gen {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define GetDescriptorTag(x) (((descr_gen_t *) x)->descriptor_tag)
#define GetDescriptorLength(x) (((descr_gen_t *) x)->descriptor_length+DESCR_GEN_LEN)
/* 0x09 ca_descriptor */
#define DESCR_CA_LEN 6
struct descr_ca {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char CA_type_hi :8;
u_char CA_type_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char reserved :3;
u_char CA_PID_hi :5;
#else
u_char CA_PID_hi :5;
u_char reserved :3;
#endif
u_char CA_PID_lo :8;
};
/* 0x0A iso_639_language_descriptor */
#define DESCR_ISO_639_LANGUAGE_LEN 5
struct descr_iso_639_language {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
struct descr_iso_639_language_loop {
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char audio_type :8;
};
/* 0x13 carousel_identifier_descriptor */
#define DESCR_CAROUSEL_IDENTIFIER_LEN 7
struct descr_carousel_identifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char carousel_id_hi_hi :8;
u_char carousel_id_hi_lo :8;
u_char carousel_id_lo_hi :8;
u_char carousel_id_lo_lo :8;
u_char FormatId :8;
/* FormatSpecifier follows */
};
/* 0x40 network_name_descriptor */
#define DESCR_NETWORK_NAME_LEN 2
struct descr_network_name {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x41 service_list_descriptor */
#define DESCR_SERVICE_LIST_LEN 2
struct descr_service_list {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define DESCR_SERVICE_LIST_LOOP_LEN 3
struct descr_service_list_loop {
u_char service_id_hi :8;
u_char service_id_lo :8;
u_char service_type :8;
};
/* 0x42 stuffing_descriptor */
#define DESCR_STUFFING_LEN XX
struct descr_stuffing {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x43 satellite_delivery_system_descriptor */
#define DESCR_SATELLITE_DELIVERY_SYSTEM_LEN 13
struct descr_satellite_delivery_system {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char frequency_hi_hi :8;
u_char frequency_hi_lo :8;
u_char frequency_lo_hi :8;
u_char frequency_lo_lo :8;
u_char orbital_position_hi :8;
u_char orbital_position_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char west_east_flag :1;
u_char polarization :2;
u_char roll_off :2;
u_char modulation_system :1;
u_char modulation_type :2;
#else
u_char modulation_type :2;
u_char modulation_system :1;
u_char roll_off :2;
u_char polarization :2;
u_char west_east_flag :1;
#endif
u_char symbol_rate_hi_hi :8;
u_char symbol_rate_hi_lo :8;
u_char symbol_rate_lo_1 :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char symbol_rate_lo_2 :4;
u_char fec_inner :4;
#else
u_char fec_inner :4;
u_char symbol_rate_lo_2 :4;
#endif
};
/* 0x44 cable_delivery_system_descriptor */
#define DESCR_CABLE_DELIVERY_SYSTEM_LEN 13
struct descr_cable_delivery_system {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char frequency_hi_hi :8;
u_char frequency_hi_lo :8;
u_char frequency_lo_hi :8;
u_char frequency_lo_lo :8;
u_char reserved1 :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char reserved2 :4;
u_char fec_outer :4;
#else
u_char fec_outer :4;
u_char reserved2 :4;
#endif
u_char modulation :8;
u_char symbol_rate_hi_hi :8;
u_char symbol_rate_hi_lo :8;
u_char symbol_rate_lo_1 :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char symbol_rate_lo_2 :4;
u_char fec_inner :4;
#else
u_char fec_inner :4;
u_char symbol_rate_lo_2 :4;
#endif
};
/* 0x45 vbi_data_descriptor */
#define DESCR_VBI_DATA_LEN XX
struct descr_vbi_data {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x46 vbi_teletext_descriptor */
#define DESCR_VBI_TELETEXT_LEN XX
struct descr_vbi_teletext {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x47 bouquet_name_descriptor */
#define DESCR_BOUQUET_NAME_LEN 2
struct descr_bouquet_name {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x48 service_descriptor */
#define DESCR_SERVICE_LEN 4
struct descr_service {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char service_type :8;
u_char provider_name_length :8;
};
struct descr_service_mid {
u_char service_name_length :8;
};
/* 0x49 country_availability_descriptor */
#define DESCR_COUNTRY_AVAILABILITY_LEN 3
struct descr_country_availability {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char country_availability_flag :1;
u_char reserved :7;
#else
u_char reserved :7;
u_char country_availability_flag :1;
#endif
};
/* 0x4A linkage_descriptor */
#define DESCR_LINKAGE_LEN 9
struct descr_linkage {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char service_id_hi :8;
u_char service_id_lo :8;
u_char linkage_type :8;
};
#define DESCR_LINKAGE_8_LEN 3
struct descr_linkage_8 {
#if BYTE_ORDER == BIG_ENDIAN
u_char hand_over_type :4;
u_char reserved :3;
u_char origin_type :1;
#else
u_char origin_type :1;
u_char reserved :3;
u_char hand_over_type :4;
#endif
u_char id_hi :8;
u_char id_lo :8;
};
/* 0x4B nvod_reference_descriptor */
#define DESCR_NVOD_REFERENCE_LEN 2
struct descr_nvod_reference {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define ITEM_NVOD_REFERENCE_LEN 6
struct item_nvod_reference {
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char service_id_hi :8;
u_char service_id_lo :8;
};
/* 0x4C time_shifted_service_descriptor */
#define DESCR_TIME_SHIFTED_SERVICE_LEN 4
struct descr_time_shifted_service {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char reference_service_id_hi :8;
u_char reference_service_id_lo :8;
};
/* 0x4D short_event_descriptor */
#define DESCR_SHORT_EVENT_LEN 6
struct descr_short_event {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char event_name_length :8;
};
struct descr_short_event_mid {
u_char text_length :8;
};
/* 0x4E extended_event_descriptor */
#define DESCR_EXTENDED_EVENT_LEN 7
struct descr_extended_event {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
#if BYTE_ORDER == BIG_ENDIAN
u_char descriptor_number :4;
u_char last_descriptor_number :4;
#else
u_char last_descriptor_number :4;
u_char descriptor_number :4;
#endif
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char length_of_items :8;
};
struct descr_extended_event_mid {
u_char text_length :8;
};
#define ITEM_EXTENDED_EVENT_LEN 1
struct item_extended_event {
u_char item_description_length :8;
};
struct item_extended_event_mid {
u_char item_length :8;
};
/* 0x4F time_shifted_event_descriptor */
#define DESCR_TIME_SHIFTED_EVENT_LEN 6
struct descr_time_shifted_event {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char reference_service_id_hi :8;
u_char reference_service_id_lo :8;
u_char reference_event_id_hi :8;
u_char reference_event_id_lo :8;
};
/* 0x50 component_descriptor */
#define DESCR_COMPONENT_LEN 8
struct descr_component {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char reserved :4;
u_char stream_content :4;
#else
u_char stream_content :4;
u_char reserved :4;
#endif
u_char component_type :8;
u_char component_tag :8;
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
};
/* 0x51 mosaic_descriptor */
#define DESCR_MOSAIC_LEN XX
struct descr_mosaic {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x52 stream_identifier_descriptor */
#define DESCR_STREAM_IDENTIFIER_LEN 3
struct descr_stream_identifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char component_tag :8;
};
/* 0x53 ca_identifier_descriptor */
#define DESCR_CA_IDENTIFIER_LEN 2
struct descr_ca_identifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x54 content_descriptor */
#define DESCR_CONTENT_LEN 2
struct descr_content {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
struct nibble_content {
#if BYTE_ORDER == BIG_ENDIAN
u_char content_nibble_level_1 :4;
u_char content_nibble_level_2 :4;
#else
u_char content_nibble_level_2 :4;
u_char content_nibble_level_1 :4;
#endif
#if BYTE_ORDER == BIG_ENDIAN
u_char user_nibble_1 :4;
u_char user_nibble_2 :4;
#else
u_char user_nibble_2 :4;
u_char user_nibble_1 :4;
#endif
};
/* 0x55 parental_rating_descriptor */
#define DESCR_PARENTAL_RATING_LEN 2
struct descr_parental_rating {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define PARENTAL_RATING_LEN 4
struct parental_rating {
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char rating :8;
};
/* 0x56 teletext_descriptor */
#define DESCR_TELETEXT_LEN 2
struct descr_teletext {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define ITEM_TELETEXT_LEN 5
struct item_teletext {
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char type :5;
u_char magazine_number :3;
#else
u_char magazine_number :3;
u_char type :5;
#endif
u_char page_number :8;
};
/* 0x57 telephone_descriptor */
#define DESCR_TELEPHONE_LEN XX
struct descr_telephone {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x58 local_time_offset_descriptor */
#define DESCR_LOCAL_TIME_OFFSET_LEN 2
struct descr_local_time_offset {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define LOCAL_TIME_OFFSET_ENTRY_LEN 15
struct local_time_offset_entry {
u_char country_code1 :8;
u_char country_code2 :8;
u_char country_code3 :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char country_region_id :6;
u_char :1;
u_char local_time_offset_polarity :1;
#else
u_char local_time_offset_polarity :1;
u_char :1;
u_char country_region_id :6;
#endif
u_char local_time_offset_h :8;
u_char local_time_offset_m :8;
u_char time_of_change_mjd_hi :8;
u_char time_of_change_mjd_lo :8;
u_char time_of_change_time_h :8;
u_char time_of_change_time_m :8;
u_char time_of_change_time_s :8;
u_char next_time_offset_h :8;
u_char next_time_offset_m :8;
};
/* 0x59 subtitling_descriptor */
#define DESCR_SUBTITLING_LEN 2
struct descr_subtitling {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define ITEM_SUBTITLING_LEN 8
struct item_subtitling {
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char subtitling_type :8;
u_char composition_page_id_hi :8;
u_char composition_page_id_lo :8;
u_char ancillary_page_id_hi :8;
u_char ancillary_page_id_lo :8;
};
/* 0x5A terrestrial_delivery_system_descriptor */
#define DESCR_TERRESTRIAL_DELIVERY_SYSTEM_LEN XX
struct descr_terrestrial_delivery {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char frequency_hi_hi :8;
u_char frequency_hi_lo :8;
u_char frequency_lo_hi :8;
u_char frequency_lo_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char bandwidth :3;
u_char priority :1;
u_char time_slicing_indicator :1;
u_char mpe_fec_indicator :1;
u_char reserved1 :2;
#else
u_char reserved1 :2;
u_char mpe_fec_indicator :1;
u_char time_slicing_indicator :1;
u_char priority :1;
u_char bandwidth :3;
#endif
#if BYTE_ORDER == BIG_ENDIAN
u_char constellation :2;
u_char hierarchy :3;
u_char code_rate_HP :3;
#else
u_char code_rate_HP :3;
u_char hierarchy :3;
u_char constellation :2;
#endif
#if BYTE_ORDER == BIG_ENDIAN
u_char code_rate_LP :3;
u_char guard_interval :2;
u_char transmission_mode :2;
u_char other_frequency_flag :1;
#else
u_char other_frequency_flag :1;
u_char transmission_mode :2;
u_char guard_interval :2;
u_char code_rate_LP :3;
#endif
u_char reserver2 :8;
u_char reserver3 :8;
u_char reserver4 :8;
u_char reserver5 :8;
};
/* 0x5B multilingual_network_name_descriptor */
#define DESCR_MULTILINGUAL_NETWORK_NAME_LEN XX
struct descr_multilingual_network_name {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
struct entry_multilingual_name {
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char text_length :8;
};
/* 0x5C multilingual_bouquet_name_descriptor */
#define DESCR_MULTILINGUAL_BOUQUET_NAME_LEN XX
struct descr_multilingual_bouquet_name {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x5D multilingual_service_name_descriptor */
#define DESCR_MULTILINGUAL_SERVICE_NAME_LEN XX
struct descr_multilingual_service_name {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
struct entry_multilingual_service_name_mid {
u_char service_name_length :8;
};
/* 0x5E multilingual_component_descriptor */
#define DESCR_MULTILINGUAL_COMPONENT_LEN XX
struct descr_multilingual_component {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char component_tag :8;
};
/* 0x5F private_data_specifier_descriptor */
#define DESCR_PRIVATE_DATA_SPECIFIER_LEN XX
struct descr_private_data_specifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char private_data_specifier_hi_hi :8;
u_char private_data_specifier_hi_lo :8;
u_char private_data_specifier_lo_hi :8;
u_char private_data_specifier_lo_lo :8;
};
/* 0x60 service_move_descriptor */
#define DESCR_SERVICE_MOVE_LEN XX
struct descr_service_move {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char new_original_network_id_hi :8;
u_char new_original_network_id_lo :8;
u_char new_transport_stream_id_hi :8;
u_char new_transport_stream_id_lo :8;
u_char new_service_id_hi :8;
u_char new_service_id_lo :8;
};
/* 0x61 short_smoothing_buffer_descriptor */
#define DESCR_SHORT_SMOOTHING_BUFFER_LEN XX
struct descr_short_smoothing_buffer {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x62 frequency_list_descriptor */
#define DESCR_FREQUENCY_LIST_LEN XX
struct descr_frequency_list {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :6;
u_char coding_type :2;
#else
u_char coding_type :2;
u_char :6;
#endif
};
/* 0x63 partial_transport_stream_descriptor */
#define DESCR_PARTIAL_TRANSPORT_STREAM_LEN XX
struct descr_partial_transport_stream {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x64 data_broadcast_descriptor */
#define DESCR_DATA_BROADCAST_LEN XX
struct descr_data_broadcast {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x65 scrambling_descriptor */
#define DESCR_SCRAMBLING_LEN XX
struct descr_scrambling {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x66 data_broadcast_id_descriptor */
#define DESCR_DATA_BROADCAST_ID_LEN XX
struct descr_data_broadcast_id {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x67 transport_stream_descriptor */
#define DESCR_TRANSPORT_STREAM_LEN XX
struct descr_transport_stream {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x68 dsng_descriptor */
#define DESCR_DSNG_LEN XX
struct descr_dsng {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x69 pdc_descriptor */
#define DESCR_PDC_LEN 5
struct descr_pdc {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char pil0 :8;
u_char pil1 :8;
u_char pil2 :8;
};
/* 0x6A ac3_descriptor */
#define DESCR_AC3_LEN 3
struct descr_ac3 {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char ac3_type_flag :1;
u_char bsid_flag :1;
u_char mainid_flag :1;
u_char asvc_flag :1;
u_char reserved :4;
#else
u_char reserved :4;
u_char asvc_flag :1;
u_char mainid_flag :1;
u_char bsid_flag :1;
u_char ac3_type_flag :1;
#endif
u_char ac3_type :8;
u_char bsid :8;
u_char mainid :8;
u_char asvc :8;
};
/* 0x6B ancillary_data_descriptor */
#define DESCR_ANCILLARY_DATA_LEN 3
struct descr_ancillary_data {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char ancillary_data_identifier :8;
};
/* 0x6C cell_list_descriptor */
#define DESCR_CELL_LIST_LEN XX
struct descr_cell_list {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x6D cell_frequency_link_descriptor */
#define DESCR_CELL_FREQUENCY_LINK_LEN XX
struct descr_cell_frequency_link {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x6E announcement_support_descriptor */
#define DESCR_ANNOUNCEMENT_SUPPORT_LEN XX
struct descr_announcement_support {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* TBD */
};
/* 0x6F application_signalling_descriptor */
#define DESCR_APPLICATION_SIGNALLING_LEN 2
struct descr_application_signalling {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define APPLICATION_SIGNALLING_ENTRY_LEN 3
struct application_signalling_entry {
u_char application_type_hi :8;
u_char application_type_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char :3;
u_char AIT_version_number :5;
#else
u_char AIT_version_number :5;
u_char :3;
#endif
};
/* 0x71 service_identifier_descriptor (ETSI TS 102 812, MHP) */
struct descr_service_identifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x72 service_availbility_descriptor */
struct descr_service_availbility {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char availability_flag :1;
u_char reserved :7;
#else
u_char reserved :7;
u_char availability_flag :1;
#endif
};
/* 0x73 default_authority_descriptor (ETSI TS 102 323) */
struct descr_default_authority {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x74 related_content_descriptor (ETSI TS 102 323) */
struct descr_related_content {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x75 tva_id_descriptor (ETSI TS 102 323) */
struct descr_tva_id {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
/* 0x76 content_identifier_descriptor (ETSI TS 102 323) */
struct descr_content_identifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
struct content_identifier_entry {
#if BYTE_ORDER == BIG_ENDIAN
u_char crid_type :6;
u_char crid_location :2;
#else
u_char crid_location :2;
u_char crid_type :6;
#endif
union {
u_char crid_length :8;
u_char crid_ref_hi :8;
};
union {
u_char crid_byte :8;
u_char crid_ref_lo :8;
};
};
/* 0x77 time_slice_fec_identifier_descriptor (ETSI EN 301 192) */
struct descr_time_slice_fec_identifier {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char time_slicing :1;
u_char mpe_fec :2;
u_char reserved :2;
u_char frame_size :3;
#else
u_char frame_size :3;
u_char reserved :2;
u_char mpe_fec :2;
u_char time_slicing :1;
#endif
u_char max_burst_duration :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char max_average_rate :4;
u_char time_slice_fec_id :4;
#else
u_char time_slice_fec_id :4;
u_char max_average_rate :4;
#endif
};
/* 0x78 ecm_repetition_rate_descriptor (ETSI EN 301 192) */
struct descr_ecm_repetition_rate {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char ca_system_id_hi :8;
u_char ca_system_id_lo :8;
u_char ecm_repetition_rate_hi :8;
u_char ecm_repetition_rate_lo :8;
};
/* 0x79 s2_satellite_delivery_system_descriptor */
struct descr_s2_satellite_delivery_system {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char scrambling_sequence_selector :1;
u_char multiple_input_stream_flag :1;
u_char backwards_compatibility_indicator :1;
u_char reserved :5;
#else
u_char reserved :5;
u_char backwards_compatibility_indicator :1;
u_char multiple_input_stream_flag :1;
u_char scrambling_sequence_selector :1;
#endif
};
struct descr_scrambling_sequence_selector {
#if BYTE_ORDER == BIG_ENDIAN
u_char reserved :6;
u_char scrambling_sequence_index_hi_lo :2;
#else
u_char scrambling_sequence_index_hi_lo :2;
u_char reserved :6;
#endif
u_char scrambling_sequence_index_lo_hi :8;
u_char scrambling_sequence_index_lo_lo :8;
};
/* 0x7A enhanced_ac3_descriptor */
struct descr_enhanced_ac3 {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char component_type_flag :1;
u_char bsid_flag :1;
u_char mainid_flag :1;
u_char asvc_flag :1;
u_char mixinfoexists :1;
u_char substream1_flag :1;
u_char substream2_flag :1;
u_char substream3_flag :1;
#else
u_char substream3_flag :1;
u_char substream2_flag :1;
u_char substream1_flag :1;
u_char mixinfoexists :1;
u_char asvc_flag :1;
u_char mainid_flag :1;
u_char bsid_flag :1;
u_char component_type_flag :1;
#endif
};
/* 0x7B dts_descriptor */
struct descr_dts {
u_char descriptor_tag :8;
u_char descriptor_length :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char sample_rate_code :4;
u_char bit_rate_code :6;
u_char nblks :7;
u_char fsize_hi :6;
u_char fsize_lo :8;
u_char surround_mode :6;
u_char lfe_flag :1;
u_char extended_surround_flag :2;
#else
u_char extended_surround_flag :2;
u_char lfe_flag :1;
u_char surround_mode :6;
u_char fsize_lo :8;
u_char fsize_hi :6;
u_char nblks :7;
u_char bit_rate_code :6;
u_char sample_rate_code :4;
#endif
};
/* 0x7C aac_descriptor */
struct descr_aac {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char profile_and_level :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char aac_type_flag :1;
u_char reserved :7;
#else
u_char reserved :7;
u_char aac_type_flag :1;
#endif
};
/* 0x7F extension_descriptor */
struct descr_extension {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char descriptor_tag_extension :8;
};
/* extension 0x04 t2_delivery_system_descriptor */
struct descr_t2_delivery_system {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char descriptor_tag_extension :8;
u_char plp_id :8;
u_char t2_system_id_hi :8;
u_char t2_system_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char siso_miso :2;
u_char bandwidth :4;
u_char reserved :2;
u_char guard_interval :3;
u_char transmission_mode :3;
u_char other_frequency_flag :1;
u_char tfs_flag :1;
#else
u_char reserved :2;
u_char bandwidth :4;
u_char siso_miso :2;
u_char tfs_flag :1;
u_char other_frequency_flag :1;
u_char transmission_mode :3;
u_char guard_interval :3;
#endif
/* now follow cell_id, frequency_loop_length, centre_frequency,
subcell_info_loop_length, cell_id_extension, transposer_frequency
fields looping to the end */
};
/* 0x83 logical_channel_descriptor */
#define DESCR_LOGICAL_CHANNEL_LEN 2
struct descr_logical_channel {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define ITEM_LOGICAL_CHANNEL_LEN 4
struct item_logical_channel {
u_char service_id_hi :8;
u_char service_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char visible_service_flag :1;
u_char reserved :5;
u_char logical_channel_number_hi :2;
#else
u_char logical_channel_number_hi :2;
u_char reserved :5;
u_char visible_service_flag :1;
#endif
u_char logical_channel_number_lo :8;
};
/* 0x88 hd_simulcast_logical_channel_descriptor */
#define DESCR_HD_SIMULCAST_LOGICAL_CHANNEL_LEN 2
struct descr_hd_simulcast_logical_channel {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define ITEM_HD_SIMULCAST_LOGICAL_CHANNEL_LEN 4
struct item_hd_simulcast_logical_channel {
u_char service_id_hi :8;
u_char service_id_lo :8;
#if BYTE_ORDER == BIG_ENDIAN
u_char visible_service_flag :1;
u_char reserved :5;
u_char logical_channel_number_hi :2;
#else
u_char logical_channel_number_hi :2;
u_char reserved :5;
u_char visible_service_flag :1;
#endif
u_char logical_channel_number_lo :8;
};
/* MHP 0x00 application_descriptor */
#define DESCR_APPLICATION_LEN 3
struct descr_application {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char application_profiles_length :8;
};
#define DESCR_APPLICATION_END_LEN 2
struct descr_application_end {
#if BYTE_ORDER == BIG_ENDIAN
u_char service_bound_flag :1;
u_char visibility :2;
u_char :5;
#else
u_char :5;
u_char visibility :2;
u_char service_bound_flag :1;
#endif
u_char application_priority :8;
/*now follow 8bit transport_protocol_label fields to the end */
};
#define APPLICATION_PROFILE_ENTRY_LEN 5
struct application_profile_entry {
u_char application_profile_hi :8;
u_char application_profile_lo :8;
u_char version_major :8;
u_char version_minor :8;
u_char version_micro :8;
};
/* MHP 0x01 application_name_desriptor */
#define DESCR_APPLICATION_NAME_LEN 2
struct descr_application_name {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define APPLICATION_NAME_ENTRY_LEN 4
struct descr_application_name_entry {
u_char lang_code1 :8;
u_char lang_code2 :8;
u_char lang_code3 :8;
u_char application_name_length :8;
/* application name string */
};
/* MHP 0x02 transport_protocol_descriptor */
#define DESCR_TRANSPORT_PROTOCOL_LEN 5
struct descr_transport_protocol {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char protocol_id_hi :8;
u_char protocol_id_lo :8;
u_char transport_protocol_label :8;
/* protocol_id-specific selector bytes follow */
};
struct descr_url_extension_entry {
u_char url_extension_length :8;
/* URL extension string */
};
#define TRANSPORT_VIA_OC_LEN 1
struct transport_via_oc {
#if BYTE_ORDER == BIG_ENDIAN
u_char remote :1;
u_char :7;
#else
u_char :7;
u_char remote :1;
#endif
};
//if remote is true, transport_via_oc_remote_end_t follows,
// else transport_via_oc_end_t.
#define TRANSPORT_VIA_OC_REMOTE_END_LEN 7
struct transport_via_oc_remote_end {
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char service_id_hi :8;
u_char service_id_lo :8;
u_char component_tag :8;
};
#define TRANSPORT_VIA_OC_END_LEN 1
struct transport_via_oc_end {
u_char component_tag :8;
};
#define TRANSPORT_VIA_HTTP_LEN 1
struct transport_via_http {
u_char url_base_length :8;
};
/* 0x03 dvb_j_application_descriptor() */
#define DESCR_DVBJ_APPLICATION_LEN 2
struct descr_dvbj_application {
u_char descriptor_tag :8;
u_char descriptor_length :8;
};
#define DESCR_DVBJ_APPLICATION_ENTRY_LEN 1
struct descr_dvbj_application_entry {
u_char parameter_length :8;
/* parameter string */
};
/* 0x04 dvb_j_application_location_descriptor */
#define DESCR_DVBJ_APPLICATION_LOCATION_LEN 3
struct descr_dvbj_application_location {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char base_directory_length :8;
/* base directory string */
};
#define DESCR_DVBJ_APPLICATION_LOCATION_MID_LEN 1
struct descr_dvbj_application_location_mid {
u_char classpath_extension_length :8;
};
/* 0x0B application_icons_descriptor */
#define DESCR_APPLICATION_ICONS_LEN 3
struct descr_application_icons_descriptor {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char icon_locator_length :8;
/* icon locator */
};
#define DESCR_APPLICATION_ICONS_END_LEN 2
struct descr_application_icons_descriptor_end {
u_char icon_flags_hi :8;
u_char icon_flags_lo :8;
};
/* 0x15 simple application location descrptor */
#define DESCR_SIMPLE_APPLICATION_LOCATION_LEN 3
struct descr_simple_application_location_descriptor {
u_char descriptor_tag :8;
u_char descriptor_length :8;
/* initial_path_bytes */
};
// Private DVB Descriptor Premiere.de
// 0xF2 Content Transmission Descriptor
// http://dvbsnoop.sourceforge.net/examples/example-private-section.html
#define DESCR_PREMIERE_CONTENT_TRANSMISSION_LEN 8
struct descr_premiere_content_transmission {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char transport_stream_id_hi :8;
u_char transport_stream_id_lo :8;
u_char original_network_id_hi :8;
u_char original_network_id_lo :8;
u_char service_id_hi :8;
u_char service_id_lo :8;
};
#define ITEM_PREMIERE_CONTENT_TRANSMISSION_DAY_LEN 3
struct item_premiere_content_transmission_day {
u_char mjd_hi :8;
u_char mjd_lo :8;
u_char start_time_loop :8;
};
#define ITEM_PREMIERE_CONTENT_TRANSMISSION_TIME_LEN 3
struct item_premiere_content_transmission_time {
u_char start_time_h :8;
u_char start_time_m :8;
u_char start_time_s :8;
};
/* 0x05 registration_descriptor */
#define DESCR_REGISTRATION_LEN 6
struct descr_registration {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char format_identifier_hi_hi :8;
u_char format_identifier_hi_lo :8;
u_char format_identifier_lo_hi :8;
u_char format_identifier_lo_lo :8;
};
/* 0x28 avc_descriptor */
#define DESCR_AVC_LEN 6
struct descr_avc {
u_char descriptor_tag :8;
u_char descriptor_length :8;
u_char profile_idc :8;
u_char constraint_set0_flag :1;
u_char constraint_set1_flag :1;
u_char constraint_set2_flag :1;
u_char constraint_set3_flag :1;
u_char constraint_set4_flag :1;
u_char constraint_set5_flag :1;
u_char avc_compatible_flags :2;
u_char level_idc :8;
u_char avc_still_present :1;
u_char avc_24_hour_picture_flag :1;
u_char frame_packing_sei_not_present_flag :1;
u_char reserved :5;
};
} //end of namespace
#endif //LIBSI_HEADERS_H