MHEG5 1.0
DTVKit MHEG5 1.0 API Documentation
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
dvb_ics.h
Go to the documentation of this file.
1 /*******************************************************************************
2  * Copyright © 2014 The DTVKit Open Software Foundation Ltd (www.dtvkit.org)
3  * Copyright © 2012 Ocean Blue Software Ltd
4  *
5  * This file is part of a DTVKit Software Component
6  * You are permitted to copy, modify or distribute this file subject to the terms
7  * of the DTVKit 1.0 Licence which can be found in licence.txt or at www.dtvkit.org
8  *
9  * THIS CODE AND INFORMATION ARE PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
10  * EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES
11  * OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.
12  *
13  * If you or your organisation is not a member of DTVKit then you have access
14  * to this source code outside of the terms of the licence agreement
15  * and you are expected to delete this and any associated files immediately.
16  * Further information on DTVKit, membership and terms can be found at www.dtvkit.org
17  *******************************************************************************/
28 #ifndef _DVB_ICS_H
29 #define _DVB_ICS_H
30 
31 #include "techtype.h"
32 #include "mherrors.h"
33 
34 /*---Constant and macro definitions for public use-----------------------------*/
35 
36 /*---Enumerations for public use-----------------------------------------------*/
37 
38 /* Video termination attribute */
39 typedef enum
40 {
44 
45 /* IP streaming status */
46 typedef enum
47 {
50 } E_ICSStatus;
51 
52 typedef enum
53 {
58 
59 #ifdef INCLUDE_FREESAT
60 typedef enum
61 {
62  MHEG5_ICS_PIN_REQ_NEVER,
63  MHEG5_ICS_PIN_REQ_GUIDANCE_ONLY,
64  MHEG5_ICS_PIN_REQ_ALWAYS
65 } E_ICSPinReq;
66 
67 typedef enum
68 {
69  MHEG5_ICS_PIN_STATUS_NOT_REQUIRED,
70  MHEG5_ICS_PIN_STATUS_OK,
71  MHEG5_ICS_PIN_STATUS_INVALID
72 } E_ICSPinStatus;
73 #endif
74 
75 /*---Global type defs for public use-------------------------------------------*/
76 
77 /* A/V component selection for IP streaming */
78 typedef struct
79 {
86 
87 /* Encryption keys for IP streams */
88 typedef struct
89 {
91  U8BIT odd_key[16];
92  U8BIT even_key[16];
93  U8BIT iv[16];
94 } S_ICSPidInfo;
95 
96 typedef struct
97 {
100 } S_ICSKeys;
101 
102 /*---Global Function prototypes for public use---------------------------------*/
103 
124 
140 
159 
172 
184 
195 
208 
224 
237 
238 #ifdef INCLUDE_FREESAT
239 
253 E_MhegErr DVB_MhegIsConnectionAllowed(BOOLEAN *pAllowed);
254 
266 E_MhegErr DVB_MhegGetPINRequirement(E_ICSPinReq *status);
267 
280 E_MhegErr DVB_MhegValidatePIN(U8BIT *pin, E_ICSPinStatus *status);
281 
293 E_MhegErr DVB_MhegGetMACAddress(U8BIT address[6]);
294 
313 E_MhegErr DVB_MhegGetPrivateKey(U8BIT *buffer, U16BIT bufsize,
314  U16BIT *keylen, U32BIT *version);
315 
316 #endif /* INCLUDE_FREESAT */
317 
318 #endif /*_DVB_ICS_H*/
E_MhegErr DVB_MhegStreamSetup(U8BIT *pmt, S_ICSKeys *keys, E_ICSStatus *status)
This function tells the external application that an IC delivered stream is to be played using DVB_Mh...
E_MhegErr DVB_MhegStreamAudioSetVolume(S32BIT volumeAdjust)
Set volume for audio component of the currently playing IC stream This function is equivalent to DVB_...
E_VideoTermination
Definition: dvb_ics.h:39
U32BIT DVB_MhegStreamHandleData(U8BIT *data, U32BIT len, BOOLEAN last)
Handle transport stream data. The data is part of a single-program transport stream, containing audio, video and/or subtitles (in one or more languages). The video is H.264 SD video and the audio is HE-AAC audio. The stream contains PAT and PMT (other SI data can be ignored). This function can block until the data has been processed / buffered. It may also return when part of the block has been processed. This would cause a subsequent call with the rest of the block. When the last block is presented (last=TRUE), the function should indicate that the block has been completely processed only when this is a true reflection of the presentation status.
E_MhegErr DVB_MhegStreamResume(void)
Resume presentation of audio and/or video components of the currently playing IC delivered stream...
const char * data
Definition: mh5gate.c:65
Definition: dvb_ics.h:96
E_MhegErr DVB_MhegGetPINSupport(E_ICSPinSupport *support)
Returns the PIN support in the receiver. This MUST be a non-blocking function, returning results imme...
E_MhegErr DVB_MhegPromptForGuidance(U8BIT *restriction, BOOLEAN show)
This function asks the external application to obtain permission from the user to present IP-delivere...
Definition: dvb_ics.h:41
E_MhegErr
Definition: mherrors.h:28
MHEG5 engine interface error codes.
S32BIT video_component_tag
Definition: dvb_ics.h:83
E_ICSStatus
Definition: dvb_ics.h:46
uint8_t U8BIT
Definition: techtype.h:93
U16BIT num_pids
Definition: dvb_ics.h:99
BOOLEAN video_active
Definition: dvb_ics.h:81
Definition: dvb_ics.h:42
S32BIT audio_component_tag
Definition: dvb_ics.h:82
E_MhegErr DVB_MhegStreamPause(void)
Pause presentation of audio and/or video components of the currently playing IC delivered stream...
Definition: dvb_ics.h:78
Definition: dvb_ics.h:56
Definition: dvb_ics.h:55
E_ICSPinSupport
Definition: dvb_ics.h:52
Definition: dvb_ics.h:49
int len
Definition: mh5gate.c:66
BOOLEAN audio_active
Definition: dvb_ics.h:80
int32_t S32BIT
Definition: techtype.h:98
S_ICSPidInfo * pid_info
Definition: dvb_ics.h:98
Definition: dvb_ics.h:48
uint16_t U16BIT
Definition: techtype.h:95
System Wide Global Technical Data Type Definitions.
Definition: mg_png.c:52
U16BIT PID
Definition: dvb_ics.h:90
E_MhegErr DVB_MhegStreamSetComponents(S_ICSComponents *components)
Set A/V components from IC delivered stream. This function can be called at any time (even while IC d...
U8BIT BOOLEAN
Definition: techtype.h:112
Definition: dvb_ics.h:54
Definition: dvb_ics.h:88
E_MhegErr DVB_MhegStreamStop(void)
This function tells the external application that the IC delivered stream is stopped. Presentation of all stream components (audio, video and/or subtitles) should cease. This function may be called while DVB_MhegHandleStreamData is in progress. In this case DVB_MhegHandleStreamData should return indicating that the entire block has been processed.
uint32_t U32BIT
Definition: techtype.h:97
E_VideoTermination video_termination
Definition: dvb_ics.h:84