diff options
| author | etobi <git@e-tobi.net> | 2013-09-03 09:48:41 +0200 | 
|---|---|---|
| committer | etobi <git@e-tobi.net> | 2013-09-03 09:48:41 +0200 | 
| commit | ab959d7b4194715870128e616b8e29d4a101e488 (patch) | |
| tree | 61a746231d30817be73416a7d67763fd677a1042 /include | |
| parent | 6b350466c4902c5b137e0efaf1d189128a7f18f5 (diff) | |
| download | linux-dvb-apps-ab959d7b4194715870128e616b8e29d4a101e488.tar.gz | |
Imported Upstream version 1.1.1+rev1207upstream/1.1.1+rev1207
Diffstat (limited to 'include')
| -rw-r--r-- | include/audio.h (renamed from include/linux/dvb/audio.h) | 67 | ||||
| -rw-r--r-- | include/ca.h (renamed from include/linux/dvb/ca.h) | 41 | ||||
| -rw-r--r-- | include/dmx.h (renamed from include/linux/dvb/dmx.h) | 59 | ||||
| -rw-r--r-- | include/frontend.h | 648 | ||||
| -rw-r--r-- | include/linux/dvb/frontend.h | 267 | ||||
| -rw-r--r-- | include/net.h (renamed from include/linux/dvb/net.h) | 24 | ||||
| -rw-r--r-- | include/osd.h (renamed from include/linux/dvb/osd.h) | 55 | ||||
| -rw-r--r-- | include/version.h (renamed from include/linux/dvb/version.h) | 2 | ||||
| -rw-r--r-- | include/video.h (renamed from include/linux/dvb/video.h) | 174 | 
9 files changed, 913 insertions, 424 deletions
| diff --git a/include/linux/dvb/audio.h b/include/audio.h index 58956c3..89412e1 100644 --- a/include/linux/dvb/audio.h +++ b/include/audio.h @@ -1,9 +1,9 @@ -/*  +/*   * audio.h   *   * Copyright (C) 2000 Ralph  Metzler <ralph@convergence.de>   *                  & Marcus Metzler <marcus@convergence.de> -                      for convergence integrated media GmbH + *                    for convergence integrated media GmbH   *   * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU General Lesser Public License @@ -32,39 +32,41 @@  typedef enum { -        AUDIO_SOURCE_DEMUX, /* Select the demux as the main source */  -	AUDIO_SOURCE_MEMORY /* Select internal memory as the main source */  +	AUDIO_SOURCE_DEMUX, /* Select the demux as the main source */ +	AUDIO_SOURCE_MEMORY /* Select internal memory as the main source */  } audio_stream_source_t; -typedef enum {  -	AUDIO_STOPPED,      /* Device is stopped */  -        AUDIO_PLAYING,      /* Device is currently playing */  -	AUDIO_PAUSED        /* Device is paused */  +typedef enum { +	AUDIO_STOPPED,      /* Device is stopped */ +	AUDIO_PLAYING,      /* Device is currently playing */ +	AUDIO_PAUSED        /* Device is paused */  } audio_play_state_t;  typedef enum { -        AUDIO_STEREO, -        AUDIO_MONO_LEFT,  -	AUDIO_MONO_RIGHT  +	AUDIO_STEREO, +	AUDIO_MONO_LEFT, +	AUDIO_MONO_RIGHT, +	AUDIO_MONO, +	AUDIO_STEREO_SWAPPED  } audio_channel_select_t; -typedef struct audio_mixer {  -        unsigned int volume_left; -        unsigned int volume_right; +typedef struct audio_mixer { +	unsigned int volume_left; +	unsigned int volume_right;    // what else do we need? bass, pass-through, ...  } audio_mixer_t; -typedef struct audio_status {  -        int                    AV_sync_state;  /* sync audio and video? */ -        int                    mute_state;     /* audio is muted */  -        audio_play_state_t     play_state;     /* current playback state */ -        audio_stream_source_t  stream_source;  /* current stream source */ -        audio_channel_select_t channel_select; /* currently selected channel */ -        int                    bypass_mode;    /* pass on audio data to */ +typedef struct audio_status { +	int                    AV_sync_state;  /* sync audio and video? */ +	int                    mute_state;     /* audio is muted */ +	audio_play_state_t     play_state;     /* current playback state */ +	audio_stream_source_t  stream_source;  /* current stream source */ +	audio_channel_select_t channel_select; /* currently selected channel */ +	int                    bypass_mode;    /* pass on audio data to */  	audio_mixer_t	       mixer_state;    /* current mixer state */  } audio_status_t;                              /* separate decoder hardware */ @@ -74,8 +76,8 @@ struct audio_karaoke{  /* if Vocal1 or Vocal2 are non-zero, they get mixed  */  	int vocal1;    /* into left and right t at 70% each */  	int vocal2;    /* if both, Vocal1 and Vocal2 are non-zero, Vocal1 gets*/  	int melody;    /* mixed into the left channel and */ -                       /* Vocal2 into the right channel at 100% each. */ -                       /* if Melody is non-zero, the melody channel gets mixed*/ +		       /* Vocal2 into the right channel at 100% each. */ +		       /* if Melody is non-zero, the melody channel gets mixed*/  } audio_karaoke_t;     /* into left and right  */ @@ -88,7 +90,7 @@ typedef uint16_t audio_attributes_t;  /*    7- 6 Quantization / DRC (mpeg audio: 1=DRC exists)(lpcm: 0=16bit,  */  /*    5- 4 Sample frequency fs (0=48kHz, 1=96kHz) */  /*    2- 0 number of audio channels (n+1 channels) */ -  +  /* for GET_CAPABILITIES and SET_FORMAT, the latter should only set one bit */  #define AUDIO_CAP_DTS    1 @@ -101,7 +103,7 @@ typedef uint16_t audio_attributes_t;  #define AUDIO_CAP_SDDS 128  #define AUDIO_CAP_AC3  256 -#define AUDIO_STOP                 _IO('o', 1)  +#define AUDIO_STOP                 _IO('o', 1)  #define AUDIO_PLAY                 _IO('o', 2)  #define AUDIO_PAUSE                _IO('o', 3)  #define AUDIO_CONTINUE             _IO('o', 4) @@ -121,5 +123,18 @@ typedef uint16_t audio_attributes_t;  #define AUDIO_SET_ATTRIBUTES       _IOW('o', 17, audio_attributes_t)  #define AUDIO_SET_KARAOKE          _IOW('o', 18, audio_karaoke_t) -#endif /* _DVBAUDIO_H_ */ +/** + * AUDIO_GET_PTS + * + * Read the 33 bit presentation time stamp as defined + * in ITU T-REC-H.222.0 / ISO/IEC 13818-1. + * + * The PTS should belong to the currently played + * frame if possible, but may also be a value close to it + * like the PTS of the last decoded frame or the last PTS + * extracted by the PES parser. + */ +#define AUDIO_GET_PTS              _IOR('o', 19, __u64) +#define AUDIO_BILINGUAL_CHANNEL_SELECT _IO('o', 20) +#endif /* _DVBAUDIO_H_ */ diff --git a/include/linux/dvb/ca.h b/include/ca.h index 026e5c3..c18537f 100644 --- a/include/linux/dvb/ca.h +++ b/include/ca.h @@ -1,9 +1,9 @@ -/*  +/*   * ca.h   *   * Copyright (C) 2000 Ralph  Metzler <ralph@convergence.de>   *                  & Marcus Metzler <marcus@convergence.de> -                      for convergence integrated media GmbH + *                    for convergence integrated media GmbH   *   * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU General Lesser Public License @@ -27,16 +27,16 @@  /* slot interface types and info */  typedef struct ca_slot_info { -        int num;               /* slot number */ +	int num;               /* slot number */ -        int type;              /* CA interface this slot supports */ +	int type;              /* CA interface this slot supports */  #define CA_CI            1     /* CI high level interface */  #define CA_CI_LINK       2     /* CI link layer level interface */  #define CA_CI_PHYS       4     /* CI physical layer level interface */  #define CA_DESCR         8     /* built-in descrambler */  #define CA_SC          128     /* simple smart card interface */ -        unsigned int flags; +	unsigned int flags;  #define CA_CI_MODULE_PRESENT 1 /* module (or card) inserted */  #define CA_CI_MODULE_READY   2  } ca_slot_info_t; @@ -45,37 +45,37 @@ typedef struct ca_slot_info {  /* descrambler types and info */  typedef struct ca_descr_info { -        unsigned int num;          /* number of available descramblers (keys) */ -        unsigned int type;         /* type of supported scrambling system */ +	unsigned int num;          /* number of available descramblers (keys) */ +	unsigned int type;         /* type of supported scrambling system */  #define CA_ECD           1  #define CA_NDS           2  #define CA_DSS           4  } ca_descr_info_t;  typedef struct ca_caps { -        unsigned int slot_num;     /* total number of CA card and module slots */ -        unsigned int slot_type;    /* OR of all supported types */ -        unsigned int descr_num;    /* total number of descrambler slots (keys) */ -        unsigned int descr_type;   /* OR of all supported types */ +	unsigned int slot_num;     /* total number of CA card and module slots */ +	unsigned int slot_type;    /* OR of all supported types */ +	unsigned int descr_num;    /* total number of descrambler slots (keys) */ +	unsigned int descr_type;   /* OR of all supported types */  } ca_caps_t;  /* a message to/from a CI-CAM */  typedef struct ca_msg { -        unsigned int index; -        unsigned int type; -        unsigned int length; -        unsigned char msg[256]; +	unsigned int index; +	unsigned int type; +	unsigned int length; +	unsigned char msg[256];  } ca_msg_t;  typedef struct ca_descr { -        unsigned int index; -        unsigned int parity;	/* 0 == even, 1 == odd */ -        unsigned char cw[8]; +	unsigned int index; +	unsigned int parity;	/* 0 == even, 1 == odd */ +	unsigned char cw[8];  } ca_descr_t;  typedef struct ca_pid { -        unsigned int pid; -        int index;		/* -1 == disable*/ +	unsigned int pid; +	int index;		/* -1 == disable*/  } ca_pid_t;  #define CA_RESET          _IO('o', 128) @@ -88,4 +88,3 @@ typedef struct ca_pid {  #define CA_SET_PID        _IOW('o', 135, ca_pid_t)  #endif - diff --git a/include/linux/dvb/dmx.h b/include/dmx.h index 62e6217..c6a2353 100644 --- a/include/linux/dvb/dmx.h +++ b/include/dmx.h @@ -1,9 +1,9 @@ -/*  +/*   * dmx.h   *   * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de>   *                  & Ralph  Metzler <ralph@convergence.de> -                      for convergence integrated media GmbH + *                    for convergence integrated media GmbH   *   * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU Lesser General Public License @@ -38,10 +38,10 @@ typedef enum  {  	DMX_OUT_DECODER, /* Streaming directly to decoder. */  	DMX_OUT_TAP,     /* Output going to a memory buffer */ -	                 /* (to be retrieved via the read command).*/ +			 /* (to be retrieved via the read command).*/  	DMX_OUT_TS_TAP   /* Output multiplexed into a new TS  */ -	                 /* (to be retrieved by reading from the */ -	                 /* logical DVR device).                 */ +			 /* (to be retrieved by reading from the */ +			 /* logical DVR device).                 */  } dmx_output_t; @@ -54,25 +54,25 @@ typedef enum  typedef enum  { -        DMX_PES_AUDIO0, +	DMX_PES_AUDIO0,  	DMX_PES_VIDEO0,  	DMX_PES_TELETEXT0,  	DMX_PES_SUBTITLE0,  	DMX_PES_PCR0, -        DMX_PES_AUDIO1, +	DMX_PES_AUDIO1,  	DMX_PES_VIDEO1,  	DMX_PES_TELETEXT1,  	DMX_PES_SUBTITLE1,  	DMX_PES_PCR1, -        DMX_PES_AUDIO2, +	DMX_PES_AUDIO2,  	DMX_PES_VIDEO2,  	DMX_PES_TELETEXT2,  	DMX_PES_SUBTITLE2,  	DMX_PES_PCR2, -        DMX_PES_AUDIO3, +	DMX_PES_AUDIO3,  	DMX_PES_VIDEO3,  	DMX_PES_TELETEXT3,  	DMX_PES_SUBTITLE3, @@ -88,20 +88,6 @@ typedef enum  #define DMX_PES_PCR      DMX_PES_PCR0 -typedef enum -{ -        DMX_SCRAMBLING_EV, -        DMX_FRONTEND_EV -} dmx_event_t; - - -typedef enum -{ -	DMX_SCRAMBLING_OFF, -	DMX_SCRAMBLING_ON -} dmx_scrambling_status_t; - -  typedef struct dmx_filter  {  	__u8  filter[DMX_FILTER_SIZE]; @@ -112,10 +98,10 @@ typedef struct dmx_filter  struct dmx_sct_filter_params  { -	__u16            pid; +	__u16          pid;  	dmx_filter_t   filter; -	__u32            timeout; -	__u32            flags; +	__u32          timeout; +	__u32          flags;  #define DMX_CHECK_CRC       1  #define DMX_ONESHOT         2  #define DMX_IMMEDIATE_START 4 @@ -125,27 +111,16 @@ struct dmx_sct_filter_params  struct dmx_pes_filter_params  { -	__u16            pid; +	__u16          pid;  	dmx_input_t    input;  	dmx_output_t   output;  	dmx_pes_type_t pes_type; -	__u32            flags; -}; - - -struct dmx_event -{ -	dmx_event_t         event; -	time_t              timeStamp; -	union -	{ -		dmx_scrambling_status_t scrambling; -	} u; +	__u32          flags;  };  typedef struct dmx_caps {  	__u32 caps; -	int num_decoders;  +	int num_decoders;  } dmx_caps_t;  typedef enum { @@ -166,16 +141,14 @@ struct dmx_stc {  }; -#define DMX_START                _IO('o', 41)  +#define DMX_START                _IO('o', 41)  #define DMX_STOP                 _IO('o', 42)  #define DMX_SET_FILTER           _IOW('o', 43, struct dmx_sct_filter_params)  #define DMX_SET_PES_FILTER       _IOW('o', 44, struct dmx_pes_filter_params)  #define DMX_SET_BUFFER_SIZE      _IO('o', 45) -#define DMX_GET_EVENT            _IOR('o', 46, struct dmx_event)  #define DMX_GET_PES_PIDS         _IOR('o', 47, __u16[5])  #define DMX_GET_CAPS             _IOR('o', 48, dmx_caps_t)  #define DMX_SET_SOURCE           _IOW('o', 49, dmx_source_t)  #define DMX_GET_STC              _IOWR('o', 50, struct dmx_stc)  #endif /*_DVBDMX_H_*/ - diff --git a/include/frontend.h b/include/frontend.h new file mode 100644 index 0000000..71abc24 --- /dev/null +++ b/include/frontend.h @@ -0,0 +1,648 @@ +/* + * frontend.h + * + * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de> + *		    Ralph  Metzler <ralph@convergence.de> + *		    Holger Waechtler <holger@convergence.de> + *		    Andre Draszik <ad@convergence.de> + *		    for convergence integrated media GmbH + * + * Copyright (C) Manu Abraham <abraham.manu@gmail.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public License + * as published by the Free Software Foundation; either version 2.1 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. + * + */ + +#ifndef _DVBFRONTEND_H_ +#define _DVBFRONTEND_H_ + +#include <asm/types.h> + + +typedef enum fe_type { +	FE_QPSK, +	FE_QAM, +	FE_OFDM, +	FE_ATSC +} fe_type_t; + + +typedef enum fe_caps { +	FE_IS_STUPID			= 0, +	FE_CAN_INVERSION_AUTO		= 0x1, +	FE_CAN_FEC_1_2			= 0x2, +	FE_CAN_FEC_2_3			= 0x4, +	FE_CAN_FEC_3_4			= 0x8, +	FE_CAN_FEC_4_5			= 0x10, +	FE_CAN_FEC_5_6			= 0x20, +	FE_CAN_FEC_6_7			= 0x40, +	FE_CAN_FEC_7_8			= 0x80, +	FE_CAN_FEC_8_9			= 0x100, +	FE_CAN_FEC_AUTO			= 0x200, +	FE_CAN_QPSK			= 0x400, +	FE_CAN_QAM_16			= 0x800, +	FE_CAN_QAM_32			= 0x1000, +	FE_CAN_QAM_64			= 0x2000, +	FE_CAN_QAM_128			= 0x4000, +	FE_CAN_QAM_256			= 0x8000, +	FE_CAN_QAM_AUTO			= 0x10000, +	FE_CAN_TRANSMISSION_MODE_AUTO	= 0x20000, +	FE_CAN_BANDWIDTH_AUTO		= 0x40000, +	FE_CAN_GUARD_INTERVAL_AUTO	= 0x80000, +	FE_CAN_HIERARCHY_AUTO		= 0x100000, +	FE_CAN_8VSB			= 0x200000, +	FE_CAN_16VSB			= 0x400000, +	FE_NEEDS_BENDING		= 0x20000000, // not supported anymore, don't use (frontend requires frequency bending) +	FE_CAN_RECOVER			= 0x40000000, // frontend can recover from a cable unplug automatically +	FE_CAN_MUTE_TS			= 0x80000000  // frontend can stop spurious TS data output +} fe_caps_t; + + +struct dvb_frontend_info { +	char       name[128]; +	fe_type_t  type; +	__u32      frequency_min; +	__u32      frequency_max; +	__u32      frequency_stepsize; +	__u32      frequency_tolerance; +	__u32      symbol_rate_min; +	__u32      symbol_rate_max; +	__u32      symbol_rate_tolerance;	/* ppm */ +	__u32      notifier_delay;		/* DEPRECATED */ +	fe_caps_t  caps; +}; + + +/** + *  Check out the DiSEqC bus spec available on http://www.eutelsat.org/ for + *  the meaning of this struct... + */ +struct dvb_diseqc_master_cmd { +	__u8 msg [6];	/*  { framing, address, command, data [3] } */ +	__u8 msg_len;	/*  valid values are 3...6  */ +}; + + +struct dvb_diseqc_slave_reply { +	__u8 msg [4];	/*  { framing, data [3] } */ +	__u8 msg_len;	/*  valid values are 0...4, 0 means no msg  */ +	int  timeout;	/*  return from ioctl after timeout ms with */ +};			/*  errorcode when no message was received  */ + + +typedef enum fe_sec_voltage { +	SEC_VOLTAGE_13, +	SEC_VOLTAGE_18, +	SEC_VOLTAGE_OFF +} fe_sec_voltage_t; + + +typedef enum fe_sec_tone_mode { +	SEC_TONE_ON, +	SEC_TONE_OFF +} fe_sec_tone_mode_t; + + +typedef enum fe_sec_mini_cmd { +	SEC_MINI_A, +	SEC_MINI_B +} fe_sec_mini_cmd_t; + + +typedef enum fe_status { +	FE_HAS_SIGNAL	= 0x01,   /*  found something above the noise level */ +	FE_HAS_CARRIER	= 0x02,   /*  found a DVB signal  */ +	FE_HAS_VITERBI	= 0x04,   /*  FEC is stable  */ +	FE_HAS_SYNC	= 0x08,   /*  found sync bytes  */ +	FE_HAS_LOCK	= 0x10,   /*  everything's working... */ +	FE_TIMEDOUT	= 0x20,   /*  no lock within the last ~2 seconds */ +	FE_REINIT	= 0x40    /*  frontend was reinitialized,  */ +} fe_status_t;			  /*  application is recommended to reset */ +				  /*  DiSEqC, tone and parameters */ + +typedef enum fe_spectral_inversion { +	INVERSION_OFF, +	INVERSION_ON, +	INVERSION_AUTO +} fe_spectral_inversion_t; + + +typedef enum fe_code_rate { +	FEC_NONE = 0, +	FEC_1_2, +	FEC_2_3, +	FEC_3_4, +	FEC_4_5, +	FEC_5_6, +	FEC_6_7, +	FEC_7_8, +	FEC_8_9, +	FEC_AUTO +} fe_code_rate_t; + + +typedef enum fe_modulation { +	QPSK, +	QAM_16, +	QAM_32, +	QAM_64, +	QAM_128, +	QAM_256, +	QAM_AUTO, +	VSB_8, +	VSB_16 +} fe_modulation_t; + +typedef enum fe_transmit_mode { +	TRANSMISSION_MODE_2K, +	TRANSMISSION_MODE_8K, +	TRANSMISSION_MODE_AUTO +} fe_transmit_mode_t; + +typedef enum fe_bandwidth { +	BANDWIDTH_8_MHZ, +	BANDWIDTH_7_MHZ, +	BANDWIDTH_6_MHZ, +	BANDWIDTH_AUTO +} fe_bandwidth_t; + + +typedef enum fe_guard_interval { +	GUARD_INTERVAL_1_32, +	GUARD_INTERVAL_1_16, +	GUARD_INTERVAL_1_8, +	GUARD_INTERVAL_1_4, +	GUARD_INTERVAL_AUTO +} fe_guard_interval_t; + + +typedef enum fe_hierarchy { +	HIERARCHY_NONE, +	HIERARCHY_1, +	HIERARCHY_2, +	HIERARCHY_4, +	HIERARCHY_AUTO +} fe_hierarchy_t; + + +struct dvb_qpsk_parameters { +	__u32		symbol_rate;  /* symbol rate in Symbols per second */ +	fe_code_rate_t	fec_inner;    /* forward error correction (see above) */ +}; + +struct dvb_qam_parameters { +	__u32		symbol_rate; /* symbol rate in Symbols per second */ +	fe_code_rate_t	fec_inner;   /* forward error correction (see above) */ +	fe_modulation_t	modulation;  /* modulation type (see above) */ +}; + +struct dvb_vsb_parameters { +	fe_modulation_t	modulation;  /* modulation type (see above) */ +}; + +struct dvb_ofdm_parameters { +	fe_bandwidth_t      bandwidth; +	fe_code_rate_t      code_rate_HP;  /* high priority stream code rate */ +	fe_code_rate_t      code_rate_LP;  /* low priority stream code rate */ +	fe_modulation_t     constellation; /* modulation type (see above) */ +	fe_transmit_mode_t  transmission_mode; +	fe_guard_interval_t guard_interval; +	fe_hierarchy_t      hierarchy_information; +}; + + +struct dvb_frontend_parameters { +	__u32 frequency;     /* (absolute) frequency in Hz for QAM/OFDM/ATSC */ +			     /* intermediate frequency in kHz for QPSK */ +	fe_spectral_inversion_t inversion; +	union { +		struct dvb_qpsk_parameters qpsk; +		struct dvb_qam_parameters  qam; +		struct dvb_ofdm_parameters ofdm; +		struct dvb_vsb_parameters vsb; +	} u; +}; + + +/** + * When set, this flag will disable any zigzagging or other "normal" tuning + * behaviour. Additionally, there will be no automatic monitoring of the lock + * status, and hence no frontend events will be generated. If a frontend device + * is closed, this flag will be automatically turned off when the device is + * reopened read-write. + */ +#define FE_TUNE_MODE_ONESHOT 0x01 + + +#define FE_GET_INFO		   _IOR('o', 61, struct dvb_frontend_info) + +#define FE_DISEQC_RESET_OVERLOAD   _IO('o', 62) +#define FE_DISEQC_SEND_MASTER_CMD  _IOW('o', 63, struct dvb_diseqc_master_cmd) +#define FE_DISEQC_RECV_SLAVE_REPLY _IOR('o', 64, struct dvb_diseqc_slave_reply) +#define FE_DISEQC_SEND_BURST       _IO('o', 65)  /* fe_sec_mini_cmd_t */ + +#define FE_SET_TONE		   _IO('o', 66)  /* fe_sec_tone_mode_t */ +#define FE_SET_VOLTAGE		   _IO('o', 67)  /* fe_sec_voltage_t */ +#define FE_ENABLE_HIGH_LNB_VOLTAGE _IO('o', 68)  /* int */ + +#define FE_READ_STATUS		   _IOR('o', 69, fe_status_t) +#define FE_READ_BER		   _IOR('o', 70, __u32) +#define FE_READ_SIGNAL_STRENGTH    _IOR('o', 71, __u16) +#define FE_READ_SNR		   _IOR('o', 72, __u16) +#define FE_READ_UNCORRECTED_BLOCKS _IOR('o', 73, __u32) + +#define FE_SET_FRONTEND		   _IOW('o', 76, struct dvb_frontend_parameters) +#define FE_GET_FRONTEND		   _IOR('o', 77, struct dvb_frontend_parameters) +#define FE_SET_FRONTEND_TUNE_MODE  _IO('o', 81) /* unsigned int */ + +#define FE_DISHNETWORK_SEND_LEGACY_CMD _IO('o', 80) /* unsigned int */ + +/* + * References: + * DVB-S : EN 300 421 + * DVB-S2: EN 302 307, TR 102 376, EN 301 210 + * DVB-C : EN 300 429 + * DVB-T : EN 300 744 + * DVB-H : EN 300 304 + * ATSC  : A/53A + */ + +/* + * Delivery Systems + * needs to set/queried for multistandard frontends + */ +enum dvbfe_delsys { +	DVBFE_DELSYS_DVBS		= (1 <<  0), +	DVBFE_DELSYS_DSS		= (1 <<  1), +	DVBFE_DELSYS_DVBS2		= (1 <<  2), +	DVBFE_DELSYS_DVBC		= (1 <<  3), +	DVBFE_DELSYS_DVBT		= (1 <<  4), +	DVBFE_DELSYS_DVBH		= (1 <<  5), +	DVBFE_DELSYS_ATSC		= (1 <<  6), +	DVBFE_DELSYS_DUMMY		= (1 << 31) +}; +#define DVBFE_GET_DELSYS		_IOR('o', 82, enum dvbfe_delsys) +#define DVBFE_SET_DELSYS		_IOW('o', 87, enum dvbfe_delsys) + +/* Modulation types			*/ +enum dvbfe_modulation { +	DVBFE_MOD_NONE			= (0 <<  0), +	DVBFE_MOD_BPSK			= (1 <<  0), +	DVBFE_MOD_QPSK			= (1 <<  1), +	DVBFE_MOD_OQPSK			= (1 <<  2), +	DVBFE_MOD_8PSK			= (1 <<  3), +	DVBFE_MOD_16APSK		= (1 <<  4), +	DVBFE_MOD_32APSK		= (1 <<  5), +	DVBFE_MOD_QAM4			= (1 <<  6), +	DVBFE_MOD_QAM16			= (1 <<  7), +	DVBFE_MOD_QAM32			= (1 <<  8), +	DVBFE_MOD_QAM64			= (1 <<  9), +	DVBFE_MOD_QAM128		= (1 << 10), +	DVBFE_MOD_QAM256		= (1 << 11), +	DVBFE_MOD_QAM512		= (1 << 12), +	DVBFE_MOD_QAM1024		= (1 << 13), +	DVBFE_MOD_QAMAUTO		= (1 << 14), +	DVBFE_MOD_OFDM			= (1 << 15), +	DVBFE_MOD_COFDM			= (1 << 16), +	DVBFE_MOD_VSB8			= (1 << 17), +	DVBFE_MOD_VSB16			= (1 << 18), +	DVBFE_MOD_AUTO			= (1 << 31) +}; + +/* + * Convolution Code Rate (Viterbi Inner Code Rate) + * DVB-S2 uses LDPC. Information on LDPC can be found at + * http://www.ldpc-codes.com + */ +enum dvbfe_fec { +	DVBFE_FEC_NONE			= (0 <<  0), +	DVBFE_FEC_1_4			= (1 <<  0), +	DVBFE_FEC_1_3			= (1 <<  1), +	DVBFE_FEC_2_5			= (1 <<  2), +	DVBFE_FEC_1_2			= (1 <<  3), +	DVBFE_FEC_3_5			= (1 <<  4), +	DVBFE_FEC_2_3			= (1 <<  5), +	DVBFE_FEC_3_4			= (1 <<  6), +	DVBFE_FEC_4_5			= (1 <<  7), +	DVBFE_FEC_5_6			= (1 <<  8), +	DVBFE_FEC_6_7			= (1 <<  9), +	DVBFE_FEC_7_8			= (1 << 10), +	DVBFE_FEC_8_9			= (1 << 11), +	DVBFE_FEC_9_10			= (1 << 12), +	DVBFE_FEC_AUTO			= (1 << 31) +}; + +/* Frontend Inversion (I/Q Swap)	*/ +enum dvbfe_inversion { +	DVBFE_INVERSION_OFF		= 0, +	DVBFE_INVERSION_ON		= 1, +	DVBFE_INVERSION_AUTO		= 2 +}; + +/* DVB-S parameters			*/ +struct dvbs_params { +	__u32				symbol_rate; + +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; +}; + +/* DSS parameters			*/ +struct dss_params { +	__u32				symbol_rate; + +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; +}; + +/* + * Rolloff Rate (Nyquist Filter Rolloff) + * NOTE: DVB-S2 has rates of 0.20, 0.25, 0.35 + * Values are x100 + * Applies to DVB-S2 + */ +enum dvbfe_rolloff { +	DVBFE_ROLLOFF_35		= 0, +	DVBFE_ROLLOFF_25		= 1, +	DVBFE_ROLLOFF_20		= 2, +	DVBFE_ROLLOFF_UNKNOWN		= 3 +}; + +/* DVB-S2 parameters			*/ +struct dvbs2_params { +	__u32				symbol_rate; + +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; + +	/* Informational fields only	*/ +	enum dvbfe_rolloff		rolloff; + +	__u8				matype_1; +	__u8				matype_2; +	__u8				upl_1; +	__u8				upl_2; +	__u8				dfl_1; +	__u8				dfl_2; +	__u8				sync; +	__u8				syncd_1; +	__u8				syncd_2; + +	__u8				pad[32]; +}; + +/* DVB-C parameters			*/ +struct dvbc_params { +	__u32				symbol_rate; +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; +}; + +/* DVB-T Channel bandwidth		*/ +enum dvbfe_bandwidth { +	DVBFE_BANDWIDTH_8_MHZ		= (1 <<  0), +	DVBFE_BANDWIDTH_7_MHZ		= (1 <<  1), +	DVBFE_BANDWIDTH_6_MHZ		= (1 <<  2), +	DVBFE_BANDWIDTH_5_MHZ		= (1 <<  3), +	DVBFE_BANDWIDTH_AUTO		= (1 << 31) +}; + +/* DVB-T/DVB-H transmission mode	*/ +enum dvbfe_transmission_mode { +	DVBFE_TRANSMISSION_MODE_2K	= (1 <<  0), +	DVBFE_TRANSMISSION_MODE_4K	= (1 <<  1), +	DVBFE_TRANSMISSION_MODE_8K	= (1 <<  2), +	DVBFE_TRANSMISSION_MODE_AUTO	= (1 << 31) +}; + +/* DVB-T/DVB-H Guard interval		*/ +enum dvbfe_guard_interval { +	DVBFE_GUARD_INTERVAL_1_32	= (1 <<  1), +	DVBFE_GUARD_INTERVAL_1_16	= (1 <<  2), +	DVBFE_GUARD_INTERVAL_1_8	= (1 <<  3), +	DVBFE_GUARD_INTERVAL_1_4	= (1 <<  4), +	DVBFE_GUARD_INTERVAL_AUTO	= (1 << 31) +}; + +/* DVB-T/DVB-H Hierarchial modulation	*/ +enum dvbfe_hierarchy { +	DVBFE_HIERARCHY_OFF		= (1 <<  0), +	DVBFE_HIERARCHY_ON		= (1 <<  1), +	DVBFE_HIERARCHY_AUTO		= (1 <<  2) +}; + +/* DVB-T/DVB-H Rolloff's		*/ +enum dvbfe_alpha { +	DVBFE_ALPHA_1			= (1 <<  0), +	DVBFE_ALPHA_2			= (1 <<  1), +	DVBFE_ALPHA_4			= (1 <<  2) +}; + +/* Stream priority (Hierachial coding)	*/ +enum dvbfe_stream_priority { +	DVBFE_STREAM_PRIORITY_HP	= (0 << 0), +	DVBFE_STREAM_PRIORITY_LP	= (1 << 0) +}; + +/* DVB-T parameters			*/ +struct dvbt_params { +	enum dvbfe_modulation		constellation; +	enum dvbfe_bandwidth		bandwidth; +	enum dvbfe_fec			code_rate_HP; +	enum dvbfe_fec			code_rate_LP; +	enum dvbfe_transmission_mode	transmission_mode; +	enum dvbfe_guard_interval	guard_interval; +	enum dvbfe_hierarchy		hierarchy; +	enum dvbfe_alpha		alpha; +	enum dvbfe_stream_priority	priority; + +	__u8				pad[32]; +}; + +/* DVB-H Interleaver type		*/ +enum dvbfe_interleaver { +	DVBFE_INTERLEAVER_NATIVE	= (1 <<  0), +	DVBFE_INTERLEAVER_INDEPTH	= (1 <<  1), +	DVBFE_INTERLEAVER_AUTO		= (1 << 31) +}; + +/* DVB-H MPE-FEC Indicator		*/ +enum dvbfe_mpefec { +	DVBFE_MPEFEC_OFF		= (1 <<  0), +	DVBFE_MPEFEC_ON			= (1 <<  1) +}; + +/* DVB-H Timeslicing Indicator		*/ +enum dvbfe_timeslicing { +	DVBFE_TIMESLICING_OFF		= (1 <<  0), +	DVBFE_TIMESLICING_ON		= (1 <<  1) +}; + +/* DVB-H parameters			*/ +struct dvbh_params { +	enum dvbfe_modulation		constellation; +	enum dvbfe_fec			code_rate_HP; +	enum dvbfe_fec			code_rate_LP; +	enum dvbfe_transmission_mode	transmission_mode; +	enum dvbfe_guard_interval	guard_interval; +	enum dvbfe_hierarchy		hierarchy; +	enum dvbfe_alpha		alpha; +	enum dvbfe_interleaver		interleaver; +	enum dvbfe_mpefec		mpefec; +	enum dvbfe_timeslicing		timeslicing; +	enum dvbfe_stream_priority	priority; + +	__u32				bandwidth; +	__u8				pad[32]; +}; + +/* ATSC parameters			*/ +struct atsc_params { +	enum dvbfe_modulation		modulation; + +	__u8				pad[32]; +}; + +/* DVB Frontend Tuning Parameters	*/ +struct dvbfe_params { +	__u32				frequency; +	enum fe_spectral_inversion	inversion; +	enum dvbfe_delsys		delivery; + +	__u8				pad[32]; + +	union { +		struct dvbs_params	dvbs; +		struct dss_params	dss; +		struct dvbs2_params	dvbs2; +		struct dvbc_params	dvbc; +		struct dvbt_params	dvbt; +		struct dvbh_params	dvbh; +		struct atsc_params	atsc; + +		__u8			pad[128]; +	} delsys; +}; +#define DVBFE_SET_PARAMS		_IOW('o', 83, struct dvbfe_params) +#define DVBFE_GET_PARAMS		_IOWR('o', 84, struct dvbfe_params) + +/* DVB-S capability bitfields		*/ +struct dvbfe_dvbs_info { +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; +}; + +/* DSS capability bitfields		*/ +struct dvbfe_dss_info { +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; +}; + +/* DVB-S2 capability bitfields		*/ +struct dvbfe_dvbs2_info { +	enum dvbfe_modulation		modulation; +	enum dvbfe_fec			fec; + +	__u8				pad[32]; +}; + +/* DVB-C capability bitfields		*/ +struct dvbfe_dvbc_info { +	enum dvbfe_modulation		modulation; +}; + +/* DVB-T capability bitfields		*/ +struct dvbfe_dvbt_info { +	enum dvbfe_modulation		modulation; +	enum dvbfe_stream_priority	stream_priority; + +	__u8				pad[32]; +}; + +/* DVB-H capability bitfields		*/ +struct dvbfe_dvbh_info { +	enum dvbfe_modulation		modulation; +	enum dvbfe_stream_priority	stream_priority; + +	__u8				pad[32]; +}; + +/* ATSC capability bitfields		*/ +struct dvbfe_atsc_info { +	enum dvbfe_modulation		modulation; + +	__u8				pad[32]; +}; + +/* DVB Frontend related Information	*/ +struct dvbfe_info { +	char				name[128]; + +	union { +		struct dvbfe_dvbs_info	dvbs; +		struct dvbfe_dss_info	dss; +		struct dvbfe_dvbs2_info	dvbs2; +		struct dvbfe_dvbc_info	dvbc; +		struct dvbfe_dvbt_info	dvbt; +		struct dvbfe_dvbh_info	dvbh; +		struct dvbfe_atsc_info	atsc; + +		__u8			pad[128]; +	} delsys; + +	__u32				frequency_min; +	__u32				frequency_max; +	__u32				frequency_step; +	__u32				frequency_tolerance; +	__u32				symbol_rate_min; +	__u32				symbol_rate_max; +	__u32				symbol_rate_tolerance; + +	enum fe_spectral_inversion	inversion; + +	__u8				pad[128]; +}; +#define DVBFE_GET_INFO			_IOR('o', 85, struct dvbfe_info) + +enum dvbfe_status { +	DVBFE_HAS_SIGNAL		= (1 <<  0),	/*  something above noise floor	*/ +	DVBFE_HAS_CARRIER		= (1 <<  1),	/*  Signal found		*/ +	DVBFE_HAS_VITERBI		= (1 <<  2),	/*  FEC is stable		*/ +	DVBFE_HAS_SYNC			= (1 <<  3),	/*  SYNC found			*/ +	DVBFE_HAS_LOCK			= (1 <<  4),	/*  OK ..			*/ +	DVBFE_TIMEDOUT			= (1 <<  5),	/*  no lock in last ~2 s	*/ +	DVBFE_STATUS_DUMMY		= (1 << 31) +}; + +/* DVB Frontend events			*/ +struct dvbfe_events { +	enum dvbfe_status		status; + +	__u8				pad[32]; +}; + +struct dvb_frontend_event { +	fe_status_t status; +	struct dvb_frontend_parameters parameters; +}; +#define FE_GET_EVENT		   _IOR('o', 78, struct dvb_frontend_event) + +struct dvbfe_event { +	struct dvbfe_events fe_events; +	struct dvbfe_params fe_params; +}; +#define DVBFE_GET_EVENT			_IOR('o', 86, struct dvbfe_event) + +#endif /*_DVBFRONTEND_H_*/ diff --git a/include/linux/dvb/frontend.h b/include/linux/dvb/frontend.h deleted file mode 100644 index d41df70..0000000 --- a/include/linux/dvb/frontend.h +++ /dev/null @@ -1,267 +0,0 @@ -/* - * frontend.h - * - * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de> - *		    Ralph  Metzler <ralph@convergence.de> - *		    Holger Waechtler <holger@convergence.de> - *		    Andre Draszik <ad@convergence.de> - *		    for convergence integrated media GmbH - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU Lesser General Public License - * as published by the Free Software Foundation; either version 2.1 - * of the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. - * - */ - -#ifndef _DVBFRONTEND_H_ -#define _DVBFRONTEND_H_ - -#include <asm/types.h> - - -typedef enum fe_type { -	FE_QPSK, -	FE_QAM, -	FE_OFDM, -	FE_ATSC -} fe_type_t; - - -typedef enum fe_caps { -	FE_IS_STUPID			= 0, -	FE_CAN_INVERSION_AUTO		= 0x1, -	FE_CAN_FEC_1_2			= 0x2, -	FE_CAN_FEC_2_3			= 0x4, -	FE_CAN_FEC_3_4			= 0x8, -	FE_CAN_FEC_4_5			= 0x10, -	FE_CAN_FEC_5_6			= 0x20, -	FE_CAN_FEC_6_7			= 0x40, -	FE_CAN_FEC_7_8			= 0x80, -	FE_CAN_FEC_8_9			= 0x100, -	FE_CAN_FEC_AUTO			= 0x200, -	FE_CAN_QPSK			= 0x400, -	FE_CAN_QAM_16			= 0x800, -	FE_CAN_QAM_32			= 0x1000, -	FE_CAN_QAM_64			= 0x2000, -	FE_CAN_QAM_128			= 0x4000, -	FE_CAN_QAM_256			= 0x8000, -	FE_CAN_QAM_AUTO			= 0x10000, -	FE_CAN_TRANSMISSION_MODE_AUTO	= 0x20000, -	FE_CAN_BANDWIDTH_AUTO		= 0x40000, -	FE_CAN_GUARD_INTERVAL_AUTO	= 0x80000, -	FE_CAN_HIERARCHY_AUTO		= 0x100000, -	FE_CAN_8VSB			= 0x200000, -	FE_CAN_16VSB			= 0x400000, -	FE_NEEDS_BENDING		= 0x20000000, // not supported anymore, don't use (frontend requires frequency bending) -	FE_CAN_RECOVER			= 0x40000000, // frontend can recover from a cable unplug automatically -	FE_CAN_MUTE_TS			= 0x80000000  // frontend can stop spurious TS data output -} fe_caps_t; - - -struct dvb_frontend_info { -	char       name[128]; -	fe_type_t  type; -	__u32      frequency_min; -	__u32      frequency_max; -	__u32      frequency_stepsize; -	__u32      frequency_tolerance; -	__u32      symbol_rate_min; -	__u32      symbol_rate_max; -	__u32      symbol_rate_tolerance;	/* ppm */ -	__u32      notifier_delay;		/* DEPRECATED */ -	fe_caps_t  caps; -}; - - -/** - *  Check out the DiSEqC bus spec available on http://www.eutelsat.org/ for - *  the meaning of this struct... - */ -struct dvb_diseqc_master_cmd { -	__u8 msg [6];	/*  { framing, address, command, data [3] } */ -	__u8 msg_len;	/*  valid values are 3...6  */ -}; - - -struct dvb_diseqc_slave_reply { -	__u8 msg [4];	/*  { framing, data [3] } */ -	__u8 msg_len;	/*  valid values are 0...4, 0 means no msg  */ -	int  timeout;	/*  return from ioctl after timeout ms with */ -};			/*  errorcode when no message was received  */ - - -typedef enum fe_sec_voltage { -	SEC_VOLTAGE_13, -	SEC_VOLTAGE_18, -	SEC_VOLTAGE_OFF -} fe_sec_voltage_t; - - -typedef enum fe_sec_tone_mode { -	SEC_TONE_ON, -	SEC_TONE_OFF -} fe_sec_tone_mode_t; - - -typedef enum fe_sec_mini_cmd { -	SEC_MINI_A, -	SEC_MINI_B -} fe_sec_mini_cmd_t; - - -typedef enum fe_status { -	FE_HAS_SIGNAL	= 0x01,   /*  found something above the noise level */ -	FE_HAS_CARRIER	= 0x02,   /*  found a DVB signal  */ -	FE_HAS_VITERBI	= 0x04,   /*  FEC is stable  */ -	FE_HAS_SYNC	= 0x08,   /*  found sync bytes  */ -	FE_HAS_LOCK	= 0x10,   /*  everything's working... */ -	FE_TIMEDOUT	= 0x20,   /*  no lock within the last ~2 seconds */ -	FE_REINIT	= 0x40    /*  frontend was reinitialized,  */ -} fe_status_t;			  /*  application is recommended to reset */ -				  /*  DiSEqC, tone and parameters */ - -typedef enum fe_spectral_inversion { -	INVERSION_OFF, -	INVERSION_ON, -	INVERSION_AUTO -} fe_spectral_inversion_t; - - -typedef enum fe_code_rate { -	FEC_NONE = 0, -	FEC_1_2, -	FEC_2_3, -	FEC_3_4, -	FEC_4_5, -	FEC_5_6, -	FEC_6_7, -	FEC_7_8, -	FEC_8_9, -	FEC_AUTO -} fe_code_rate_t; - - -typedef enum fe_modulation { -	QPSK, -	QAM_16, -	QAM_32, -	QAM_64, -	QAM_128, -	QAM_256, -	QAM_AUTO, -	VSB_8, -	VSB_16 -} fe_modulation_t; - -typedef enum fe_transmit_mode { -	TRANSMISSION_MODE_2K, -	TRANSMISSION_MODE_8K, -	TRANSMISSION_MODE_AUTO -} fe_transmit_mode_t; - -typedef enum fe_bandwidth { -	BANDWIDTH_8_MHZ, -	BANDWIDTH_7_MHZ, -	BANDWIDTH_6_MHZ, -	BANDWIDTH_AUTO -} fe_bandwidth_t; - - -typedef enum fe_guard_interval { -	GUARD_INTERVAL_1_32, -	GUARD_INTERVAL_1_16, -	GUARD_INTERVAL_1_8, -	GUARD_INTERVAL_1_4, -	GUARD_INTERVAL_AUTO -} fe_guard_interval_t; - - -typedef enum fe_hierarchy { -	HIERARCHY_NONE, -	HIERARCHY_1, -	HIERARCHY_2, -	HIERARCHY_4, -	HIERARCHY_AUTO -} fe_hierarchy_t; - - -struct dvb_qpsk_parameters { -	__u32		symbol_rate;  /* symbol rate in Symbols per second */ -	fe_code_rate_t	fec_inner;    /* forward error correction (see above) */ -}; - -struct dvb_qam_parameters { -	__u32		symbol_rate; /* symbol rate in Symbols per second */ -	fe_code_rate_t	fec_inner;   /* forward error correction (see above) */ -	fe_modulation_t	modulation;  /* modulation type (see above) */ -}; - -struct dvb_vsb_parameters { -	fe_modulation_t	modulation;  /* modulation type (see above) */ -}; - -struct dvb_ofdm_parameters { -	fe_bandwidth_t      bandwidth; -	fe_code_rate_t      code_rate_HP;  /* high priority stream code rate */ -	fe_code_rate_t      code_rate_LP;  /* low priority stream code rate */ -	fe_modulation_t     constellation; /* modulation type (see above) */ -	fe_transmit_mode_t  transmission_mode; -	fe_guard_interval_t guard_interval; -	fe_hierarchy_t      hierarchy_information; -}; - - -struct dvb_frontend_parameters { -	__u32 frequency;     /* (absolute) frequency in Hz for QAM/OFDM/ATSC */ -			     /* intermediate frequency in kHz for QPSK */ -	fe_spectral_inversion_t inversion; -	union { -		struct dvb_qpsk_parameters qpsk; -		struct dvb_qam_parameters  qam; -		struct dvb_ofdm_parameters ofdm; -		struct dvb_vsb_parameters vsb; -	} u; -}; - - -struct dvb_frontend_event { -	fe_status_t status; -	struct dvb_frontend_parameters parameters; -}; - - - -#define FE_GET_INFO		   _IOR('o', 61, struct dvb_frontend_info) - -#define FE_DISEQC_RESET_OVERLOAD   _IO('o', 62) -#define FE_DISEQC_SEND_MASTER_CMD  _IOW('o', 63, struct dvb_diseqc_master_cmd) -#define FE_DISEQC_RECV_SLAVE_REPLY _IOR('o', 64, struct dvb_diseqc_slave_reply) -#define FE_DISEQC_SEND_BURST       _IO('o', 65)  /* fe_sec_mini_cmd_t */ - -#define FE_SET_TONE		   _IO('o', 66)  /* fe_sec_tone_mode_t */ -#define FE_SET_VOLTAGE		   _IO('o', 67)  /* fe_sec_voltage_t */ -#define FE_ENABLE_HIGH_LNB_VOLTAGE _IO('o', 68)  /* int */ - -#define FE_READ_STATUS		   _IOR('o', 69, fe_status_t) -#define FE_READ_BER		   _IOR('o', 70, __u32) -#define FE_READ_SIGNAL_STRENGTH    _IOR('o', 71, __u16) -#define FE_READ_SNR		   _IOR('o', 72, __u16) -#define FE_READ_UNCORRECTED_BLOCKS _IOR('o', 73, __u32) - -#define FE_SET_FRONTEND		   _IOW('o', 76, struct dvb_frontend_parameters) -#define FE_GET_FRONTEND		   _IOR('o', 77, struct dvb_frontend_parameters) -#define FE_GET_EVENT		   _IOR('o', 78, struct dvb_frontend_event) - -#define FE_DISHNETWORK_SEND_LEGACY_CMD _IO('o', 80) /* unsigned int */ - -#endif /*_DVBFRONTEND_H_*/ diff --git a/include/linux/dvb/net.h b/include/net.h index 4b8fa51..5be474b 100644 --- a/include/linux/dvb/net.h +++ b/include/net.h @@ -1,9 +1,9 @@ -/*  +/*   * net.h   *   * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de>   *                  & Ralph  Metzler <ralph@convergence.de> -                      for convergence integrated media GmbH + *                    for convergence integrated media GmbH   *   * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU Lesser General Public License @@ -30,12 +30,24 @@  struct dvb_net_if {  	__u16 pid;  	__u16 if_num; +	__u8  feedtype; +#define DVB_NET_FEEDTYPE_MPE 0	/* multi protocol encapsulation */ +#define DVB_NET_FEEDTYPE_ULE 1	/* ultra lightweight encapsulation */  }; -#define NET_ADD_IF                 _IOWR('o', 52, struct dvb_net_if) -#define NET_REMOVE_IF              _IO('o', 53) -#define NET_GET_IF                 _IOWR('o', 54, struct dvb_net_if) +#define NET_ADD_IF    _IOWR('o', 52, struct dvb_net_if) +#define NET_REMOVE_IF _IO('o', 53) +#define NET_GET_IF    _IOWR('o', 54, struct dvb_net_if) -#endif /*_DVBNET_H_*/ +/* binary compatibility cruft: */ +struct __dvb_net_if_old { +	__u16 pid; +	__u16 if_num; +}; +#define __NET_ADD_IF_OLD _IOWR('o', 52, struct __dvb_net_if_old) +#define __NET_GET_IF_OLD _IOWR('o', 54, struct __dvb_net_if_old) + + +#endif /*_DVBNET_H_*/ diff --git a/include/linux/dvb/osd.h b/include/osd.h index 0d81439..5d2961c 100644 --- a/include/linux/dvb/osd.h +++ b/include/osd.h @@ -1,9 +1,9 @@ -/*  +/*   * osd.h   *   * Copyright (C) 2001 Ralph  Metzler <ralph@convergence.de>   *                  & Marcus Metzler <marcus@convergence.de> -                      for convergence integrated media GmbH + *                    for convergence integrated media GmbH   *   * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU General Lesser Public License @@ -91,21 +91,52 @@ typedef enum {  // TODO: remove "test" in final version    OSD_Text,       // (x0,y0,size,color,text)    OSD_SetWindow, //  (x0) set window with number 0<x0<8 as current -  OSD_MoveWindow, //  move current window to (x0, y0)   +  OSD_MoveWindow, //  move current window to (x0, y0) +  OSD_OpenRaw,	// Open other types of OSD windows  } OSD_Command;  typedef struct osd_cmd_s { -        OSD_Command cmd; -        int x0; -        int y0; -        int x1; -        int y1; -        int color; -        void *data; +	OSD_Command cmd; +	int x0; +	int y0; +	int x1; +	int y1; +	int color; +	void *data;  } osd_cmd_t; +/* OSD_OpenRaw: set 'color' to desired window type */ +typedef enum { +	OSD_BITMAP1,           /* 1 bit bitmap */ +	OSD_BITMAP2,           /* 2 bit bitmap */ +	OSD_BITMAP4,           /* 4 bit bitmap */ +	OSD_BITMAP8,           /* 8 bit bitmap */ +	OSD_BITMAP1HR,         /* 1 Bit bitmap half resolution */ +	OSD_BITMAP2HR,         /* 2 bit bitmap half resolution */ +	OSD_BITMAP4HR,         /* 4 bit bitmap half resolution */ +	OSD_BITMAP8HR,         /* 8 bit bitmap half resolution */ +	OSD_YCRCB422,          /* 4:2:2 YCRCB Graphic Display */ +	OSD_YCRCB444,          /* 4:4:4 YCRCB Graphic Display */ +	OSD_YCRCB444HR,        /* 4:4:4 YCRCB graphic half resolution */ +	OSD_VIDEOTSIZE,        /* True Size Normal MPEG Video Display */ +	OSD_VIDEOHSIZE,        /* MPEG Video Display Half Resolution */ +	OSD_VIDEOQSIZE,        /* MPEG Video Display Quarter Resolution */ +	OSD_VIDEODSIZE,        /* MPEG Video Display Double Resolution */ +	OSD_VIDEOTHSIZE,       /* True Size MPEG Video Display Half Resolution */ +	OSD_VIDEOTQSIZE,       /* True Size MPEG Video Display Quarter Resolution*/ +	OSD_VIDEOTDSIZE,       /* True Size MPEG Video Display Double Resolution */ +	OSD_VIDEONSIZE,        /* Full Size MPEG Video Display */ +	OSD_CURSOR             /* Cursor */ +} osd_raw_window_t; -#define OSD_SEND_CMD       _IOW('o', 160, osd_cmd_t) +typedef struct osd_cap_s { +	int  cmd; +#define OSD_CAP_MEMSIZE         1  /* memory size */ +	long val; +} osd_cap_t; -#endif +#define OSD_SEND_CMD            _IOW('o', 160, osd_cmd_t) +#define OSD_GET_CAPABILITY      _IOR('o', 161, osd_cap_t) + +#endif diff --git a/include/linux/dvb/version.h b/include/version.h index 54e256e..2dd76c8 100644 --- a/include/linux/dvb/version.h +++ b/include/version.h @@ -24,6 +24,6 @@  #define _DVBVERSION_H_  #define DVB_API_VERSION 3 +#define DVB_API_VERSION_MINOR 3  #endif /*_DVBVERSION_H_*/ - diff --git a/include/linux/dvb/video.h b/include/video.h index a8b6008..317ba6b 100644 --- a/include/linux/dvb/video.h +++ b/include/video.h @@ -1,9 +1,9 @@ -/*  +/*   * video.h   *   * Copyright (C) 2000 Marcus Metzler <marcus@convergence.de>   *                  & Ralph  Metzler <ralph@convergence.de> -                      for convergence integrated media GmbH + *                    for convergence integrated media GmbH   *   * This program is free software; you can redistribute it and/or   * modify it under the terms of the GNU Lesser General Public License @@ -27,6 +27,7 @@  #ifdef __KERNEL__  #include <linux/types.h>  #else +#include <asm/types.h>  #include <stdint.h>  #include <time.h>  #endif @@ -34,25 +35,25 @@  typedef enum {  	VIDEO_FORMAT_4_3,     /* Select 4:3 format */ -        VIDEO_FORMAT_16_9,    /* Select 16:9 format. */ +	VIDEO_FORMAT_16_9,    /* Select 16:9 format. */  	VIDEO_FORMAT_221_1    /* 2.21:1 */  } video_format_t;  typedef enum { -	 VIDEO_SYSTEM_PAL,  -	 VIDEO_SYSTEM_NTSC,  -	 VIDEO_SYSTEM_PALN,  -	 VIDEO_SYSTEM_PALNc,  -	 VIDEO_SYSTEM_PALM,  -	 VIDEO_SYSTEM_NTSC60,  +	 VIDEO_SYSTEM_PAL, +	 VIDEO_SYSTEM_NTSC, +	 VIDEO_SYSTEM_PALN, +	 VIDEO_SYSTEM_PALNc, +	 VIDEO_SYSTEM_PALM, +	 VIDEO_SYSTEM_NTSC60,  	 VIDEO_SYSTEM_PAL60,  	 VIDEO_SYSTEM_PALM60  } video_system_t; -typedef enum {    -        VIDEO_PAN_SCAN,       /* use pan and scan format */ +typedef enum { +	VIDEO_PAN_SCAN,       /* use pan and scan format */  	VIDEO_LETTER_BOX,     /* use letterbox format */  	VIDEO_CENTER_CUT_OUT  /* use center cut out format */  } video_displayformat_t; @@ -64,62 +65,120 @@ typedef struct {  } video_size_t;  typedef enum { -        VIDEO_SOURCE_DEMUX, /* Select the demux as the main source */  -	VIDEO_SOURCE_MEMORY /* If this source is selected, the stream  -			       comes from the user through the write  -			       system call */  +	VIDEO_SOURCE_DEMUX, /* Select the demux as the main source */ +	VIDEO_SOURCE_MEMORY /* If this source is selected, the stream +			       comes from the user through the write +			       system call */  } video_stream_source_t;  typedef enum { -	VIDEO_STOPPED, /* Video is stopped */  -        VIDEO_PLAYING, /* Video is currently playing */  -	VIDEO_FREEZED  /* Video is freezed */  -} video_play_state_t;  - +	VIDEO_STOPPED, /* Video is stopped */ +	VIDEO_PLAYING, /* Video is currently playing */ +	VIDEO_FREEZED  /* Video is freezed */ +} video_play_state_t; + + +/* Decoder commands */ +#define VIDEO_CMD_PLAY        (0) +#define VIDEO_CMD_STOP        (1) +#define VIDEO_CMD_FREEZE      (2) +#define VIDEO_CMD_CONTINUE    (3) + +/* Flags for VIDEO_CMD_FREEZE */ +#define VIDEO_CMD_FREEZE_TO_BLACK     	(1 << 0) + +/* Flags for VIDEO_CMD_STOP */ +#define VIDEO_CMD_STOP_TO_BLACK      	(1 << 0) +#define VIDEO_CMD_STOP_IMMEDIATELY     	(1 << 1) + +/* Play input formats: */ +/* The decoder has no special format requirements */ +#define VIDEO_PLAY_FMT_NONE         (0) +/* The decoder requires full GOPs */ +#define VIDEO_PLAY_FMT_GOP          (1) + +/* The structure must be zeroed before use by the application +   This ensures it can be extended safely in the future. */ +struct video_command { +	__u32 cmd; +	__u32 flags; +	union { +		struct { +			__u64 pts; +		} stop; + +		struct { +			/* 0 or 1000 specifies normal speed, +			   1 specifies forward single stepping, +			   -1 specifies backward single stepping, +			   >1: playback at speed/1000 of the normal speed, +			   <-1: reverse playback at (-speed/1000) of the normal speed. */ +			__s32 speed; +			__u32 format; +		} play; + +		struct { +			__u32 data[16]; +		} raw; +	}; +}; -struct video_event {  -        int32_t type;  -#define VIDEO_EVENT_SIZE_CHANGED 1 -        time_t timestamp; +/* FIELD_UNKNOWN can be used if the hardware does not know whether +   the Vsync is for an odd, even or progressive (i.e. non-interlaced) +   field. */ +#define VIDEO_VSYNC_FIELD_UNKNOWN  	(0) +#define VIDEO_VSYNC_FIELD_ODD 		(1) +#define VIDEO_VSYNC_FIELD_EVEN		(2) +#define VIDEO_VSYNC_FIELD_PROGRESSIVE	(3) + +struct video_event { +	int32_t type; +#define VIDEO_EVENT_SIZE_CHANGED	1 +#define VIDEO_EVENT_FRAME_RATE_CHANGED	2 +#define VIDEO_EVENT_DECODER_STOPPED 	3 +#define VIDEO_EVENT_VSYNC 		4 +	time_t timestamp;  	union { -	        video_size_t size; +		video_size_t size; +		unsigned int frame_rate;	/* in frames per 1000sec */ +		unsigned char vsync_field;	/* unknown/odd/even/progressive */  	} u;  }; -struct video_status {  -        int                   video_blank;   /* blank video on freeze? */ -        video_play_state_t    play_state;    /* current state of playback */   -        video_stream_source_t stream_source; /* current source (demux/memory) */ -        video_format_t        video_format;  /* current aspect ratio of stream*/ -        video_displayformat_t display_format;/* selected cropping mode */ +struct video_status { +	int                   video_blank;   /* blank video on freeze? */ +	video_play_state_t    play_state;    /* current state of playback */ +	video_stream_source_t stream_source; /* current source (demux/memory) */ +	video_format_t        video_format;  /* current aspect ratio of stream*/ +	video_displayformat_t display_format;/* selected cropping mode */  };  struct video_still_picture { -        char *iFrame;        /* pointer to a single iframe in memory */ -        int32_t size;  +	char *iFrame;        /* pointer to a single iframe in memory */ +	int32_t size;  }; -typedef  +typedef  struct video_highlight {  	int     active;      /*    1=show highlight, 0=hide highlight */  	uint8_t contrast1;   /*    7- 4  Pattern pixel contrast */ -                             /*    3- 0  Background pixel contrast */ +			     /*    3- 0  Background pixel contrast */  	uint8_t contrast2;   /*    7- 4  Emphasis pixel-2 contrast */ -                             /*    3- 0  Emphasis pixel-1 contrast */ +			     /*    3- 0  Emphasis pixel-1 contrast */  	uint8_t color1;      /*    7- 4  Pattern pixel color */ -                             /*    3- 0  Background pixel color */ +			     /*    3- 0  Background pixel color */  	uint8_t color2;      /*    7- 4  Emphasis pixel-2 color */ -                             /*    3- 0  Emphasis pixel-1 color */ - 	uint32_t ypos;       /*   23-22  auto action mode */ -                             /*   21-12  start y */ -                             /*    9- 0  end y */ +			     /*    3- 0  Emphasis pixel-1 color */ +	uint32_t ypos;       /*   23-22  auto action mode */ +			     /*   21-12  start y */ +			     /*    9- 0  end y */  	uint32_t xpos;       /*   23-22  button color number */ -                             /*   21-12  start x */ -                             /*    9- 0  end x */ +			     /*   21-12  start x */ +			     /*    9- 0  end x */  } video_highlight_t; @@ -156,21 +215,21 @@ typedef uint16_t video_attributes_t;  /* bit definitions for capabilities: */  /* can the hardware decode MPEG1 and/or MPEG2? */ -#define VIDEO_CAP_MPEG1   1  +#define VIDEO_CAP_MPEG1   1  #define VIDEO_CAP_MPEG2   2  /* can you send a system and/or program stream to video device? -   (you still have to open the video and the audio device but only  +   (you still have to open the video and the audio device but only      send the stream to the video device) */  #define VIDEO_CAP_SYS     4  #define VIDEO_CAP_PROG    8 -/* can the driver also handle SPU, NAVI and CSS encoded data?  +/* can the driver also handle SPU, NAVI and CSS encoded data?     (CSS API is not present yet) */  #define VIDEO_CAP_SPU    16  #define VIDEO_CAP_NAVI   32  #define VIDEO_CAP_CSS    64 -#define VIDEO_STOP                 _IO('o', 21)  +#define VIDEO_STOP                 _IO('o', 21)  #define VIDEO_PLAY                 _IO('o', 22)  #define VIDEO_FREEZE               _IO('o', 23)  #define VIDEO_CONTINUE             _IO('o', 24) @@ -194,6 +253,25 @@ typedef uint16_t video_attributes_t;  #define VIDEO_GET_NAVI             _IOR('o', 52, video_navi_pack_t)  #define VIDEO_SET_ATTRIBUTES       _IO('o', 53)  #define VIDEO_GET_SIZE             _IOR('o', 55, video_size_t) +#define VIDEO_GET_FRAME_RATE       _IOR('o', 56, unsigned int) -#endif /*_DVBVIDEO_H_*/ +/** + * VIDEO_GET_PTS + * + * Read the 33 bit presentation time stamp as defined + * in ITU T-REC-H.222.0 / ISO/IEC 13818-1. + * + * The PTS should belong to the currently played + * frame if possible, but may also be a value close to it + * like the PTS of the last decoded frame or the last PTS + * extracted by the PES parser. + */ +#define VIDEO_GET_PTS              _IOR('o', 57, __u64) + +/* Read the number of displayed frames since the decoder was started */ +#define VIDEO_GET_FRAME_COUNT  	   _IOR('o', 58, __u64) +#define VIDEO_COMMAND     	   _IOWR('o', 59, struct video_command) +#define VIDEO_TRY_COMMAND 	   _IOWR('o', 60, struct video_command) + +#endif /*_DVBVIDEO_H_*/ | 
