2005-04-17 02:20:36 +04:00
/*
*
* v4l2 device driver for philips saa7134 based TV cards
*
* ( c ) 2001 , 02 Gerd Knorr < kraxel @ bytesex . org >
*
* 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 .
*
* 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 General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
2005-09-10 00:04:03 +04:00
# include <linux/version.h>
2005-08-01 09:34:43 +04:00
# define SAA7134_VERSION_CODE KERNEL_VERSION(0,2,14)
2005-04-17 02:20:36 +04:00
# include <linux/pci.h>
# include <linux/i2c.h>
2005-11-09 08:37:49 +03:00
# include <linux/videodev2.h>
2005-04-17 02:20:36 +04:00
# include <linux/kdev_t.h>
# include <linux/input.h>
2005-11-09 08:37:27 +03:00
# include <linux/notifier.h>
# include <linux/delay.h>
2006-02-07 11:49:14 +03:00
# include <linux/mutex.h>
2005-04-17 02:20:36 +04:00
# include <asm/io.h>
2006-06-04 17:06:18 +04:00
# include <media/v4l2-common.h>
2008-07-20 15:12:02 +04:00
# include <media/v4l2-ioctl.h>
2005-04-17 02:20:36 +04:00
# include <media/tuner.h>
# include <media/ir-common.h>
2005-11-09 08:37:56 +03:00
# include <media/ir-kbd-i2c.h>
2007-08-23 23:37:49 +04:00
# include <media/videobuf-dma-sg.h>
2006-01-09 20:25:21 +03:00
# include <sound/core.h>
# include <sound/pcm.h>
2007-10-04 11:54:11 +04:00
# if defined(CONFIG_VIDEO_SAA7134_DVB) || defined(CONFIG_VIDEO_SAA7134_DVB_MODULE)
2007-08-24 01:12:08 +04:00
# include <media/videobuf-dvb.h>
2007-01-31 05:26:01 +03:00
# endif
2005-04-17 02:20:36 +04:00
# define UNSET (-1U)
/* ----------------------------------------------------------- */
/* enums */
enum saa7134_tvaudio_mode {
TVAUDIO_FM_MONO = 1 ,
TVAUDIO_FM_BG_STEREO = 2 ,
TVAUDIO_FM_SAT_STEREO = 3 ,
TVAUDIO_FM_K_STEREO = 4 ,
TVAUDIO_NICAM_AM = 5 ,
TVAUDIO_NICAM_FM = 6 ,
} ;
enum saa7134_audio_in {
TV = 1 ,
LINE1 = 2 ,
LINE2 = 3 ,
LINE2_LEFT ,
} ;
enum saa7134_video_out {
CCIR656 = 1 ,
} ;
/* ----------------------------------------------------------- */
/* static data */
struct saa7134_tvnorm {
char * name ;
v4l2_std_id id ;
/* video decoder */
unsigned int sync_control ;
unsigned int luma_control ;
unsigned int chroma_ctrl1 ;
unsigned int chroma_gain ;
unsigned int chroma_ctrl2 ;
unsigned int vgate_misc ;
/* video scaler */
unsigned int h_start ;
unsigned int h_stop ;
unsigned int video_v_start ;
unsigned int video_v_stop ;
2005-06-24 09:04:47 +04:00
unsigned int vbi_v_start_0 ;
unsigned int vbi_v_stop_0 ;
2005-04-17 02:20:36 +04:00
unsigned int src_timing ;
2005-06-24 09:04:47 +04:00
unsigned int vbi_v_start_1 ;
2005-04-17 02:20:36 +04:00
} ;
struct saa7134_tvaudio {
char * name ;
v4l2_std_id std ;
enum saa7134_tvaudio_mode mode ;
int carr1 ;
int carr2 ;
} ;
struct saa7134_format {
char * name ;
unsigned int fourcc ;
unsigned int depth ;
unsigned int pm ;
unsigned int vshift ; /* vertical downsampling (for planar yuv) */
unsigned int hshift ; /* horizontal downsampling (for planar yuv) */
unsigned int bswap : 1 ;
unsigned int wswap : 1 ;
unsigned int yuv : 1 ;
unsigned int planar : 1 ;
unsigned int uvswap : 1 ;
} ;
/* ----------------------------------------------------------- */
/* card configuration */
# define SAA7134_BOARD_NOAUTO UNSET
# define SAA7134_BOARD_UNKNOWN 0
# define SAA7134_BOARD_PROTEUS_PRO 1
# define SAA7134_BOARD_FLYVIDEO3000 2
# define SAA7134_BOARD_FLYVIDEO2000 3
# define SAA7134_BOARD_EMPRESS 4
# define SAA7134_BOARD_MONSTERTV 5
# define SAA7134_BOARD_MD9717 6
# define SAA7134_BOARD_TVSTATION_RDS 7
# define SAA7134_BOARD_CINERGY400 8
# define SAA7134_BOARD_MD5044 9
# define SAA7134_BOARD_KWORLD 10
# define SAA7134_BOARD_CINERGY600 11
# define SAA7134_BOARD_MD7134 12
# define SAA7134_BOARD_TYPHOON_90031 13
# define SAA7134_BOARD_ELSA 14
# define SAA7134_BOARD_ELSA_500TV 15
# define SAA7134_BOARD_ASUSTeK_TVFM7134 16
# define SAA7134_BOARD_VA1000POWER 17
# define SAA7134_BOARD_BMK_MPEX_NOTUNER 18
# define SAA7134_BOARD_VIDEOMATE_TV 19
# define SAA7134_BOARD_CRONOS_PLUS 20
# define SAA7134_BOARD_10MOONSTVMASTER 21
# define SAA7134_BOARD_MD2819 22
# define SAA7134_BOARD_BMK_MPEX_TUNER 23
# define SAA7134_BOARD_TVSTATION_DVR 24
# define SAA7134_BOARD_ASUSTEK_TVFM7133 25
# define SAA7134_BOARD_PINNACLE_PCTV_STEREO 26
# define SAA7134_BOARD_MANLI_MTV002 27
# define SAA7134_BOARD_MANLI_MTV001 28
# define SAA7134_BOARD_TG3000TV 29
# define SAA7134_BOARD_ECS_TVP3XP 30
# define SAA7134_BOARD_ECS_TVP3XP_4CB5 31
# define SAA7134_BOARD_AVACSSMARTTV 32
# define SAA7134_BOARD_AVERMEDIA_DVD_EZMAKER 33
# define SAA7134_BOARD_NOVAC_PRIMETV7133 34
# define SAA7134_BOARD_AVERMEDIA_STUDIO_305 35
2005-07-13 00:59:01 +04:00
# define SAA7134_BOARD_UPMOST_PURPLE_TV 36
2005-04-17 02:20:36 +04:00
# define SAA7134_BOARD_ITEMS_MTV005 37
# define SAA7134_BOARD_CINERGY200 38
# define SAA7134_BOARD_FLYTVPLATINUM_MINI 39
# define SAA7134_BOARD_VIDEOMATE_TV_PVR 40
# define SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUS 41
# define SAA7134_BOARD_SABRENT_SBTTVFM 42
# define SAA7134_BOARD_ZOLID_XPERT_TV7134 43
# define SAA7134_BOARD_EMPIRE_PCI_TV_RADIO_LE 44
2005-06-24 09:05:09 +04:00
# define SAA7134_BOARD_AVERMEDIA_STUDIO_307 45
2005-04-17 02:20:36 +04:00
# define SAA7134_BOARD_AVERMEDIA_CARDBUS 46
# define SAA7134_BOARD_CINERGY400_CARDBUS 47
# define SAA7134_BOARD_CINERGY600_MK3 48
# define SAA7134_BOARD_VIDEOMATE_GOLD_PLUS 49
# define SAA7134_BOARD_PINNACLE_300I_DVBT_PAL 50
# define SAA7134_BOARD_PROVIDEO_PV952 51
# define SAA7134_BOARD_AVERMEDIA_305 52
2005-07-13 00:59:01 +04:00
# define SAA7134_BOARD_ASUSTeK_TVFM7135 53
2005-04-17 02:20:36 +04:00
# define SAA7134_BOARD_FLYTVPLATINUM_FM 54
# define SAA7134_BOARD_FLYDVBTDUO 55
2005-06-24 09:05:09 +04:00
# define SAA7134_BOARD_AVERMEDIA_307 56
# define SAA7134_BOARD_AVERMEDIA_GO_007_FM 57
# define SAA7134_BOARD_ADS_INSTANT_TV 58
# define SAA7134_BOARD_KWORLD_VSTREAM_XPERT 59
2006-01-23 14:51:17 +03:00
# define SAA7134_BOARD_FLYDVBT_DUO_CARDBUS 60
2005-07-13 00:59:01 +04:00
# define SAA7134_BOARD_PHILIPS_TOUGH 61
# define SAA7134_BOARD_VIDEOMATE_TV_GOLD_PLUSII 62
# define SAA7134_BOARD_KWORLD_XPERT 63
2005-09-10 00:03:46 +04:00
# define SAA7134_BOARD_FLYTV_DIGIMATRIX 64
2005-09-10 00:03:49 +04:00
# define SAA7134_BOARD_KWORLD_TERMINATOR 65
2005-09-10 00:03:51 +04:00
# define SAA7134_BOARD_YUAN_TUN900 66
2005-11-09 08:36:16 +03:00
# define SAA7134_BOARD_BEHOLD_409FM 67
2005-11-09 08:36:22 +03:00
# define SAA7134_BOARD_GOTVIEW_7135 68
2005-11-09 08:36:32 +03:00
# define SAA7134_BOARD_PHILIPS_EUROPA 69
# define SAA7134_BOARD_VIDEOMATE_DVBT_300 70
# define SAA7134_BOARD_VIDEOMATE_DVBT_200 71
2005-11-09 08:36:35 +03:00
# define SAA7134_BOARD_RTD_VFG7350 72
# define SAA7134_BOARD_RTD_VFG7330 73
2005-11-09 08:36:49 +03:00
# define SAA7134_BOARD_FLYTVPLATINUM_MINI2 74
2005-11-09 08:37:27 +03:00
# define SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180 75
2005-11-09 08:37:40 +03:00
# define SAA7134_BOARD_MONSTERTV_MOBILE 76
2005-11-09 08:37:51 +03:00
# define SAA7134_BOARD_PINNACLE_PCTV_110i 77
2005-11-09 08:38:03 +03:00
# define SAA7134_BOARD_ASUSTeK_P7131_DUAL 78
2005-11-09 08:38:47 +03:00
# define SAA7134_BOARD_SEDNA_PC_TV_CARDBUS 79
2005-11-09 08:38:08 +03:00
# define SAA7134_BOARD_ASUSTEK_DIGIMATRIX_TV 80
2005-11-09 08:38:42 +03:00
# define SAA7134_BOARD_PHILIPS_TIGER 81
2005-11-14 03:08:01 +03:00
# define SAA7134_BOARD_MSI_TVATANYWHERE_PLUS 82
2006-01-09 20:25:01 +03:00
# define SAA7134_BOARD_CINERGY250PCI 83
2006-01-09 20:32:45 +03:00
# define SAA7134_BOARD_FLYDVB_TRIO 84
2006-02-07 11:25:14 +03:00
# define SAA7134_BOARD_AVERMEDIA_777 85
2006-02-07 11:49:09 +03:00
# define SAA7134_BOARD_FLYDVBT_LR301 86
2006-02-07 11:49:10 +03:00
# define SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331 87
2006-02-07 11:49:13 +03:00
# define SAA7134_BOARD_TEVION_DVBT_220RF 88
2006-02-27 06:08:04 +03:00
# define SAA7134_BOARD_ELSA_700TV 89
2006-02-27 06:08:23 +03:00
# define SAA7134_BOARD_KWORLD_ATSC110 90
2006-03-11 23:14:12 +03:00
# define SAA7134_BOARD_AVERMEDIA_A169_B 91
# define SAA7134_BOARD_AVERMEDIA_A169_B1 92
2006-03-15 01:02:12 +03:00
# define SAA7134_BOARD_MD7134_BRIDGE_2 93
2006-03-28 02:39:30 +04:00
# define SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS 94
2006-06-20 02:49:20 +04:00
# define SAA7134_BOARD_FLYVIDEO3000_NTSC 95
2006-08-07 21:03:32 +04:00
# define SAA7134_BOARD_MEDION_MD8800_QUADRO 96
2006-08-08 16:10:10 +04:00
# define SAA7134_BOARD_FLYDVBS_LR300 97
2006-09-13 23:42:42 +04:00
# define SAA7134_BOARD_PROTEUS_2309 98
2006-09-26 23:53:53 +04:00
# define SAA7134_BOARD_AVERMEDIA_A16AR 99
2006-10-03 03:49:24 +04:00
# define SAA7134_BOARD_ASUS_EUROPA2_HYBRID 100
2006-10-07 02:13:50 +04:00
# define SAA7134_BOARD_PINNACLE_PCTV_310i 101
2006-10-07 03:23:47 +04:00
# define SAA7134_BOARD_AVERMEDIA_STUDIO_507 102
2006-10-31 02:00:16 +03:00
# define SAA7134_BOARD_VIDEOMATE_DVBT_200A 103
2006-11-16 03:31:54 +03:00
# define SAA7134_BOARD_HAUPPAUGE_HVR1110 104
# define SAA7134_BOARD_CINERGY_HT_PCMCIA 105
2006-12-20 15:29:09 +03:00
# define SAA7134_BOARD_ENCORE_ENLTV 106
2006-12-27 18:46:36 +03:00
# define SAA7134_BOARD_ENCORE_ENLTV_FM 107
2007-01-17 00:36:40 +03:00
# define SAA7134_BOARD_CINERGY_HT_PCI 108
2007-04-27 19:31:12 +04:00
# define SAA7134_BOARD_PHILIPS_TIGER_S 109
2007-04-27 19:31:19 +04:00
# define SAA7134_BOARD_AVERMEDIA_M102 110
2007-03-14 02:58:29 +03:00
# define SAA7134_BOARD_ASUS_P7131_4871 111
2007-03-15 02:33:55 +03:00
# define SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA 112
2007-05-01 17:01:20 +04:00
# define SAA7134_BOARD_ECS_TVP3XP_4CB6 113
# define SAA7134_BOARD_KWORLD_DVBT_210 114
2007-05-01 17:48:09 +04:00
# define SAA7134_BOARD_SABRENT_TV_PCB05 115
2007-05-10 19:16:47 +04:00
# define SAA7134_BOARD_10MOONSTVMASTER3 116
2007-08-20 21:14:50 +04:00
# define SAA7134_BOARD_AVERMEDIA_SUPER_007 117
2008-01-07 11:17:39 +03:00
# define SAA7134_BOARD_BEHOLD_401 118
# define SAA7134_BOARD_BEHOLD_403 119
# define SAA7134_BOARD_BEHOLD_403FM 120
# define SAA7134_BOARD_BEHOLD_405 121
# define SAA7134_BOARD_BEHOLD_405FM 122
# define SAA7134_BOARD_BEHOLD_407 123
# define SAA7134_BOARD_BEHOLD_407FM 124
# define SAA7134_BOARD_BEHOLD_409 125
# define SAA7134_BOARD_BEHOLD_505FM 126
# define SAA7134_BOARD_BEHOLD_507_9FM 127
# define SAA7134_BOARD_BEHOLD_COLUMBUS_TVFM 128
# define SAA7134_BOARD_BEHOLD_607_9FM 129
# define SAA7134_BOARD_BEHOLD_M6 130
2008-01-21 01:27:51 +03:00
# define SAA7134_BOARD_TWINHAN_DTV_DVB_3056 131
2008-04-22 21:42:11 +04:00
# define SAA7134_BOARD_GENIUS_TVGO_A11MCE 132
# define SAA7134_BOARD_PHILIPS_SNAKE 133
2008-04-22 21:42:12 +04:00
# define SAA7134_BOARD_CREATIX_CTX953 134
2008-04-22 21:42:12 +04:00
# define SAA7134_BOARD_MSI_TVANYWHERE_AD11 135
2008-04-22 21:45:27 +04:00
# define SAA7134_BOARD_AVERMEDIA_CARDBUS_506 136
# define SAA7134_BOARD_AVERMEDIA_A16D 137
# define SAA7134_BOARD_AVERMEDIA_M115 138
# define SAA7134_BOARD_VIDEOMATE_T750 139
2008-04-09 04:45:08 +04:00
# define SAA7134_BOARD_AVERMEDIA_A700_PRO 140
# define SAA7134_BOARD_AVERMEDIA_A700_HYBRID 141
2008-04-26 21:53:48 +04:00
# define SAA7134_BOARD_BEHOLD_H6 142
2008-06-10 21:22:00 +04:00
# define SAA7134_BOARD_BEHOLD_M63 143
# define SAA7134_BOARD_BEHOLD_M6_EXTRA 144
2008-07-11 20:48:02 +04:00
# define SAA7134_BOARD_AVERMEDIA_M103 145
2008-07-12 19:27:59 +04:00
# define SAA7134_BOARD_ASUSTeK_P7131_ANALOG 146
2005-04-17 02:20:36 +04:00
# define SAA7134_MAXBOARDS 8
# define SAA7134_INPUT_MAX 8
2005-11-09 08:38:47 +03:00
/* ----------------------------------------------------------- */
/* Since we support 2 remote types, lets tell them apart */
# define SAA7134_REMOTE_GPIO 1
# define SAA7134_REMOTE_I2C 2
2005-11-09 08:37:10 +03:00
/* ----------------------------------------------------------- */
/* Video Output Port Register Initialization Options */
# define SET_T_CODE_POLARITY_NON_INVERTED (1 << 0)
# define SET_CLOCK_NOT_DELAYED (1 << 1)
# define SET_CLOCK_INVERTED (1 << 2)
# define SET_VSYNC_OFF (1 << 3)
2005-04-17 02:20:36 +04:00
struct saa7134_input {
char * name ;
unsigned int vmux ;
enum saa7134_audio_in amux ;
unsigned int gpio ;
unsigned int tv : 1 ;
} ;
enum saa7134_mpeg_type {
SAA7134_MPEG_UNUSED ,
SAA7134_MPEG_EMPRESS ,
SAA7134_MPEG_DVB ,
} ;
struct saa7134_board {
char * name ;
unsigned int audio_clock ;
/* input switching */
unsigned int gpiomask ;
struct saa7134_input inputs [ SAA7134_INPUT_MAX ] ;
struct saa7134_input radio ;
struct saa7134_input mute ;
/* i2c chip info */
unsigned int tuner_type ;
2005-07-13 00:59:01 +04:00
unsigned int radio_type ;
unsigned char tuner_addr ;
unsigned char radio_addr ;
2005-04-17 02:20:36 +04:00
unsigned int tda9887_conf ;
2007-04-27 19:31:12 +04:00
unsigned int tuner_config ;
2005-04-17 02:20:36 +04:00
/* peripheral I/O */
enum saa7134_video_out video_out ;
enum saa7134_mpeg_type mpeg ;
2005-11-09 08:37:10 +03:00
unsigned int vid_port_opts ;
2005-04-17 02:20:36 +04:00
} ;
# define card_has_radio(dev) (NULL != saa7134_boards[dev->board].radio.name)
# define card_is_empress(dev) (SAA7134_MPEG_EMPRESS == saa7134_boards[dev->board].mpeg)
# define card_is_dvb(dev) (SAA7134_MPEG_DVB == saa7134_boards[dev->board].mpeg)
# define card_has_mpeg(dev) (SAA7134_MPEG_UNUSED != saa7134_boards[dev->board].mpeg)
# define card(dev) (saa7134_boards[dev->board])
# define card_in(dev,n) (saa7134_boards[dev->board].inputs[n])
/* ----------------------------------------------------------- */
/* device / file handle status */
# define RESOURCE_OVERLAY 1
# define RESOURCE_VIDEO 2
# define RESOURCE_VBI 4
# define INTERLACE_AUTO 0
# define INTERLACE_ON 1
# define INTERLACE_OFF 2
2007-07-17 23:36:20 +04:00
# define BUFFER_TIMEOUT msecs_to_jiffies(500) /* 0.5 seconds */
2005-04-17 02:20:36 +04:00
struct saa7134_dev ;
struct saa7134_dma ;
/* saa7134 page table */
struct saa7134_pgtable {
unsigned int size ;
2005-06-24 09:04:37 +04:00
__le32 * cpu ;
2005-04-17 02:20:36 +04:00
dma_addr_t dma ;
} ;
/* tvaudio thread status */
struct saa7134_thread {
2007-06-02 03:15:26 +04:00
struct task_struct * thread ;
2005-04-17 02:20:36 +04:00
unsigned int scan1 ;
unsigned int scan2 ;
unsigned int mode ;
2007-10-13 12:35:33 +04:00
unsigned int stopped ;
2005-04-17 02:20:36 +04:00
} ;
/* buffer for one video/vbi/ts frame */
struct saa7134_buf {
/* common v4l buffer stuff -- must be first */
struct videobuf_buffer vb ;
/* saa7134 specific */
struct saa7134_format * fmt ;
unsigned int top_seen ;
int ( * activate ) ( struct saa7134_dev * dev ,
struct saa7134_buf * buf ,
struct saa7134_buf * next ) ;
/* page tables */
struct saa7134_pgtable * pt ;
} ;
struct saa7134_dmaqueue {
struct saa7134_dev * dev ;
struct saa7134_buf * curr ;
struct list_head queue ;
struct timer_list timeout ;
unsigned int need_two ;
} ;
/* video filehandle status */
struct saa7134_fh {
struct saa7134_dev * dev ;
unsigned int radio ;
enum v4l2_buf_type type ;
unsigned int resources ;
enum v4l2_priority prio ;
/* video overlay */
struct v4l2_window win ;
struct v4l2_clip clips [ 8 ] ;
unsigned int nclips ;
/* video capture */
struct saa7134_format * fmt ;
unsigned int width , height ;
struct videobuf_queue cap ;
struct saa7134_pgtable pt_cap ;
/* vbi capture */
struct videobuf_queue vbi ;
struct saa7134_pgtable pt_vbi ;
} ;
2005-11-09 08:38:54 +03:00
/* dmasound dsp status */
struct saa7134_dmasound {
2006-02-07 11:49:14 +03:00
struct mutex lock ;
2005-04-17 02:20:36 +04:00
int minor_mixer ;
int minor_dsp ;
unsigned int users_dsp ;
/* mixer */
enum saa7134_audio_in input ;
unsigned int count ;
unsigned int line1 ;
unsigned int line2 ;
/* dsp */
unsigned int afmt ;
unsigned int rate ;
unsigned int channels ;
unsigned int recording_on ;
unsigned int dma_running ;
unsigned int blocks ;
unsigned int blksize ;
unsigned int bufsize ;
struct saa7134_pgtable pt ;
struct videobuf_dmabuf dma ;
wait_queue_head_t wq ;
unsigned int dma_blk ;
unsigned int read_offset ;
unsigned int read_count ;
2005-11-14 03:08:00 +03:00
void * priv_data ;
2006-01-13 20:48:06 +03:00
struct snd_pcm_substream * substream ;
2005-04-17 02:20:36 +04:00
} ;
/* ts/mpeg status */
struct saa7134_ts {
/* TS capture */
struct saa7134_pgtable pt_ts ;
int nr_packets ;
int nr_bufs ;
} ;
/* ts/mpeg ops */
struct saa7134_mpeg_ops {
enum saa7134_mpeg_type type ;
struct list_head next ;
int ( * init ) ( struct saa7134_dev * dev ) ;
int ( * fini ) ( struct saa7134_dev * dev ) ;
void ( * signal_change ) ( struct saa7134_dev * dev ) ;
} ;
/* global device status */
struct saa7134_dev {
struct list_head devlist ;
2006-02-07 11:49:14 +03:00
struct mutex lock ;
2005-11-09 08:37:43 +03:00
spinlock_t slock ;
2005-04-17 02:20:36 +04:00
struct v4l2_prio_state prio ;
2007-04-27 19:31:17 +04:00
/* workstruct for loading modules */
struct work_struct request_module_wk ;
2005-04-17 02:20:36 +04:00
2006-10-31 01:56:59 +03:00
/* insmod option/autodetected */
int autodetected ;
2005-04-17 02:20:36 +04:00
/* various device info */
unsigned int resources ;
struct video_device * video_dev ;
struct video_device * radio_dev ;
struct video_device * vbi_dev ;
2005-11-09 08:38:54 +03:00
struct saa7134_dmasound dmasound ;
2005-04-17 02:20:36 +04:00
/* infrared remote */
int has_remote ;
2006-12-08 03:45:28 +03:00
struct card_ir * remote ;
2005-04-17 02:20:36 +04:00
/* pci i/o */
char name [ 32 ] ;
int nr ;
struct pci_dev * pci ;
unsigned char pci_rev , pci_lat ;
__u32 __iomem * lmmio ;
__u8 __iomem * bmmio ;
/* config info */
unsigned int board ;
unsigned int tuner_type ;
2005-07-13 00:59:01 +04:00
unsigned int radio_type ;
unsigned char tuner_addr ;
unsigned char radio_addr ;
2005-04-17 02:20:36 +04:00
unsigned int tda9887_conf ;
unsigned int gpio_value ;
/* i2c i/o */
struct i2c_adapter i2c_adap ;
struct i2c_client i2c_client ;
2007-11-15 16:34:33 +03:00
unsigned char eedata [ 256 ] ;
2005-04-17 02:20:36 +04:00
/* video overlay */
struct v4l2_framebuffer ovbuf ;
struct saa7134_format * ovfmt ;
unsigned int ovenable ;
enum v4l2_field ovfield ;
/* video+ts+vbi capture */
struct saa7134_dmaqueue video_q ;
struct saa7134_dmaqueue vbi_q ;
unsigned int video_fieldcount ;
unsigned int vbi_fieldcount ;
/* various v4l controls */
struct saa7134_tvnorm * tvnorm ; /* video */
struct saa7134_tvaudio * tvaudio ;
unsigned int ctl_input ;
int ctl_bright ;
int ctl_contrast ;
int ctl_hue ;
int ctl_saturation ;
int ctl_freq ;
int ctl_mute ; /* audio */
int ctl_volume ;
int ctl_invert ; /* private */
int ctl_mirror ;
int ctl_y_odd ;
int ctl_y_even ;
int ctl_automute ;
/* crop */
struct v4l2_rect crop_bounds ;
struct v4l2_rect crop_defrect ;
struct v4l2_rect crop_current ;
/* other global state info */
unsigned int automute ;
struct saa7134_thread thread ;
struct saa7134_input * input ;
struct saa7134_input * hw_input ;
unsigned int hw_mute ;
int last_carrier ;
int nosignal ;
2007-10-12 07:57:15 +04:00
unsigned int insuspend ;
2005-04-17 02:20:36 +04:00
/* SAA7134_MPEG_* */
struct saa7134_ts ts ;
struct saa7134_dmaqueue ts_q ;
struct saa7134_mpeg_ops * mops ;
2008-06-28 04:18:15 +04:00
struct i2c_client * mpeg_i2c_client ;
2005-04-17 02:20:36 +04:00
/* SAA7134_MPEG_EMPRESS only */
struct video_device * empress_dev ;
struct videobuf_queue empress_tsq ;
2008-07-26 16:01:24 +04:00
atomic_t empress_users ;
2005-04-17 02:20:36 +04:00
struct work_struct empress_workqueue ;
int empress_started ;
2007-10-04 11:54:11 +04:00
# if defined(CONFIG_VIDEO_SAA7134_DVB) || defined(CONFIG_VIDEO_SAA7134_DVB_MODULE)
2005-04-17 02:20:36 +04:00
/* SAA7134_MPEG_DVB only */
struct videobuf_dvb dvb ;
2008-04-22 21:42:12 +04:00
int ( * original_demod_sleep ) ( struct dvb_frontend * fe ) ;
int ( * original_set_voltage ) ( struct dvb_frontend * fe , fe_sec_voltage_t voltage ) ;
int ( * original_set_high_voltage ) ( struct dvb_frontend * fe , long arg ) ;
2007-01-31 05:26:01 +03:00
# endif
2005-04-17 02:20:36 +04:00
} ;
/* ----------------------------------------------------------- */
# define saa_readl(reg) readl(dev->lmmio + (reg))
# define saa_writel(reg,value) writel((value), dev->lmmio + (reg));
# define saa_andorl(reg,mask,value) \
writel ( ( readl ( dev - > lmmio + ( reg ) ) & ~ ( mask ) ) | \
( ( value ) & ( mask ) ) , dev - > lmmio + ( reg ) )
# define saa_setl(reg,bit) saa_andorl((reg),(bit),(bit))
# define saa_clearl(reg,bit) saa_andorl((reg),(bit),0)
# define saa_readb(reg) readb(dev->bmmio + (reg))
# define saa_writeb(reg,value) writeb((value), dev->bmmio + (reg));
# define saa_andorb(reg,mask,value) \
writeb ( ( readb ( dev - > bmmio + ( reg ) ) & ~ ( mask ) ) | \
( ( value ) & ( mask ) ) , dev - > bmmio + ( reg ) )
# define saa_setb(reg,bit) saa_andorb((reg),(bit),(bit))
# define saa_clearb(reg,bit) saa_andorb((reg),(bit),0)
# define saa_wait(us) { udelay(us); }
2007-12-11 18:56:23 +03:00
# define SAA7134_NORMS (\
V4L2_STD_PAL | V4L2_STD_PAL_N | \
V4L2_STD_PAL_Nc | V4L2_STD_SECAM | \
V4L2_STD_NTSC | V4L2_STD_PAL_M | \
V4L2_STD_PAL_60 )
2005-04-17 02:20:36 +04:00
/* ----------------------------------------------------------- */
/* saa7134-core.c */
extern struct list_head saa7134_devlist ;
2006-03-18 02:54:32 +03:00
extern int saa7134_no_overlay ;
2005-04-17 02:20:36 +04:00
void saa7134_track_gpio ( struct saa7134_dev * dev , char * msg ) ;
2007-04-27 19:31:11 +04:00
void saa7134_set_gpio ( struct saa7134_dev * dev , int bit_no , int value ) ;
2005-04-17 02:20:36 +04:00
# define SAA7134_PGTABLE_SIZE 4096
int saa7134_pgtable_alloc ( struct pci_dev * pci , struct saa7134_pgtable * pt ) ;
int saa7134_pgtable_build ( struct pci_dev * pci , struct saa7134_pgtable * pt ,
struct scatterlist * list , unsigned int length ,
unsigned int startpage ) ;
void saa7134_pgtable_free ( struct pci_dev * pci , struct saa7134_pgtable * pt ) ;
int saa7134_buffer_count ( unsigned int size , unsigned int count ) ;
int saa7134_buffer_startpage ( struct saa7134_buf * buf ) ;
unsigned long saa7134_buffer_base ( struct saa7134_buf * buf ) ;
int saa7134_buffer_queue ( struct saa7134_dev * dev , struct saa7134_dmaqueue * q ,
struct saa7134_buf * buf ) ;
void saa7134_buffer_finish ( struct saa7134_dev * dev , struct saa7134_dmaqueue * q ,
unsigned int state ) ;
void saa7134_buffer_next ( struct saa7134_dev * dev , struct saa7134_dmaqueue * q ) ;
void saa7134_buffer_timeout ( unsigned long data ) ;
2006-03-10 18:29:15 +03:00
void saa7134_dma_free ( struct videobuf_queue * q , struct saa7134_buf * buf ) ;
2005-04-17 02:20:36 +04:00
int saa7134_set_dmabits ( struct saa7134_dev * dev ) ;
2006-07-15 22:19:56 +04:00
extern int ( * saa7134_dmasound_init ) ( struct saa7134_dev * dev ) ;
extern int ( * saa7134_dmasound_exit ) ( struct saa7134_dev * dev ) ;
2005-12-01 11:51:20 +03:00
2005-04-17 02:20:36 +04:00
/* ----------------------------------------------------------- */
/* saa7134-cards.c */
extern struct saa7134_board saa7134_boards [ ] ;
extern const unsigned int saa7134_bcount ;
extern struct pci_device_id __devinitdata saa7134_pci_tbl [ ] ;
extern int saa7134_board_init1 ( struct saa7134_dev * dev ) ;
extern int saa7134_board_init2 ( struct saa7134_dev * dev ) ;
2008-04-22 21:45:27 +04:00
int saa7134_tuner_callback ( void * priv , int command , int arg ) ;
2005-04-17 02:20:36 +04:00
/* ----------------------------------------------------------- */
/* saa7134-i2c.c */
int saa7134_i2c_register ( struct saa7134_dev * dev ) ;
int saa7134_i2c_unregister ( struct saa7134_dev * dev ) ;
void saa7134_i2c_call_clients ( struct saa7134_dev * dev ,
unsigned int cmd , void * arg ) ;
/* ----------------------------------------------------------- */
/* saa7134-video.c */
2007-12-07 23:34:48 +03:00
extern unsigned int video_debug ;
2005-04-17 02:20:36 +04:00
extern struct video_device saa7134_video_template ;
extern struct video_device saa7134_radio_template ;
2007-12-11 18:56:23 +03:00
int saa7134_g_ctrl ( struct file * file , void * priv , struct v4l2_control * c ) ;
int saa7134_s_ctrl ( struct file * file , void * f , struct v4l2_control * c ) ;
int saa7134_queryctrl ( struct file * file , void * priv , struct v4l2_queryctrl * c ) ;
2007-09-28 03:34:25 +04:00
int saa7134_videoport_init ( struct saa7134_dev * dev ) ;
2007-10-12 07:57:15 +04:00
void saa7134_set_tvnorm_hw ( struct saa7134_dev * dev ) ;
2007-09-28 03:34:25 +04:00
2005-04-17 02:20:36 +04:00
int saa7134_video_init1 ( struct saa7134_dev * dev ) ;
int saa7134_video_init2 ( struct saa7134_dev * dev ) ;
2007-09-28 03:44:39 +04:00
void saa7134_irq_video_signalchange ( struct saa7134_dev * dev ) ;
2005-04-17 02:20:36 +04:00
void saa7134_irq_video_done ( struct saa7134_dev * dev , unsigned long status ) ;
/* ----------------------------------------------------------- */
/* saa7134-ts.c */
# define TS_PACKET_SIZE 188 /* TS packets 188 bytes */
extern struct videobuf_queue_ops saa7134_ts_qops ;
int saa7134_ts_init1 ( struct saa7134_dev * dev ) ;
int saa7134_ts_fini ( struct saa7134_dev * dev ) ;
void saa7134_irq_ts_done ( struct saa7134_dev * dev , unsigned long status ) ;
int saa7134_ts_register ( struct saa7134_mpeg_ops * ops ) ;
void saa7134_ts_unregister ( struct saa7134_mpeg_ops * ops ) ;
2007-09-28 03:34:25 +04:00
int saa7134_ts_init_hw ( struct saa7134_dev * dev ) ;
2005-04-17 02:20:36 +04:00
/* ----------------------------------------------------------- */
/* saa7134-vbi.c */
extern struct videobuf_queue_ops saa7134_vbi_qops ;
extern struct video_device saa7134_vbi_template ;
int saa7134_vbi_init1 ( struct saa7134_dev * dev ) ;
int saa7134_vbi_fini ( struct saa7134_dev * dev ) ;
void saa7134_irq_vbi_done ( struct saa7134_dev * dev , unsigned long status ) ;
/* ----------------------------------------------------------- */
/* saa7134-tvaudio.c */
int saa7134_tvaudio_rx2mode ( u32 rx ) ;
void saa7134_tvaudio_setmute ( struct saa7134_dev * dev ) ;
void saa7134_tvaudio_setinput ( struct saa7134_dev * dev ,
struct saa7134_input * in ) ;
void saa7134_tvaudio_setvolume ( struct saa7134_dev * dev , int level ) ;
int saa7134_tvaudio_getstereo ( struct saa7134_dev * dev ) ;
2007-10-23 07:58:59 +04:00
void saa7134_tvaudio_init ( struct saa7134_dev * dev ) ;
2005-04-17 02:20:36 +04:00
int saa7134_tvaudio_init2 ( struct saa7134_dev * dev ) ;
int saa7134_tvaudio_fini ( struct saa7134_dev * dev ) ;
int saa7134_tvaudio_do_scan ( struct saa7134_dev * dev ) ;
int saa_dsp_writel ( struct saa7134_dev * dev , int reg , u32 value ) ;
2007-09-28 03:34:25 +04:00
void saa7134_enable_i2s ( struct saa7134_dev * dev ) ;
2005-04-17 02:20:36 +04:00
/* ----------------------------------------------------------- */
/* saa7134-oss.c */
2007-02-12 11:55:33 +03:00
extern const struct file_operations saa7134_dsp_fops ;
extern const struct file_operations saa7134_mixer_fops ;
2005-04-17 02:20:36 +04:00
int saa7134_oss_init1 ( struct saa7134_dev * dev ) ;
int saa7134_oss_fini ( struct saa7134_dev * dev ) ;
void saa7134_irq_oss_done ( struct saa7134_dev * dev , unsigned long status ) ;
/* ----------------------------------------------------------- */
/* saa7134-input.c */
int saa7134_input_init1 ( struct saa7134_dev * dev ) ;
void saa7134_input_fini ( struct saa7134_dev * dev ) ;
void saa7134_input_irq ( struct saa7134_dev * dev ) ;
2005-11-09 08:37:56 +03:00
void saa7134_set_i2c_ir ( struct saa7134_dev * dev , struct IR_i2c * ir ) ;
2007-10-12 07:57:15 +04:00
void saa7134_ir_start ( struct saa7134_dev * dev , struct card_ir * ir ) ;
void saa7134_ir_stop ( struct saa7134_dev * dev ) ;
2005-11-09 08:37:56 +03:00
2006-12-08 03:45:28 +03:00
2005-04-17 02:20:36 +04:00
/*
* Local variables :
* c - basic - offset : 8
* End :
*/