2007-12-18 01:55:51 -03:00
/*
* Driver for Xceive XC5000 " QAM/8VSB single chip tuner "
*
2008-09-03 17:12:12 -03:00
* Copyright ( c ) 2007 Steven Toth < stoth @ linuxtv . org >
2007-12-18 01:55:51 -03:00
*
* 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 .
*/
# ifndef __XC5000_H__
# define __XC5000_H__
# include <linux/firmware.h>
struct dvb_frontend ;
struct i2c_adapter ;
2012-02-07 02:39:36 -03:00
# define XC5000_FW_A_1_6_114 1
# define XC5000_FW_C_41_024_5_31875 2
2012-02-06 19:40:32 -03:00
2012-02-07 02:39:36 -03:00
# define XC5000_DEFAULT_FIRMWARE XC5000_FW_A_1_6_114
# define XC5000C_DEFAULT_FIRMWARE XC5000_FW_C_41_024_5_31875
2012-02-06 19:40:32 -03:00
2007-12-18 01:55:51 -03:00
struct xc5000_config {
2008-01-05 16:50:14 -03:00
u8 i2c_address ;
u32 if_khz ;
2009-09-24 13:27:24 -03:00
u8 radio_input ;
2012-02-06 19:40:32 -03:00
2012-02-07 02:39:36 -03:00
int fw ;
2007-12-18 01:55:51 -03:00
} ;
2008-01-05 16:50:14 -03:00
/* xc5000 callback command */
# define XC5000_TUNER_RESET 0
2009-09-24 13:27:24 -03:00
/* Possible Radio inputs */
# define XC5000_RADIO_NOT_CONFIGURED 0
# define XC5000_RADIO_FM1 1
# define XC5000_RADIO_FM2 2
2011-02-01 05:25:19 -03:00
# define XC5000_RADIO_FM1_MONO 3
2009-09-24 13:27:24 -03:00
2008-05-10 14:34:09 -03:00
/* For each bridge framework, when it attaches either analog or digital,
* it has to store a reference back to its _core equivalent structure ,
* so that it can service the hardware by steering gpio ' s etc .
* Each bridge implementation is different so cast devptr accordingly .
* The xc5000 driver cares not for this value , other than ensuring
* it ' s passed back to a bridge during tuner_callback ( ) .
*/
2008-04-29 21:38:46 -03:00
# if defined(CONFIG_MEDIA_TUNER_XC5000) || \
( defined ( CONFIG_MEDIA_TUNER_XC5000_MODULE ) & & defined ( MODULE ) )
2008-10-16 20:29:38 -03:00
extern struct dvb_frontend * xc5000_attach ( struct dvb_frontend * fe ,
2007-12-18 01:55:51 -03:00
struct i2c_adapter * i2c ,
2010-08-25 09:50:20 -03:00
const struct xc5000_config * cfg ) ;
2007-12-18 01:55:51 -03:00
# else
2008-10-16 20:29:38 -03:00
static inline struct dvb_frontend * xc5000_attach ( struct dvb_frontend * fe ,
2007-12-18 01:55:51 -03:00
struct i2c_adapter * i2c ,
2010-08-25 09:50:20 -03:00
const struct xc5000_config * cfg )
2007-12-18 01:55:51 -03:00
{
2008-04-08 23:20:00 -03:00
printk ( KERN_WARNING " %s: driver disabled by Kconfig \n " , __func__ ) ;
2007-12-18 01:55:51 -03:00
return NULL ;
}
2008-10-16 20:29:38 -03:00
# endif
2007-12-18 01:55:51 -03:00
2008-10-16 20:29:38 -03:00
# endif