2005-04-16 15:20:36 -07:00
/*
* descriptions + helper functions for simple dvb plls .
*
* ( c ) 2004 Gerd Knorr < kraxel @ bytesex . org > [ SuSE Labs ]
*
* 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 .
*/
# include <linux/module.h>
# include <linux/dvb/frontend.h>
# include <asm/types.h>
# include "dvb-pll.h"
/* ----------------------------------------------------------- */
/* descriptions */
2007-04-27 12:31:29 -03:00
/* Set AGC TOP value to 103 dBuV:
0x80 = Control Byte
0x40 = 250 uA charge pump ( irrelevant )
0x18 = Aux Byte to follow
0x06 = 64.5 kHz divider ( irrelevant )
0x01 = Disable Vt ( aka sleep )
0x00 = AGC Time constant 2 s Iagc = 300 nA ( vs 0x80 = 9 nA )
0x50 = AGC Take over point = 103 dBuV */
static u8 tua603x_agc103 [ ] = { 2 , 0x80 | 0x40 | 0x18 | 0x06 | 0x01 , 0x00 | 0x50 } ;
2005-04-16 15:20:36 -07:00
struct dvb_pll_desc dvb_pll_thomson_dtt7579 = {
. name = " Thomson dtt7579 " ,
. min = 177000000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2007-03-19 02:24:09 -03:00
. sleepdata = ( u8 [ ] ) { 2 , 0xb4 , 0x03 } ,
. count = 4 ,
2005-04-16 15:20:36 -07:00
. entries = {
2007-03-19 02:24:04 -03:00
{ 443250000 , 166667 , 0xb4 , 0x02 } ,
{ 542000000 , 166667 , 0xb4 , 0x08 } ,
{ 771000000 , 166667 , 0xbc , 0x08 } ,
{ 999999999 , 166667 , 0xf4 , 0x08 } ,
2005-04-16 15:20:36 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_thomson_dtt7579 ) ;
struct dvb_pll_desc dvb_pll_thomson_dtt7610 = {
. name = " Thomson dtt7610 " ,
. min = 44000000 ,
. max = 958000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2005-04-16 15:20:36 -07:00
. count = 3 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 157250000 , 62500 , 0x8e , 0x39 } ,
{ 454000000 , 62500 , 0x8e , 0x3a } ,
{ 999999999 , 62500 , 0x8e , 0x3c } ,
2005-04-16 15:20:36 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_thomson_dtt7610 ) ;
2007-05-05 12:05:39 -03:00
static void thomson_dtt759x_bw ( u8 * buf ,
const struct dvb_frontend_parameters * params )
2005-04-16 15:20:36 -07:00
{
2007-05-05 12:05:39 -03:00
if ( BANDWIDTH_7_MHZ = = params - > u . ofdm . bandwidth )
2005-04-16 15:20:36 -07:00
buf [ 3 ] | = 0x10 ;
}
struct dvb_pll_desc dvb_pll_thomson_dtt759x = {
. name = " Thomson dtt759x " ,
. min = 177000000 ,
. max = 896000000 ,
2007-05-05 12:05:39 -03:00
. set = thomson_dtt759x_bw ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2007-03-19 02:24:09 -03:00
. sleepdata = ( u8 [ ] ) { 2 , 0x84 , 0x03 } ,
. count = 5 ,
2005-04-16 15:20:36 -07:00
. entries = {
2007-03-19 02:24:04 -03:00
{ 264000000 , 166667 , 0xb4 , 0x02 } ,
{ 470000000 , 166667 , 0xbc , 0x02 } ,
{ 735000000 , 166667 , 0xbc , 0x08 } ,
{ 835000000 , 166667 , 0xf4 , 0x08 } ,
{ 999999999 , 166667 , 0xfc , 0x08 } ,
2005-04-16 15:20:36 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_thomson_dtt759x ) ;
struct dvb_pll_desc dvb_pll_lg_z201 = {
. name = " LG z201 " ,
. min = 174000000 ,
. max = 862000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2007-03-19 02:24:09 -03:00
. sleepdata = ( u8 [ ] ) { 2 , 0xbc , 0x03 } ,
. count = 5 ,
2005-04-16 15:20:36 -07:00
. entries = {
2007-03-19 02:24:04 -03:00
{ 157500000 , 166667 , 0xbc , 0x01 } ,
{ 443250000 , 166667 , 0xbc , 0x02 } ,
{ 542000000 , 166667 , 0xbc , 0x04 } ,
{ 830000000 , 166667 , 0xf4 , 0x04 } ,
{ 999999999 , 166667 , 0xfc , 0x04 } ,
2005-04-16 15:20:36 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_lg_z201 ) ;
2005-07-07 17:58:29 -07:00
struct dvb_pll_desc dvb_pll_microtune_4042 = {
. name = " Microtune 4042 FI5 " ,
. min = 57000000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2005-07-07 17:58:29 -07:00
. count = 3 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 162000000 , 62500 , 0x8e , 0xa1 } ,
{ 457000000 , 62500 , 0x8e , 0x91 } ,
{ 999999999 , 62500 , 0x8e , 0x31 } ,
2005-07-07 17:58:29 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_microtune_4042 ) ;
2006-01-09 15:25:29 -02:00
struct dvb_pll_desc dvb_pll_thomson_dtt761x = {
/* DTT 7611 7611A 7612 7613 7613A 7614 7615 7615A */
. name = " Thomson dtt761x " ,
. min = 57000000 ,
. max = 863000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2005-07-07 17:58:42 -07:00
. count = 3 ,
2007-04-27 12:31:29 -03:00
. initdata = tua603x_agc103 ,
2005-07-07 17:58:42 -07:00
. entries = {
2007-03-19 02:24:04 -03:00
{ 147000000 , 62500 , 0x8e , 0x39 } ,
{ 417000000 , 62500 , 0x8e , 0x3a } ,
{ 999999999 , 62500 , 0x8e , 0x3c } ,
2005-07-07 17:58:42 -07:00
} ,
} ;
2006-01-09 15:25:29 -02:00
EXPORT_SYMBOL ( dvb_pll_thomson_dtt761x ) ;
2005-07-07 17:58:42 -07:00
2005-04-16 15:20:36 -07:00
struct dvb_pll_desc dvb_pll_unknown_1 = {
. name = " unknown 1 " , /* used by dntv live dvb-t */
. min = 174000000 ,
. max = 862000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2005-04-16 15:20:36 -07:00
. count = 9 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 150000000 , 166667 , 0xb4 , 0x01 } ,
{ 173000000 , 166667 , 0xbc , 0x01 } ,
{ 250000000 , 166667 , 0xb4 , 0x02 } ,
{ 400000000 , 166667 , 0xbc , 0x02 } ,
{ 420000000 , 166667 , 0xf4 , 0x02 } ,
{ 470000000 , 166667 , 0xfc , 0x02 } ,
{ 600000000 , 166667 , 0xbc , 0x08 } ,
{ 730000000 , 166667 , 0xf4 , 0x08 } ,
{ 999999999 , 166667 , 0xfc , 0x08 } ,
2005-04-16 15:20:36 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_unknown_1 ) ;
2005-06-23 22:02:35 -07:00
/* Infineon TUA6010XS
* used in Thomson Cable Tuner
*/
struct dvb_pll_desc dvb_pll_tua6010xs = {
. name = " Infineon TUA6010XS " ,
. min = 44250000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36125000 ,
2005-06-23 22:02:35 -07:00
. count = 3 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 115750000 , 62500 , 0x8e , 0x03 } ,
{ 403250000 , 62500 , 0x8e , 0x06 } ,
{ 999999999 , 62500 , 0x8e , 0x85 } ,
2005-06-23 22:02:35 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_tua6010xs ) ;
/* Panasonic env57h1xd5 (some Philips PLL ?) */
struct dvb_pll_desc dvb_pll_env57h1xd5 = {
. name = " Panasonic ENV57H1XD5 " ,
. min = 44250000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36125000 ,
2005-06-23 22:02:35 -07:00
. count = 4 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 153000000 , 166667 , 0xc2 , 0x41 } ,
{ 470000000 , 166667 , 0xc2 , 0x42 } ,
{ 526000000 , 166667 , 0xc2 , 0x84 } ,
{ 999999999 , 166667 , 0xc2 , 0xa4 } ,
2005-06-23 22:02:35 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_env57h1xd5 ) ;
/* Philips TDA6650/TDA6651
* used in Panasonic ENV77H11D5
*/
2007-05-05 12:05:39 -03:00
static void tda665x_bw ( u8 * buf , const struct dvb_frontend_parameters * params )
2005-06-23 22:02:35 -07:00
{
2007-05-05 12:05:39 -03:00
if ( params - > u . ofdm . bandwidth = = BANDWIDTH_8_MHZ )
2005-06-23 22:02:35 -07:00
buf [ 3 ] | = 0x08 ;
}
struct dvb_pll_desc dvb_pll_tda665x = {
. name = " Philips TDA6650/TDA6651 " ,
. min = 44250000 ,
. max = 858000000 ,
2007-05-05 12:05:39 -03:00
. set = tda665x_bw ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2005-06-23 22:02:35 -07:00
. count = 12 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 93834000 , 166667 , 0xca , 0x61 /* 011 0 0 0 01 */ } ,
{ 123834000 , 166667 , 0xca , 0xa1 /* 101 0 0 0 01 */ } ,
{ 161000000 , 166667 , 0xca , 0xa1 /* 101 0 0 0 01 */ } ,
{ 163834000 , 166667 , 0xca , 0xc2 /* 110 0 0 0 10 */ } ,
{ 253834000 , 166667 , 0xca , 0x62 /* 011 0 0 0 10 */ } ,
{ 383834000 , 166667 , 0xca , 0xa2 /* 101 0 0 0 10 */ } ,
{ 443834000 , 166667 , 0xca , 0xc2 /* 110 0 0 0 10 */ } ,
{ 444000000 , 166667 , 0xca , 0xc4 /* 110 0 0 1 00 */ } ,
{ 583834000 , 166667 , 0xca , 0x64 /* 011 0 0 1 00 */ } ,
{ 793834000 , 166667 , 0xca , 0xa4 /* 101 0 0 1 00 */ } ,
{ 444834000 , 166667 , 0xca , 0xc4 /* 110 0 0 1 00 */ } ,
{ 861000000 , 166667 , 0xca , 0xe4 /* 111 0 0 1 00 */ } ,
2005-06-23 22:02:35 -07:00
}
} ;
EXPORT_SYMBOL ( dvb_pll_tda665x ) ;
/* Infineon TUA6034
* used in LG TDTP E102P
*/
2007-05-05 12:05:39 -03:00
static void tua6034_bw ( u8 * buf , const struct dvb_frontend_parameters * params )
2005-06-23 22:02:35 -07:00
{
2007-05-05 12:05:39 -03:00
if ( BANDWIDTH_7_MHZ ! = params - > u . ofdm . bandwidth )
2005-06-23 22:02:35 -07:00
buf [ 3 ] | = 0x08 ;
}
struct dvb_pll_desc dvb_pll_tua6034 = {
. name = " Infineon TUA6034 " ,
. min = 44250000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2005-06-23 22:02:35 -07:00
. count = 3 ,
2007-05-05 12:05:39 -03:00
. set = tua6034_bw ,
2005-06-23 22:02:35 -07:00
. entries = {
2007-03-19 02:24:04 -03:00
{ 174500000 , 62500 , 0xce , 0x01 } ,
{ 230000000 , 62500 , 0xce , 0x02 } ,
{ 999999999 , 62500 , 0xce , 0x04 } ,
2005-06-23 22:02:35 -07:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_tua6034 ) ;
2005-08-08 09:22:43 -07:00
/* Infineon TUA6034
2006-04-22 16:15:11 -03:00
* used in LG TDVS - H061F , LG TDVS - H062F and LG TDVS - H064F
2005-08-08 09:22:43 -07:00
*/
2006-04-27 01:31:26 -03:00
struct dvb_pll_desc dvb_pll_lg_tdvs_h06xf = {
2006-04-22 16:15:11 -03:00
. name = " LG TDVS-H06xF " ,
2005-08-08 09:22:43 -07:00
. min = 54000000 ,
. max = 863000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2007-04-27 12:31:30 -03:00
. initdata = tua603x_agc103 ,
2005-08-08 09:22:43 -07:00
. count = 3 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 165000000 , 62500 , 0xce , 0x01 } ,
{ 450000000 , 62500 , 0xce , 0x02 } ,
{ 999999999 , 62500 , 0xce , 0x04 } ,
2005-08-08 09:22:43 -07:00
} ,
} ;
2006-04-27 01:31:26 -03:00
EXPORT_SYMBOL ( dvb_pll_lg_tdvs_h06xf ) ;
2005-08-08 09:22:43 -07:00
2005-07-07 17:58:09 -07:00
/* Philips FMD1216ME
* used in Medion Hybrid PCMCIA card and USB Box
*/
2007-05-05 12:05:39 -03:00
static void fmd1216me_bw ( u8 * buf , const struct dvb_frontend_parameters * params )
2005-07-07 17:58:09 -07:00
{
2007-05-05 12:05:39 -03:00
if ( params - > u . ofdm . bandwidth = = BANDWIDTH_8_MHZ & &
params - > frequency > = 158870000 )
2005-07-07 17:58:09 -07:00
buf [ 3 ] | = 0x08 ;
}
struct dvb_pll_desc dvb_pll_fmd1216me = {
2005-07-07 17:58:12 -07:00
. name = " Philips FMD1216ME " ,
2005-07-07 17:58:09 -07:00
. min = 50870000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36125000 ,
2007-05-05 12:05:39 -03:00
. set = fmd1216me_bw ,
2005-07-07 17:58:09 -07:00
. count = 7 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 143870000 , 166667 , 0xbc , 0x41 } ,
{ 158870000 , 166667 , 0xf4 , 0x41 } ,
{ 329870000 , 166667 , 0xbc , 0x42 } ,
{ 441870000 , 166667 , 0xf4 , 0x42 } ,
{ 625870000 , 166667 , 0xbc , 0x44 } ,
{ 803870000 , 166667 , 0xf4 , 0x44 } ,
{ 999999999 , 166667 , 0xfc , 0x44 } ,
2005-07-07 17:58:09 -07:00
}
} ;
EXPORT_SYMBOL ( dvb_pll_fmd1216me ) ;
2005-07-07 17:58:12 -07:00
/* ALPS TDED4
* used in Nebula - Cards and USB boxes
*/
2007-05-05 12:05:39 -03:00
static void tded4_bw ( u8 * buf , const struct dvb_frontend_parameters * params )
2005-07-07 17:58:12 -07:00
{
2007-05-05 12:05:39 -03:00
if ( params - > u . ofdm . bandwidth = = BANDWIDTH_8_MHZ )
2005-07-07 17:58:12 -07:00
buf [ 3 ] | = 0x04 ;
}
struct dvb_pll_desc dvb_pll_tded4 = {
. name = " ALPS TDED4 " ,
. min = 47000000 ,
. max = 863000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2007-05-05 12:05:39 -03:00
. set = tded4_bw ,
2005-07-07 17:58:12 -07:00
. count = 4 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 153000000 , 166667 , 0x85 , 0x01 } ,
{ 470000000 , 166667 , 0x85 , 0x02 } ,
{ 823000000 , 166667 , 0x85 , 0x08 } ,
{ 999999999 , 166667 , 0x85 , 0x88 } ,
2005-07-07 17:58:12 -07:00
}
} ;
EXPORT_SYMBOL ( dvb_pll_tded4 ) ;
2005-11-08 21:35:39 -08:00
/* ALPS TDHU2
* used in AverTVHD MCE A180
*/
struct dvb_pll_desc dvb_pll_tdhu2 = {
. name = " ALPS TDHU2 " ,
. min = 54000000 ,
. max = 864000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2005-11-08 21:35:39 -08:00
. count = 4 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 162000000 , 62500 , 0x85 , 0x01 } ,
{ 426000000 , 62500 , 0x85 , 0x02 } ,
{ 782000000 , 62500 , 0x85 , 0x08 } ,
{ 999999999 , 62500 , 0x85 , 0x88 } ,
2005-11-08 21:35:39 -08:00
}
} ;
EXPORT_SYMBOL ( dvb_pll_tdhu2 ) ;
/* Philips TUV1236D
* used in ATI HDTV Wonder
*/
2007-05-05 12:15:57 -03:00
static void tuv1236d_rf ( u8 * buf , const struct dvb_frontend_parameters * params )
{
switch ( params - > u . vsb . modulation ) {
case QAM_64 :
case QAM_256 :
buf [ 3 ] | = 0x08 ;
break ;
case VSB_8 :
default :
buf [ 3 ] & = ~ 0x08 ;
}
}
2005-11-08 21:35:39 -08:00
struct dvb_pll_desc dvb_pll_tuv1236d = {
. name = " Philips TUV1236D " ,
2005-11-08 21:35:46 -08:00
. min = 54000000 ,
2005-11-08 21:35:39 -08:00
. max = 864000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2007-05-05 12:15:57 -03:00
. set = tuv1236d_rf ,
2005-11-08 21:35:39 -08:00
. count = 3 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 157250000 , 62500 , 0xc6 , 0x41 } ,
{ 454000000 , 62500 , 0xc6 , 0x42 } ,
{ 999999999 , 62500 , 0xc6 , 0x44 } ,
2005-11-08 21:35:39 -08:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_tuv1236d ) ;
2006-01-23 17:11:06 -02:00
/* Samsung TBMV30111IN / TBMV30712IN1
2005-11-08 21:35:39 -08:00
* used in Air2PC ATSC - 2 nd generation ( nxt2002 )
*/
2006-01-23 17:11:07 -02:00
struct dvb_pll_desc dvb_pll_samsung_tbmv = {
. name = " Samsung TBMV30111IN / TBMV30712IN1 " ,
2005-11-08 21:35:39 -08:00
. min = 54000000 ,
. max = 860000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 44000000 ,
2006-01-15 19:04:04 -02:00
. count = 6 ,
2005-11-08 21:35:39 -08:00
. entries = {
2007-03-19 02:24:04 -03:00
{ 172000000 , 166667 , 0xb4 , 0x01 } ,
{ 214000000 , 166667 , 0xb4 , 0x02 } ,
{ 467000000 , 166667 , 0xbc , 0x02 } ,
{ 721000000 , 166667 , 0xbc , 0x08 } ,
{ 841000000 , 166667 , 0xf4 , 0x08 } ,
{ 999999999 , 166667 , 0xfc , 0x02 } ,
2005-11-08 21:35:39 -08:00
}
} ;
2006-01-23 17:11:07 -02:00
EXPORT_SYMBOL ( dvb_pll_samsung_tbmv ) ;
2005-11-08 21:35:39 -08:00
2006-01-11 23:31:53 -02:00
/*
* Philips SD1878 Tuner .
*/
struct dvb_pll_desc dvb_pll_philips_sd1878_tda8261 = {
. name = " Philips SD1878 " ,
. min = 950000 ,
. max = 2150000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 249 , /* zero-IF, offset 249 is to round up */
2006-01-11 23:31:53 -02:00
. count = 4 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 1250000 , 500 , 0xc4 , 0x00 } ,
{ 1550000 , 500 , 0xc4 , 0x40 } ,
{ 2050000 , 500 , 0xc4 , 0x80 } ,
{ 2150000 , 500 , 0xc4 , 0xc0 } ,
2006-01-11 23:31:53 -02:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_philips_sd1878_tda8261 ) ;
2006-02-07 06:25:14 -02:00
/*
* Philips TD1316 Tuner .
*/
2007-05-05 12:05:39 -03:00
static void td1316_bw ( u8 * buf , const struct dvb_frontend_parameters * params )
2006-02-07 06:25:14 -02:00
{
u8 band ;
/* determine band */
2007-05-05 12:05:39 -03:00
if ( params - > frequency < 161000000 )
2006-02-07 06:25:14 -02:00
band = 1 ;
2007-05-05 12:05:39 -03:00
else if ( params - > frequency < 444000000 )
2006-02-07 06:25:14 -02:00
band = 2 ;
else
band = 4 ;
buf [ 3 ] | = band ;
/* setup PLL filter */
2007-05-05 12:05:39 -03:00
if ( params - > u . ofdm . bandwidth = = BANDWIDTH_8_MHZ )
2006-02-07 06:25:14 -02:00
buf [ 3 ] | = 1 < < 3 ;
}
struct dvb_pll_desc dvb_pll_philips_td1316 = {
. name = " Philips TD1316 " ,
. min = 87000000 ,
. max = 895000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36166667 ,
2007-05-05 12:05:39 -03:00
. set = td1316_bw ,
2006-02-07 06:25:14 -02:00
. count = 9 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 93834000 , 166667 , 0xca , 0x60 } ,
{ 123834000 , 166667 , 0xca , 0xa0 } ,
{ 163834000 , 166667 , 0xca , 0xc0 } ,
{ 253834000 , 166667 , 0xca , 0x60 } ,
{ 383834000 , 166667 , 0xca , 0xa0 } ,
{ 443834000 , 166667 , 0xca , 0xc0 } ,
{ 583834000 , 166667 , 0xca , 0x60 } ,
{ 793834000 , 166667 , 0xca , 0xa0 } ,
{ 858834000 , 166667 , 0xca , 0xe0 } ,
2006-02-07 06:25:14 -02:00
} ,
} ;
EXPORT_SYMBOL ( dvb_pll_philips_td1316 ) ;
2006-02-28 08:34:59 -03:00
/* FE6600 used on DViCO Hybrid */
2006-03-01 00:04:42 -03:00
struct dvb_pll_desc dvb_pll_thomson_fe6600 = {
. name = " Thomson FE6600 " ,
2006-02-28 08:34:59 -03:00
. min = 44250000 ,
. max = 858000000 ,
2007-03-19 02:24:04 -03:00
. iffreq = 36125000 ,
2006-02-28 08:34:59 -03:00
. count = 4 ,
. entries = {
2007-03-19 02:24:04 -03:00
{ 250000000 , 166667 , 0xb4 , 0x12 } ,
{ 455000000 , 166667 , 0xfe , 0x11 } ,
{ 775500000 , 166667 , 0xbc , 0x18 } ,
{ 999999999 , 166667 , 0xf4 , 0x18 } ,
2006-02-28 08:34:59 -03:00
}
} ;
2006-03-01 00:04:42 -03:00
EXPORT_SYMBOL ( dvb_pll_thomson_fe6600 ) ;
2007-05-05 12:05:39 -03:00
static void opera1_bw ( u8 * buf , const struct dvb_frontend_parameters * params )
2007-04-19 11:26:47 -03:00
{
2007-05-05 12:05:39 -03:00
if ( params - > u . ofdm . bandwidth = = BANDWIDTH_8_MHZ )
2007-04-19 11:26:47 -03:00
buf [ 2 ] | = 0x08 ;
}
struct dvb_pll_desc dvb_pll_opera1 = {
. name = " Opera Tuner " ,
. min = 900000 ,
. max = 2250000 ,
. iffreq = 0 ,
2007-05-05 12:05:39 -03:00
. set = opera1_bw ,
2007-04-19 11:26:47 -03:00
. count = 8 ,
. entries = {
{ 1064000 , 500 , 0xe5 , 0xc6 } ,
{ 1169000 , 500 , 0xe5 , 0xe6 } ,
{ 1299000 , 500 , 0xe5 , 0x24 } ,
{ 1444000 , 500 , 0xe5 , 0x44 } ,
{ 1606000 , 500 , 0xe5 , 0x64 } ,
{ 1777000 , 500 , 0xe5 , 0x84 } ,
{ 1941000 , 500 , 0xe5 , 0xa4 } ,
{ 2250000 , 500 , 0xe5 , 0xc4 } ,
}
} ;
EXPORT_SYMBOL ( dvb_pll_opera1 ) ;
2006-02-28 08:34:59 -03:00
2006-04-18 17:47:12 -03:00
struct dvb_pll_priv {
/* i2c details */
int pll_i2c_address ;
struct i2c_adapter * i2c ;
/* the PLL descriptor */
struct dvb_pll_desc * pll_desc ;
/* cached frequency/bandwidth */
u32 frequency ;
u32 bandwidth ;
} ;
2005-04-16 15:20:36 -07:00
/* ----------------------------------------------------------- */
/* code */
static int debug = 0 ;
module_param ( debug , int , 0644 ) ;
MODULE_PARM_DESC ( debug , " enable verbose debug messages " ) ;
int dvb_pll_configure ( struct dvb_pll_desc * desc , u8 * buf ,
2007-05-05 12:05:39 -03:00
const struct dvb_frontend_parameters * params )
2005-04-16 15:20:36 -07:00
{
u32 div ;
int i ;
2007-05-05 12:05:39 -03:00
if ( params - > frequency ! = 0 & & ( params - > frequency < desc - > min | |
params - > frequency > desc - > max ) )
return - EINVAL ;
2005-04-16 15:20:36 -07:00
for ( i = 0 ; i < desc - > count ; i + + ) {
2007-05-05 12:05:39 -03:00
if ( params - > frequency > desc - > entries [ i ] . limit )
2005-04-16 15:20:36 -07:00
continue ;
break ;
}
2007-05-05 12:05:39 -03:00
2005-04-16 15:20:36 -07:00
if ( debug )
2007-05-05 12:05:39 -03:00
printk ( " pll: %s: freq=%d | i=%d/%d \n " , desc - > name ,
params - > frequency , i , desc - > count ) ;
2006-04-18 17:47:12 -03:00
if ( i = = desc - > count )
return - EINVAL ;
2005-04-16 15:20:36 -07:00
2007-05-05 12:05:39 -03:00
div = ( params - > frequency + desc - > iffreq +
desc - > entries [ i ] . stepsize / 2 ) / desc - > entries [ i ] . stepsize ;
2005-04-16 15:20:36 -07:00
buf [ 0 ] = div > > 8 ;
buf [ 1 ] = div & 0xff ;
2006-01-23 17:11:11 -02:00
buf [ 2 ] = desc - > entries [ i ] . config ;
buf [ 3 ] = desc - > entries [ i ] . cb ;
2005-04-16 15:20:36 -07:00
2007-05-05 12:05:39 -03:00
if ( desc - > set )
desc - > set ( buf , params ) ;
2005-04-16 15:20:36 -07:00
if ( debug )
printk ( " pll: %s: div=%d | buf=0x%02x,0x%02x,0x%02x,0x%02x \n " ,
desc - > name , div , buf [ 0 ] , buf [ 1 ] , buf [ 2 ] , buf [ 3 ] ) ;
2006-11-20 16:45:29 -03:00
// calculate the frequency we set it to
2007-03-19 02:24:04 -03:00
return ( div * desc - > entries [ i ] . stepsize ) - desc - > iffreq ;
2005-04-16 15:20:36 -07:00
}
EXPORT_SYMBOL ( dvb_pll_configure ) ;
2006-04-18 17:47:12 -03:00
static int dvb_pll_release ( struct dvb_frontend * fe )
{
2006-11-19 19:49:11 -03:00
kfree ( fe - > tuner_priv ) ;
2006-04-18 17:47:12 -03:00
fe - > tuner_priv = NULL ;
return 0 ;
}
static int dvb_pll_sleep ( struct dvb_frontend * fe )
{
struct dvb_pll_priv * priv = fe - > tuner_priv ;
2006-08-08 15:48:08 -03:00
if ( priv - > i2c = = NULL )
return - EINVAL ;
2007-03-19 02:24:09 -03:00
if ( priv - > pll_desc - > sleepdata ) {
struct i2c_msg msg = { . flags = 0 ,
. addr = priv - > pll_i2c_address ,
. buf = priv - > pll_desc - > sleepdata + 1 ,
. len = priv - > pll_desc - > sleepdata [ 0 ] } ;
2006-04-18 17:47:12 -03:00
2007-03-19 02:24:09 -03:00
int result ;
2006-04-18 17:47:12 -03:00
2007-03-19 02:24:09 -03:00
if ( fe - > ops . i2c_gate_ctrl )
fe - > ops . i2c_gate_ctrl ( fe , 1 ) ;
if ( ( result = i2c_transfer ( priv - > i2c , & msg , 1 ) ) ! = 1 ) {
return result ;
}
return 0 ;
2006-04-18 17:47:12 -03:00
}
2007-03-19 02:24:09 -03:00
/* Shouldn't be called when initdata is NULL, maybe BUG()? */
return - EINVAL ;
2006-04-18 17:47:12 -03:00
}
2006-11-20 16:38:42 -03:00
static int dvb_pll_set_params ( struct dvb_frontend * fe ,
struct dvb_frontend_parameters * params )
2006-04-18 17:47:12 -03:00
{
struct dvb_pll_priv * priv = fe - > tuner_priv ;
u8 buf [ 4 ] ;
struct i2c_msg msg =
2006-11-20 16:38:42 -03:00
{ . addr = priv - > pll_i2c_address , . flags = 0 ,
. buf = buf , . len = sizeof ( buf ) } ;
2006-04-18 17:47:12 -03:00
int result ;
2007-05-05 12:05:39 -03:00
u32 frequency = 0 ;
2006-04-18 17:47:12 -03:00
if ( priv - > i2c = = NULL )
return - EINVAL ;
2007-05-05 12:05:39 -03:00
if ( ( result = dvb_pll_configure ( priv - > pll_desc , buf , params ) ) < 0 )
2006-04-18 17:47:12 -03:00
return result ;
2006-11-20 16:45:29 -03:00
else
frequency = result ;
2006-04-18 17:47:12 -03:00
2006-05-14 05:01:31 -03:00
if ( fe - > ops . i2c_gate_ctrl )
fe - > ops . i2c_gate_ctrl ( fe , 1 ) ;
2006-04-18 17:47:12 -03:00
if ( ( result = i2c_transfer ( priv - > i2c , & msg , 1 ) ) ! = 1 ) {
return result ;
}
2006-11-20 16:45:29 -03:00
priv - > frequency = frequency ;
2007-05-05 12:05:39 -03:00
priv - > bandwidth = ( fe - > ops . info . type = = FE_OFDM ) ? params - > u . ofdm . bandwidth : 0 ;
2006-04-18 17:47:12 -03:00
return 0 ;
}
2006-11-20 16:38:42 -03:00
static int dvb_pll_calc_regs ( struct dvb_frontend * fe ,
struct dvb_frontend_parameters * params ,
u8 * buf , int buf_len )
2006-04-18 17:47:12 -03:00
{
struct dvb_pll_priv * priv = fe - > tuner_priv ;
int result ;
2007-05-05 12:05:39 -03:00
u32 frequency = 0 ;
2006-04-18 17:47:12 -03:00
if ( buf_len < 5 )
return - EINVAL ;
2007-05-05 12:05:39 -03:00
if ( ( result = dvb_pll_configure ( priv - > pll_desc , buf + 1 , params ) ) < 0 )
2006-04-18 17:47:12 -03:00
return result ;
2006-11-20 16:45:29 -03:00
else
frequency = result ;
2006-04-18 17:47:12 -03:00
buf [ 0 ] = priv - > pll_i2c_address ;
2006-11-20 16:45:29 -03:00
priv - > frequency = frequency ;
2007-05-05 12:05:39 -03:00
priv - > bandwidth = ( fe - > ops . info . type = = FE_OFDM ) ? params - > u . ofdm . bandwidth : 0 ;
2006-04-18 17:47:12 -03:00
return 5 ;
}
static int dvb_pll_get_frequency ( struct dvb_frontend * fe , u32 * frequency )
{
struct dvb_pll_priv * priv = fe - > tuner_priv ;
* frequency = priv - > frequency ;
return 0 ;
}
static int dvb_pll_get_bandwidth ( struct dvb_frontend * fe , u32 * bandwidth )
{
struct dvb_pll_priv * priv = fe - > tuner_priv ;
* bandwidth = priv - > bandwidth ;
return 0 ;
}
2007-04-27 12:31:29 -03:00
static int dvb_pll_init ( struct dvb_frontend * fe )
{
struct dvb_pll_priv * priv = fe - > tuner_priv ;
if ( priv - > i2c = = NULL )
return - EINVAL ;
if ( priv - > pll_desc - > initdata ) {
struct i2c_msg msg = { . flags = 0 ,
. addr = priv - > pll_i2c_address ,
. buf = priv - > pll_desc - > initdata + 1 ,
. len = priv - > pll_desc - > initdata [ 0 ] } ;
int result ;
if ( fe - > ops . i2c_gate_ctrl )
fe - > ops . i2c_gate_ctrl ( fe , 1 ) ;
if ( ( result = i2c_transfer ( priv - > i2c , & msg , 1 ) ) ! = 1 ) {
return result ;
}
return 0 ;
}
/* Shouldn't be called when initdata is NULL, maybe BUG()? */
return - EINVAL ;
}
2006-04-18 17:47:12 -03:00
static struct dvb_tuner_ops dvb_pll_tuner_ops = {
. release = dvb_pll_release ,
. sleep = dvb_pll_sleep ,
2007-03-19 02:24:09 -03:00
. init = dvb_pll_init ,
2006-04-18 17:47:12 -03:00
. set_params = dvb_pll_set_params ,
2006-04-18 21:38:49 -03:00
. calc_regs = dvb_pll_calc_regs ,
2006-04-18 17:47:12 -03:00
. get_frequency = dvb_pll_get_frequency ,
. get_bandwidth = dvb_pll_get_bandwidth ,
} ;
2006-11-20 16:38:42 -03:00
struct dvb_frontend * dvb_pll_attach ( struct dvb_frontend * fe , int pll_addr ,
struct i2c_adapter * i2c ,
struct dvb_pll_desc * desc )
2006-04-18 17:47:12 -03:00
{
2006-07-10 03:34:14 -03:00
u8 b1 [ ] = { 0 } ;
2006-11-20 16:38:42 -03:00
struct i2c_msg msg = { . addr = pll_addr , . flags = I2C_M_RD ,
. buf = b1 , . len = 1 } ;
2006-04-18 17:47:12 -03:00
struct dvb_pll_priv * priv = NULL ;
2006-07-10 03:34:14 -03:00
int ret ;
2006-07-16 19:41:41 -03:00
if ( i2c ! = NULL ) {
if ( fe - > ops . i2c_gate_ctrl )
fe - > ops . i2c_gate_ctrl ( fe , 1 ) ;
2006-07-18 16:37:13 -03:00
ret = i2c_transfer ( i2c , & msg , 1 ) ;
if ( ret ! = 1 )
2006-08-08 09:10:08 -03:00
return NULL ;
2006-07-16 19:41:41 -03:00
if ( fe - > ops . i2c_gate_ctrl )
fe - > ops . i2c_gate_ctrl ( fe , 0 ) ;
}
2006-04-18 17:47:12 -03:00
priv = kzalloc ( sizeof ( struct dvb_pll_priv ) , GFP_KERNEL ) ;
if ( priv = = NULL )
2006-08-08 09:10:08 -03:00
return NULL ;
2006-04-18 17:47:12 -03:00
priv - > pll_i2c_address = pll_addr ;
priv - > i2c = i2c ;
priv - > pll_desc = desc ;
2006-11-20 16:38:42 -03:00
memcpy ( & fe - > ops . tuner_ops , & dvb_pll_tuner_ops ,
sizeof ( struct dvb_tuner_ops ) ) ;
2007-04-27 12:31:27 -03:00
strncpy ( fe - > ops . tuner_ops . info . name , desc - > name ,
sizeof ( fe - > ops . tuner_ops . info . name ) ) ;
2006-05-14 05:01:31 -03:00
fe - > ops . tuner_ops . info . frequency_min = desc - > min ;
fe - > ops . tuner_ops . info . frequency_min = desc - > max ;
2007-03-19 02:24:09 -03:00
if ( ! desc - > initdata )
fe - > ops . tuner_ops . init = NULL ;
if ( ! desc - > sleepdata )
fe - > ops . tuner_ops . sleep = NULL ;
2006-04-18 17:47:12 -03:00
fe - > tuner_priv = priv ;
2006-08-08 09:10:08 -03:00
return fe ;
2006-04-18 17:47:12 -03:00
}
EXPORT_SYMBOL ( dvb_pll_attach ) ;
2005-04-16 15:20:36 -07:00
MODULE_DESCRIPTION ( " dvb pll library " ) ;
MODULE_AUTHOR ( " Gerd Knorr " ) ;
MODULE_LICENSE ( " GPL " ) ;