2005-04-17 02:20:36 +04:00
/*
*
* i2c tv tuner chip device driver
* controls all those simple 4 - control - bytes style tuners .
*/
# include <linux/delay.h>
# include <linux/i2c.h>
# include <linux/videodev.h>
# include <media/tuner.h>
2006-01-09 20:25:11 +03:00
static int offset = 0 ;
module_param ( offset , int , 0666 ) ;
MODULE_PARM_DESC ( offset , " Allows to specify an offset for tuner " ) ;
2005-04-17 02:20:36 +04:00
/* ---------------------------------------------------------------------- */
/* tv standard selection for Temic 4046 FM5
this value takes the low bits of control byte 2
from datasheet Rev .01 , Feb .00
standard BG I L L2 D
picture IF 38.9 38.9 38.9 33.95 38.9
sound 1 33.4 32.9 32.4 40.45 32.4
sound 2 33.16
NICAM 33.05 32.348 33.05 33.05
*/
# define TEMIC_SET_PAL_I 0x05
# define TEMIC_SET_PAL_DK 0x09
# define TEMIC_SET_PAL_L 0x0a // SECAM ?
# define TEMIC_SET_PAL_L2 0x0b // change IF !
# define TEMIC_SET_PAL_BG 0x0c
/* tv tuner system standard selection for Philips FQ1216ME
this value takes the low bits of control byte 2
from datasheet " 1999 Nov 16 " ( supersedes " 1999 Mar 23 " )
standard BG DK I L L `
picture carrier 38.90 38.90 38.90 38.90 33.95
colour 34.47 34.47 34.47 34.47 38.38
sound 1 33.40 32.40 32.90 32.40 40.45
sound 2 33.16 - - - -
NICAM 33.05 33.05 32.35 33.05 39.80
*/
# define PHILIPS_SET_PAL_I 0x01 /* Bit 2 always zero !*/
# define PHILIPS_SET_PAL_BGDK 0x09
# define PHILIPS_SET_PAL_L2 0x0a
# define PHILIPS_SET_PAL_L 0x0b
/* system switching for Philips FI1216MF MK2
from datasheet " 1996 Jul 09 " ,
standard BG L L '
picture carrier 38.90 38.90 33.95
colour 34.47 34.37 38.38
sound 1 33.40 32.40 40.45
sound 2 33.16 - -
NICAM 33.05 33.05 39.80
*/
# define PHILIPS_MF_SET_BG 0x01 /* Bit 2 must be zero, Bit 3 is system output */
# define PHILIPS_MF_SET_PAL_L 0x03 // France
# define PHILIPS_MF_SET_PAL_L2 0x02 // L'
2005-07-13 00:58:55 +04:00
/* Control byte */
# define TUNER_RATIO_MASK 0x06 /* Bit cb1:cb2 */
# define TUNER_RATIO_SELECT_50 0x00
# define TUNER_RATIO_SELECT_32 0x02
# define TUNER_RATIO_SELECT_166 0x04
# define TUNER_RATIO_SELECT_62 0x06
# define TUNER_CHARGE_PUMP 0x40 /* Bit cb6 */
/* Status byte */
# define TUNER_POR 0x80
# define TUNER_FL 0x40
# define TUNER_MODE 0x38
# define TUNER_AFC 0x07
# define TUNER_SIGNAL 0x07
# define TUNER_STEREO 0x10
# define TUNER_PLL_LOCKED 0x40
# define TUNER_STEREO_MK3 0x04
2005-04-17 02:20:36 +04:00
2006-01-09 20:25:38 +03:00
# define TUNER_MAX_RANGES 3
2005-04-17 02:20:36 +04:00
/* ---------------------------------------------------------------------- */
struct tunertype
{
char * name ;
2006-01-09 20:25:38 +03:00
int count ;
struct {
unsigned short thresh ;
unsigned char cb ;
} ranges [ TUNER_MAX_RANGES ] ;
2005-04-17 02:20:36 +04:00
unsigned char config ;
} ;
/*
* The floats in the tuner struct are computed at compile time
* by gcc and cast back to integers . Thus we don ' t violate the
* " no float in kernel " rule .
*/
static struct tunertype tuners [ ] = {
2005-09-10 00:03:52 +04:00
/* 0-9 */
2006-01-09 20:25:03 +03:00
[ TUNER_TEMIC_PAL ] = { /* TEMIC PAL */
. name = " Temic PAL (4002 FH5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 140.25 /*MHz*/ , 0x02 , } ,
{ 16 * 463.25 /*MHz*/ , 0x04 , } ,
{ 16 * 999.99 , 0x01 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_PAL_I ] = { /* Philips PAL_I */
. name = " Philips PAL_I (FI1246 and compatibles) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 140.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 463.25 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_NTSC ] = { /* Philips NTSC */
. name = " Philips NTSC (FI1236,FM1236 and compatibles) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 451.25 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_SECAM ] = { /* Philips SECAM */
. name = " Philips (SECAM+PAL_BG) (FI1216MF, FM1216MF, FR1216MF) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 168.25 /*MHz*/ , 0xa7 , } ,
{ 16 * 447.25 /*MHz*/ , 0x97 , } ,
{ 16 * 999.99 , 0x37 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_ABSENT ] = { /* Tuner Absent */
. name = " NoTuner " ,
2006-01-09 20:25:38 +03:00
. count = 1 ,
. ranges = {
{ 0 , 0x00 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x00 ,
} ,
[ TUNER_PHILIPS_PAL ] = { /* Philips PAL */
. name = " Philips PAL_BG (FI1216 and compatibles) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 168.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 447.25 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_NTSC ] = { /* TEMIC NTSC */
. name = " Temic NTSC (4032 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0x02 , } ,
{ 16 * 463.25 /*MHz*/ , 0x04 , } ,
{ 16 * 999.99 , 0x01 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_PAL_I ] = { /* TEMIC PAL_I */
. name = " Temic PAL_I (4062 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0x02 , } ,
{ 16 * 450.00 /*MHz*/ , 0x04 , } ,
{ 16 * 999.99 , 0x01 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4036FY5_NTSC ] = { /* TEMIC NTSC */
. name = " Temic NTSC (4036 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 463.25 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_ALPS_TSBH1_NTSC ] = { /* TEMIC NTSC */
. name = " Alps HSBH1 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 137.25 /*MHz*/ , 0x01 , } ,
{ 16 * 385.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-09-10 00:03:52 +04:00
/* 10-19 */
2006-01-09 20:25:03 +03:00
[ TUNER_ALPS_TSBE1_PAL ] = { /* TEMIC PAL */
. name = " Alps TSBE1 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 137.25 /*MHz*/ , 0x01 , } ,
{ 16 * 385.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_ALPS_TSBB5_PAL_I ] = { /* Alps PAL_I */
. name = " Alps TSBB5 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 133.25 /*MHz*/ , 0x01 , } ,
{ 16 * 351.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_ALPS_TSBE5_PAL ] = { /* Alps PAL */
. name = " Alps TSBE5 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 133.25 /*MHz*/ , 0x01 , } ,
{ 16 * 351.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_ALPS_TSBC5_PAL ] = { /* Alps PAL */
. name = " Alps TSBC5 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 133.25 /*MHz*/ , 0x01 , } ,
{ 16 * 351.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4006FH5_PAL ] = { /* TEMIC PAL */
. name = " Temic PAL_BG (4006FH5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_ALPS_TSHC6_NTSC ] = { /* Alps NTSC */
. name = " Alps TSCH6 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 137.25 /*MHz*/ , 0x14 , } ,
{ 16 * 385.25 /*MHz*/ , 0x12 , } ,
{ 16 * 999.99 , 0x11 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_PAL_DK ] = { /* TEMIC PAL */
. name = " Temic PAL_DK (4016 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 168.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 456.25 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_NTSC_M ] = { /* Philips NTSC */
. name = " Philips NTSC_M (MK2) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 454.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4066FY5_PAL_I ] = { /* TEMIC PAL_I */
. name = " Temic PAL_I (4066 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 169.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 454.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4006FN5_MULTI_PAL ] = { /* TEMIC PAL */
. name = " Temic PAL* auto (4006 FN5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 169.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 454.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-04-17 02:20:36 +04:00
2005-09-10 00:03:52 +04:00
/* 20-29 */
2006-01-09 20:25:03 +03:00
[ TUNER_TEMIC_4009FR5_PAL ] = { /* TEMIC PAL */
. name = " Temic PAL_BG (4009 FR5) or PAL_I (4069 FR5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 141.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 464.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4039FR5_NTSC ] = { /* TEMIC NTSC */
. name = " Temic NTSC (4039 FR5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 158.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 453.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4046FM5 ] = { /* TEMIC PAL */
. name = " Temic PAL/SECAM multi (4046 FM5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 169.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 454.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_PAL_DK ] = { /* Philips PAL */
. name = " Philips PAL_DK (FI1256 and compatibles) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_FQ1216ME ] = { /* Philips PAL */
. name = " Philips PAL/SECAM multi (FQ1216ME) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_PAL_I_FM ] = { /* LGINNOTEK PAL_I */
. name = " LG PAL_I+FM (TAPC-I001D) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_PAL_I ] = { /* LGINNOTEK PAL_I */
. name = " LG PAL_I (TAPC-I701D) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_NTSC_FM ] = { /* LGINNOTEK NTSC */
. name = " LG NTSC+FM (TPI8NSR01F) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 210.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 497.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_PAL_FM ] = { /* LGINNOTEK PAL */
. name = " LG PAL_BG+FM (TPI8PSB01D) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_PAL ] = { /* LGINNOTEK PAL */
. name = " LG PAL_BG (TPI8PSB11D) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 450.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-09-10 00:03:52 +04:00
/* 30-39 */
2006-01-09 20:25:03 +03:00
[ TUNER_TEMIC_4009FN5_MULTI_PAL_FM ] = { /* TEMIC PAL */
. name = " Temic PAL* auto + FM (4009 FN5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 141.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 464.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_SHARP_2U5JF5540_NTSC ] = { /* SHARP NTSC */
. name = " SHARP NTSC_JP (2U5JF5540) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 137.25 /*MHz*/ , 0x01 , } ,
{ 16 * 317.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_Samsung_PAL_TCPM9091PD27 ] = { /* Samsung PAL */
. name = " Samsung PAL TCPM9091PD27 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 169 /*MHz*/ , 0xa0 , } ,
{ 16 * 464 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_MT2032 ] = { /* Microtune PAL|NTSC */
. name = " MT20xx universal " ,
2005-04-17 02:20:36 +04:00
/* see mt20xx.c for details */ } ,
2006-01-09 20:25:03 +03:00
[ TUNER_TEMIC_4106FH5 ] = { /* TEMIC PAL */
. name = " Temic PAL_BG (4106 FH5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 141.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 464.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4012FY5 ] = { /* TEMIC PAL */
. name = " Temic PAL_DK/SECAM_L (4012 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 140.25 /*MHz*/ , 0x02 , } ,
{ 16 * 463.25 /*MHz*/ , 0x04 , } ,
{ 16 * 999.99 , 0x01 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEMIC_4136FY5 ] = { /* TEMIC NTSC */
. name = " Temic NTSC (4136 FY5) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 158.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 453.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_PAL_NEW_TAPC ] = { /* LGINNOTEK PAL */
. name = " LG PAL (newer TAPC series) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0x01 , } ,
{ 16 * 450.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_FM1216ME_MK3 ] = { /* Philips PAL */
. name = " Philips PAL/SECAM multi (FM1216ME MK3) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 158.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_NTSC_NEW_TAPC ] = { /* LGINNOTEK NTSC */
. name = " LG NTSC (newer TAPC series) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0x01 , } ,
{ 16 * 450.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-04-17 02:20:36 +04:00
2005-09-10 00:03:52 +04:00
/* 40-49 */
2006-01-09 20:25:03 +03:00
[ TUNER_HITACHI_NTSC ] = { /* HITACHI NTSC */
. name = " HITACHI V7-J180AT " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0x01 , } ,
{ 16 * 450.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_PAL_MK ] = { /* Philips PAL */
. name = " Philips PAL_MK (FI1216 MK) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 140.25 /*MHz*/ , 0x01 , } ,
{ 16 * 463.25 /*MHz*/ , 0xc2 , } ,
{ 16 * 999.99 , 0xcf , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_ATSC ] = { /* Philips ATSC */
2006-01-09 20:25:26 +03:00
. name = " Philips 1236D ATSC/NTSC dual in " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 454.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_FM1236_MK3 ] = { /* Philips NTSC */
. name = " Philips NTSC MK3 (FM1236MK3 or FM1236/F) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_4IN1 ] = { /* Philips NTSC */
. name = " Philips 4 in 1 (ATI TV Wonder Pro/Conexant) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_MICROTUNE_4049FM5 ] = { /* Microtune PAL */
. name = " Microtune 4049 FM5 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 141.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 464.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2006-01-09 20:25:10 +03:00
[ TUNER_PANASONIC_VP27 ] = { /* Panasonic NTSC */
2006-01-09 20:25:03 +03:00
. name = " Panasonic VP27s/ENGE4324D " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 454.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0xce ,
} ,
[ TUNER_LG_NTSC_TAPE ] = { /* LGINNOTEK NTSC */
. name = " LG NTSC (TAPE series) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TNF_8831BGFF ] = { /* Philips PAL */
. name = " Tenna TNF 8831 BGFF) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 161.25 /*MHz*/ , 0xa0 , } ,
{ 16 * 463.25 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_MICROTUNE_4042FI5 ] = { /* Microtune NTSC */
. name = " Microtune 4042 FI5 ATSC/NTSC dual in " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 162.00 /*MHz*/ , 0xa2 , } ,
{ 16 * 457.00 /*MHz*/ , 0x94 , } ,
{ 16 * 999.99 , 0x31 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-09-10 00:03:52 +04:00
/* 50-59 */
2006-01-09 20:25:03 +03:00
[ TUNER_TCL_2002N ] = { /* TCL NTSC */
. name = " TCL 2002N " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 172.00 /*MHz*/ , 0x01 , } ,
{ 16 * 448.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_FM1256_IH3 ] = { /* Philips PAL */
. name = " Philips PAL/SECAM_D (FM 1256 I-H3) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_THOMSON_DTT7610 ] = { /* THOMSON ATSC */
2006-01-09 20:25:29 +03:00
. name = " Thomson DTT 7610 (ATSC/NTSC) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0x39 , } ,
{ 16 * 454.00 /*MHz*/ , 0x3a , } ,
{ 16 * 999.99 , 0x3c , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_FQ1286 ] = { /* Philips NTSC */
. name = " Philips FQ1286 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x41 , } ,
{ 16 * 454.00 /*MHz*/ , 0x42 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_TDA8290 ] = { /* Philips PAL|NTSC */
. name = " tda8290+75 " ,
2005-04-17 02:20:36 +04:00
/* see tda8290.c for details */ } ,
2006-01-09 20:25:03 +03:00
[ TUNER_TCL_2002MB ] = { /* TCL PAL */
. name = " TCL 2002MB " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 170.00 /*MHz*/ , 0x01 , } ,
{ 16 * 450.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0xce ,
} ,
[ TUNER_PHILIPS_FQ1216AME_MK4 ] = { /* Philips PAL */
. name = " Philips PAL/SECAM multi (FQ1216AME MK4) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0xce ,
} ,
[ TUNER_PHILIPS_FQ1236A_MK4 ] = { /* Philips NTSC */
. name = " Philips FQ1236A MK4 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 442.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_YMEC_TVF_8531MF ] = { /* Philips NTSC */
. name = " Ymec TVision TVF-8531MF/8831MF/8731MF " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0xa0 , } ,
{ 16 * 454.00 /*MHz*/ , 0x90 , } ,
{ 16 * 999.99 , 0x30 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_YMEC_TVF_5533MF ] = { /* Philips NTSC */
. name = " Ymec TVision TVF-5533MF " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 , } ,
{ 16 * 454.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-07-13 00:58:55 +04:00
2005-11-14 03:07:50 +03:00
/* 60-69 */
2006-01-09 20:25:29 +03:00
[ TUNER_THOMSON_DTT761X ] = { /* THOMSON ATSC */
/* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
. name = " Thomson DTT 761X (ATSC/NTSC) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 145.25 /*MHz*/ , 0x39 , } ,
{ 16 * 415.25 /*MHz*/ , 0x3a , } ,
{ 16 * 999.99 , 0x3c , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TENA_9533_DI ] = { /* Philips PAL */
. name = " Tena TNF9533-D/IF/TNF9533-B/DF " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.25 /*MHz*/ , 0x01 , } ,
{ 16 * 464.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_TEA5767 ] = { /* Philips RADIO */
. name = " Philips TEA5767HN FM Radio " ,
2005-11-09 08:37:43 +03:00
/* see tea5767.c for details */ } ,
2006-01-09 20:25:03 +03:00
[ TUNER_PHILIPS_FMD1216ME_MK3 ] = { /* Philips PAL */
. name = " Philips FMD1216ME MK3 Hybrid Tuner " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x51 , } ,
{ 16 * 442.00 /*MHz*/ , 0x52 , } ,
{ 16 * 999.99 , 0x54 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x86 ,
} ,
[ TUNER_LG_TDVS_H062F ] = { /* LGINNOTEK ATSC */
. name = " LG TDVS-H062F/TUA6034 " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0x01 } ,
{ 16 * 455.00 /*MHz*/ , 0x02 } ,
{ 16 * 999.99 , 0x04 } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_YMEC_TVF66T5_B_DFF ] = { /* Philips PAL */
. name = " Ymec TVF66T5-B/DFF " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.25 /*MHz*/ , 0x01 , } ,
{ 16 * 464.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_LG_NTSC_TALN_MINI ] = { /* LGINNOTEK NTSC */
. name = " LG NTSC (TALN mini series) " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 137.25 /*MHz*/ , 0x01 , } ,
{ 16 * 373.25 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x08 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
[ TUNER_PHILIPS_TD1316 ] = { /* Philips PAL */
. name = " Philips TD1316 Hybrid Tuner " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 160.00 /*MHz*/ , 0xa1 , } ,
{ 16 * 442.00 /*MHz*/ , 0xa2 , } ,
{ 16 * 999.99 , 0xa4 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0xc8 ,
} ,
[ TUNER_PHILIPS_TUV1236D ] = { /* Philips ATSC */
. name = " Philips TUV1236D ATSC/NTSC dual in " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0x01 , } ,
{ 16 * 454.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0xce ,
} ,
[ TUNER_TNF_5335MF ] = { /* Philips NTSC */
. name = " Tena TNF 5335 MF " ,
2006-01-09 20:25:38 +03:00
. count = 3 ,
. ranges = {
{ 16 * 157.25 /*MHz*/ , 0x01 , } ,
{ 16 * 454.00 /*MHz*/ , 0x02 , } ,
{ 16 * 999.99 , 0x04 , } ,
} ,
2006-01-09 20:25:03 +03:00
. config = 0x8e ,
} ,
2005-04-17 02:20:36 +04:00
} ;
2005-06-24 09:05:07 +04:00
2005-04-17 02:20:36 +04:00
unsigned const int tuner_count = ARRAY_SIZE ( tuners ) ;
/* ---------------------------------------------------------------------- */
static int tuner_getstatus ( struct i2c_client * c )
{
unsigned char byte ;
if ( 1 ! = i2c_master_recv ( c , & byte , 1 ) )
return 0 ;
2005-06-24 09:05:07 +04:00
2005-04-17 02:20:36 +04:00
return byte ;
}
static int tuner_signal ( struct i2c_client * c )
{
2005-06-24 09:05:07 +04:00
return ( tuner_getstatus ( c ) & TUNER_SIGNAL ) < < 13 ;
2005-04-17 02:20:36 +04:00
}
static int tuner_stereo ( struct i2c_client * c )
{
2005-06-24 09:05:07 +04:00
int stereo , status ;
struct tuner * t = i2c_get_clientdata ( c ) ;
status = tuner_getstatus ( c ) ;
switch ( t - > type ) {
2005-11-09 08:37:43 +03:00
case TUNER_PHILIPS_FM1216ME_MK3 :
2005-06-24 09:05:07 +04:00
case TUNER_PHILIPS_FM1236_MK3 :
case TUNER_PHILIPS_FM1256_IH3 :
stereo = ( ( status & TUNER_SIGNAL ) = = TUNER_STEREO_MK3 ) ;
break ;
default :
stereo = status & TUNER_STEREO ;
}
return stereo ;
2005-04-17 02:20:36 +04:00
}
/* ---------------------------------------------------------------------- */
static void default_set_tv_freq ( struct i2c_client * c , unsigned int freq )
{
struct tuner * t = i2c_get_clientdata ( c ) ;
2005-11-09 08:38:19 +03:00
u8 config , tuneraddr ;
2005-04-17 02:20:36 +04:00
u16 div ;
struct tunertype * tun ;
2005-11-09 08:37:43 +03:00
unsigned char buffer [ 4 ] ;
2006-01-09 20:25:38 +03:00
int rc , IFPCoff , i ;
2005-04-17 02:20:36 +04:00
tun = & tuners [ t - > type ] ;
2006-01-09 20:25:38 +03:00
for ( i = 0 ; i < tun - > count ; i + + ) {
if ( freq > tun - > ranges [ i ] . thresh )
continue ;
break ;
2005-04-17 02:20:36 +04:00
}
2006-01-09 20:25:38 +03:00
config = tun - > ranges [ i ] . cb ;
/* i == 0 -> VHF_LO */
/* i == 1 -> VHF_HI */
/* i == 2 -> UHF */
tuner_dbg ( " tv: range %d \n " , i ) ;
2005-04-17 02:20:36 +04:00
/* tv norm specific stuff for multi-norm tuners */
switch ( t - > type ) {
case TUNER_PHILIPS_SECAM : // FI1216MF
/* 0x01 -> ??? no change ??? */
/* 0x02 -> PAL BDGHI / SECAM L */
/* 0x04 -> ??? PAL others / SECAM others ??? */
config & = ~ 0x02 ;
if ( t - > std & V4L2_STD_SECAM )
config | = 0x02 ;
break ;
case TUNER_TEMIC_4046FM5 :
config & = ~ 0x0f ;
if ( t - > std & V4L2_STD_PAL_BG ) {
config | = TEMIC_SET_PAL_BG ;
} else if ( t - > std & V4L2_STD_PAL_I ) {
config | = TEMIC_SET_PAL_I ;
} else if ( t - > std & V4L2_STD_PAL_DK ) {
config | = TEMIC_SET_PAL_DK ;
} else if ( t - > std & V4L2_STD_SECAM_L ) {
config | = TEMIC_SET_PAL_L ;
}
break ;
case TUNER_PHILIPS_FQ1216ME :
config & = ~ 0x0f ;
if ( t - > std & ( V4L2_STD_PAL_BG | V4L2_STD_PAL_DK ) ) {
config | = PHILIPS_SET_PAL_BGDK ;
} else if ( t - > std & V4L2_STD_PAL_I ) {
config | = PHILIPS_SET_PAL_I ;
} else if ( t - > std & V4L2_STD_SECAM_L ) {
config | = PHILIPS_SET_PAL_L ;
}
break ;
case TUNER_PHILIPS_ATSC :
/* 0x00 -> ATSC antenna input 1 */
/* 0x01 -> ATSC antenna input 2 */
/* 0x02 -> NTSC antenna input 1 */
/* 0x03 -> NTSC antenna input 2 */
config & = ~ 0x03 ;
if ( ! ( t - > std & V4L2_STD_ATSC ) )
config | = 2 ;
/* FIXME: input */
break ;
case TUNER_MICROTUNE_4042FI5 :
/* Set the charge pump for fast tuning */
2005-07-13 00:58:55 +04:00
tun - > config | = TUNER_CHARGE_PUMP ;
2005-04-17 02:20:36 +04:00
break ;
2005-11-09 08:37:04 +03:00
case TUNER_PHILIPS_TUV1236D :
/* 0x40 -> ATSC antenna input 1 */
/* 0x48 -> ATSC antenna input 2 */
/* 0x00 -> NTSC antenna input 1 */
/* 0x08 -> NTSC antenna input 2 */
2005-11-09 08:38:18 +03:00
buffer [ 0 ] = 0x14 ;
buffer [ 1 ] = 0x00 ;
buffer [ 2 ] = 0x17 ;
buffer [ 3 ] = 0x00 ;
2005-11-09 08:37:04 +03:00
config & = ~ 0x40 ;
2005-11-09 08:38:18 +03:00
if ( t - > std & V4L2_STD_ATSC ) {
2005-11-09 08:37:04 +03:00
config | = 0x40 ;
2005-11-09 08:38:18 +03:00
buffer [ 1 ] = 0x04 ;
}
/* set to the correct mode (analog or digital) */
tuneraddr = c - > addr ;
c - > addr = 0x0a ;
if ( 2 ! = ( rc = i2c_master_send ( c , & buffer [ 0 ] , 2 ) ) )
tuner_warn ( " i2c i/o error: rc == %d (should be 2) \n " , rc ) ;
if ( 2 ! = ( rc = i2c_master_send ( c , & buffer [ 2 ] , 2 ) ) )
tuner_warn ( " i2c i/o error: rc == %d (should be 2) \n " , rc ) ;
c - > addr = tuneraddr ;
2005-11-09 08:37:04 +03:00
/* FIXME: input */
break ;
2005-04-17 02:20:36 +04:00
}
/*
* Philips FI1216MK2 remark from specification :
* for channel selection involving band switching , and to ensure
* smooth tuning to the desired channel without causing
* unnecessary charge pump action , it is recommended to consider
* the difference between wanted channel frequency and the
* current channel frequency . Unnecessary charge pump action
* will result in very low tuning voltage which may drive the
* oscillator to extreme conditions .
*
* Progfou : specification says to send config data before
* frequency in case ( wanted frequency < current frequency ) .
*/
2006-01-09 20:25:03 +03:00
/* IFPCoff = Video Intermediate Frequency - Vif:
940 = 16 * 58.75 NTSC / J ( Japan )
732 = 16 * 45.75 M / N STD
704 = 16 * 44 ATSC ( at DVB code )
632 = 16 * 39.50 I U . K .
622.4 = 16 * 38.90 B / G D / K I , L STD
592 = 16 * 37.00 D China
590 = 16.36 .875 B Australia
543.2 = 16 * 33.95 L ' STD
171.2 = 16 * 10.70 FM Radio ( at set_radio_freq )
*/
2006-01-09 20:25:19 +03:00
if ( t - > std = = V4L2_STD_NTSC_M_JP ) {
2006-01-09 20:25:03 +03:00
IFPCoff = 940 ;
2006-01-09 20:25:19 +03:00
} else if ( ( t - > std & V4L2_STD_MN ) & &
! ( t - > std & ~ V4L2_STD_MN ) ) {
2006-01-09 20:25:03 +03:00
IFPCoff = 732 ;
2006-01-09 20:25:19 +03:00
} else if ( t - > std = = V4L2_STD_SECAM_LC ) {
2006-01-09 20:25:03 +03:00
IFPCoff = 543 ;
} else {
IFPCoff = 623 ;
}
2006-01-09 20:25:11 +03:00
div = freq + IFPCoff + offset ;
2006-01-09 20:25:12 +03:00
tuner_dbg ( " Freq= %d.%02d MHz, V_IF=%d.%02d MHz, Offset=%d.%02d MHz, div=%0d \n " ,
freq / 16 , freq % 16 * 100 / 16 ,
IFPCoff / 16 , IFPCoff % 16 * 100 / 16 ,
offset / 16 , offset % 16 * 100 / 16 ,
div ) ;
2005-04-17 02:20:36 +04:00
if ( t - > type = = TUNER_PHILIPS_SECAM & & freq < t - > freq ) {
buffer [ 0 ] = tun - > config ;
buffer [ 1 ] = config ;
buffer [ 2 ] = ( div > > 8 ) & 0x7f ;
buffer [ 3 ] = div & 0xff ;
} else {
buffer [ 0 ] = ( div > > 8 ) & 0x7f ;
buffer [ 1 ] = div & 0xff ;
buffer [ 2 ] = tun - > config ;
buffer [ 3 ] = config ;
}
tuner_dbg ( " tv 0x%02x 0x%02x 0x%02x 0x%02x \n " ,
buffer [ 0 ] , buffer [ 1 ] , buffer [ 2 ] , buffer [ 3 ] ) ;
2005-11-09 08:37:43 +03:00
if ( 4 ! = ( rc = i2c_master_send ( c , buffer , 4 ) ) )
2005-04-17 02:20:36 +04:00
tuner_warn ( " i2c i/o error: rc == %d (should be 4) \n " , rc ) ;
if ( t - > type = = TUNER_MICROTUNE_4042FI5 ) {
// FIXME - this may also work for other tuners
unsigned long timeout = jiffies + msecs_to_jiffies ( 1 ) ;
u8 status_byte = 0 ;
/* Wait until the PLL locks */
for ( ; ; ) {
if ( time_after ( jiffies , timeout ) )
return ;
if ( 1 ! = ( rc = i2c_master_recv ( c , & status_byte , 1 ) ) ) {
tuner_warn ( " i2c i/o read error: rc == %d (should be 1) \n " , rc ) ;
break ;
}
2005-07-13 00:58:55 +04:00
if ( status_byte & TUNER_PLL_LOCKED )
2005-04-17 02:20:36 +04:00
break ;
udelay ( 10 ) ;
}
/* Set the charge pump for optimized phase noise figure */
2005-07-13 00:58:55 +04:00
tun - > config & = ~ TUNER_CHARGE_PUMP ;
2005-04-17 02:20:36 +04:00
buffer [ 0 ] = ( div > > 8 ) & 0x7f ;
buffer [ 1 ] = div & 0xff ;
buffer [ 2 ] = tun - > config ;
buffer [ 3 ] = config ;
tuner_dbg ( " tv 0x%02x 0x%02x 0x%02x 0x%02x \n " ,
buffer [ 0 ] , buffer [ 1 ] , buffer [ 2 ] , buffer [ 3 ] ) ;
if ( 4 ! = ( rc = i2c_master_send ( c , buffer , 4 ) ) )
tuner_warn ( " i2c i/o error: rc == %d (should be 4) \n " , rc ) ;
}
}
static void default_set_radio_freq ( struct i2c_client * c , unsigned int freq )
{
struct tunertype * tun ;
struct tuner * t = i2c_get_clientdata ( c ) ;
2005-11-09 08:37:43 +03:00
unsigned char buffer [ 4 ] ;
2005-04-17 02:20:36 +04:00
unsigned div ;
int rc ;
2005-07-13 00:58:55 +04:00
tun = & tuners [ t - > type ] ;
div = ( 20 * freq / 16000 ) + ( int ) ( 20 * 10.7 ) ; /* IF 10.7 MHz */
buffer [ 2 ] = ( tun - > config & ~ TUNER_RATIO_MASK ) | TUNER_RATIO_SELECT_50 ; /* 50 kHz step */
2005-04-17 02:20:36 +04:00
switch ( t - > type ) {
2005-06-24 09:05:07 +04:00
case TUNER_TENA_9533_DI :
2005-06-24 09:02:43 +04:00
case TUNER_YMEC_TVF_5533MF :
2005-07-13 00:58:55 +04:00
tuner_dbg ( " This tuner doesn't have FM. Most cards has a TEA5767 for FM \n " ) ;
return ;
2005-04-17 02:20:36 +04:00
case TUNER_PHILIPS_FM1216ME_MK3 :
case TUNER_PHILIPS_FM1236_MK3 :
2005-06-29 07:45:21 +04:00
case TUNER_PHILIPS_FMD1216ME_MK3 :
2005-04-17 02:20:36 +04:00
buffer [ 3 ] = 0x19 ;
break ;
case TUNER_PHILIPS_FM1256_IH3 :
2005-07-13 00:58:55 +04:00
div = ( 20 * freq ) / 16000 + ( int ) ( 33.3 * 20 ) ; /* IF 33.3 MHz */
2005-04-17 02:20:36 +04:00
buffer [ 3 ] = 0x19 ;
break ;
case TUNER_LG_PAL_FM :
buffer [ 3 ] = 0xa5 ;
break ;
2005-09-10 00:03:56 +04:00
case TUNER_MICROTUNE_4049FM5 :
div = ( 20 * freq ) / 16000 + ( int ) ( 33.3 * 20 ) ; /* IF 33.3 MHz */
buffer [ 3 ] = 0xa4 ;
break ;
2005-04-17 02:20:36 +04:00
default :
buffer [ 3 ] = 0xa4 ;
break ;
}
2005-11-09 08:37:43 +03:00
buffer [ 0 ] = ( div > > 8 ) & 0x7f ;
buffer [ 1 ] = div & 0xff ;
2005-04-17 02:20:36 +04:00
tuner_dbg ( " radio 0x%02x 0x%02x 0x%02x 0x%02x \n " ,
buffer [ 0 ] , buffer [ 1 ] , buffer [ 2 ] , buffer [ 3 ] ) ;
2005-11-09 08:37:43 +03:00
if ( 4 ! = ( rc = i2c_master_send ( c , buffer , 4 ) ) )
2005-04-17 02:20:36 +04:00
tuner_warn ( " i2c i/o error: rc == %d (should be 4) \n " , rc ) ;
}
int default_tuner_init ( struct i2c_client * c )
{
struct tuner * t = i2c_get_clientdata ( c ) ;
tuner_info ( " type set to %d (%s) \n " ,
t - > type , tuners [ t - > type ] . name ) ;
strlcpy ( c - > name , tuners [ t - > type ] . name , sizeof ( c - > name ) ) ;
t - > tv_freq = default_set_tv_freq ;
t - > radio_freq = default_set_radio_freq ;
t - > has_signal = tuner_signal ;
t - > is_stereo = tuner_stereo ;
2005-09-10 00:03:37 +04:00
t - > standby = NULL ;
2005-06-29 07:45:21 +04:00
2005-04-17 02:20:36 +04:00
return 0 ;
}
/*
* Overrides for Emacs so that we follow Linus ' s tabbing style .
* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
* Local variables :
* c - basic - offset : 8
* End :
*/