Home | History | Annotate | Download | only in dvb
      1 /*
      2  * dmx.h
      3  *
      4  * Copyright (C) 2000 Marcus Metzler <marcus (at) convergence.de>
      5  *                  & Ralph  Metzler <ralph (at) convergence.de>
      6  *                    for convergence integrated media GmbH
      7  *
      8  * This program is free software; you can redistribute it and/or
      9  * modify it under the terms of the GNU Lesser General Public License
     10  * as published by the Free Software Foundation; either version 2.1
     11  * of the License, or (at your option) any later version.
     12  *
     13  * This program is distributed in the hope that it will be useful,
     14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
     15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     16  * GNU General Public License for more details.
     17  *
     18  * You should have received a copy of the GNU Lesser General Public License
     19  * along with this program; if not, write to the Free Software
     20  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
     21  *
     22  */
     23 
     24 #ifndef _DVBDMX_H_
     25 #define _DVBDMX_H_
     26 
     27 #include <asm/types.h>
     28 #include <time.h>
     29 
     30 
     31 #define DMX_FILTER_SIZE 16
     32 
     33 typedef enum
     34 {
     35 	DMX_OUT_DECODER, /* Streaming directly to decoder. */
     36 	DMX_OUT_TAP,     /* Output going to a memory buffer */
     37 			 /* (to be retrieved via the read command).*/
     38 	DMX_OUT_TS_TAP   /* Output multiplexed into a new TS  */
     39 			 /* (to be retrieved by reading from the */
     40 			 /* logical DVR device).                 */
     41 } dmx_output_t;
     42 
     43 
     44 typedef enum
     45 {
     46 	DMX_IN_FRONTEND, /* Input from a front-end device.  */
     47 	DMX_IN_DVR       /* Input from the logical DVR device.  */
     48 } dmx_input_t;
     49 
     50 
     51 typedef enum
     52 {
     53 	DMX_PES_AUDIO0,
     54 	DMX_PES_VIDEO0,
     55 	DMX_PES_TELETEXT0,
     56 	DMX_PES_SUBTITLE0,
     57 	DMX_PES_PCR0,
     58 
     59 	DMX_PES_AUDIO1,
     60 	DMX_PES_VIDEO1,
     61 	DMX_PES_TELETEXT1,
     62 	DMX_PES_SUBTITLE1,
     63 	DMX_PES_PCR1,
     64 
     65 	DMX_PES_AUDIO2,
     66 	DMX_PES_VIDEO2,
     67 	DMX_PES_TELETEXT2,
     68 	DMX_PES_SUBTITLE2,
     69 	DMX_PES_PCR2,
     70 
     71 	DMX_PES_AUDIO3,
     72 	DMX_PES_VIDEO3,
     73 	DMX_PES_TELETEXT3,
     74 	DMX_PES_SUBTITLE3,
     75 	DMX_PES_PCR3,
     76 
     77 	DMX_PES_OTHER
     78 } dmx_pes_type_t;
     79 
     80 #define DMX_PES_AUDIO    DMX_PES_AUDIO0
     81 #define DMX_PES_VIDEO    DMX_PES_VIDEO0
     82 #define DMX_PES_TELETEXT DMX_PES_TELETEXT0
     83 #define DMX_PES_SUBTITLE DMX_PES_SUBTITLE0
     84 #define DMX_PES_PCR      DMX_PES_PCR0
     85 
     86 
     87 typedef struct dmx_filter
     88 {
     89 	__u8  filter[DMX_FILTER_SIZE];
     90 	__u8  mask[DMX_FILTER_SIZE];
     91 	__u8  mode[DMX_FILTER_SIZE];
     92 } dmx_filter_t;
     93 
     94 
     95 struct dmx_sct_filter_params
     96 {
     97 	__u16          pid;
     98 	dmx_filter_t   filter;
     99 	__u32          timeout;
    100 	__u32          flags;
    101 #define DMX_CHECK_CRC       1
    102 #define DMX_ONESHOT         2
    103 #define DMX_IMMEDIATE_START 4
    104 #define DMX_KERNEL_CLIENT   0x8000
    105 };
    106 
    107 
    108 struct dmx_pes_filter_params
    109 {
    110 	__u16          pid;
    111 	dmx_input_t    input;
    112 	dmx_output_t   output;
    113 	dmx_pes_type_t pes_type;
    114 	__u32          flags;
    115 };
    116 
    117 typedef struct dmx_caps {
    118 	__u32 caps;
    119 	int num_decoders;
    120 } dmx_caps_t;
    121 
    122 typedef enum {
    123 	DMX_SOURCE_FRONT0 = 0,
    124 	DMX_SOURCE_FRONT1,
    125 	DMX_SOURCE_FRONT2,
    126 	DMX_SOURCE_FRONT3,
    127 	DMX_SOURCE_DVR0   = 16,
    128 	DMX_SOURCE_DVR1,
    129 	DMX_SOURCE_DVR2,
    130 	DMX_SOURCE_DVR3
    131 } dmx_source_t;
    132 
    133 struct dmx_stc {
    134 	unsigned int num;	/* input : which STC? 0..N */
    135 	unsigned int base;	/* output: divisor for stc to get 90 kHz clock */
    136 	__u64 stc;		/* output: stc in 'base'*90 kHz units */
    137 };
    138 
    139 
    140 #define DMX_START                _IO('o', 41)
    141 #define DMX_STOP                 _IO('o', 42)
    142 #define DMX_SET_FILTER           _IOW('o', 43, struct dmx_sct_filter_params)
    143 #define DMX_SET_PES_FILTER       _IOW('o', 44, struct dmx_pes_filter_params)
    144 #define DMX_SET_BUFFER_SIZE      _IO('o', 45)
    145 #define DMX_GET_PES_PIDS         _IOR('o', 47, __u16[5])
    146 #define DMX_GET_CAPS             _IOR('o', 48, dmx_caps_t)
    147 #define DMX_SET_SOURCE           _IOW('o', 49, dmx_source_t)
    148 #define DMX_GET_STC              _IOWR('o', 50, struct dmx_stc)
    149 
    150 #endif /*_DVBDMX_H_*/
    151