aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/dvb/frontends
diff options
context:
space:
mode:
authorMichael Krufky <mkrufky@linuxtv.org>2007-12-24 22:39:37 -0500
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-01-25 16:04:25 -0500
commit2f27dfc98cc0a183be9e3c2fc0da0450b85e5fde (patch)
treee47034d3d6b0c09c34de248e18a01a880d485abc /drivers/media/dvb/frontends
parentd37142102a2adaa3391a384ea6a780afb5804789 (diff)
V4L/DVB (6926): tda18271: consolidate table lookup functions
Signed-off-by: Michael Krufky <mkrufky@linuxtv.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/dvb/frontends')
-rw-r--r--drivers/media/dvb/frontends/tda18271-fe.c28
-rw-r--r--drivers/media/dvb/frontends/tda18271-priv.h26
-rw-r--r--drivers/media/dvb/frontends/tda18271-tables.c126
3 files changed, 106 insertions, 74 deletions
diff --git a/drivers/media/dvb/frontends/tda18271-fe.c b/drivers/media/dvb/frontends/tda18271-fe.c
index 4526def2d42f..72e256ebeb0f 100644
--- a/drivers/media/dvb/frontends/tda18271-fe.c
+++ b/drivers/media/dvb/frontends/tda18271-fe.c
@@ -360,7 +360,9 @@ static int tda18271_calc_main_pll(struct dvb_frontend *fe, u32 freq)
360 u8 d, pd; 360 u8 d, pd;
361 u32 div; 361 u32 div;
362 362
363 tda18271_lookup_main_pll(&freq, &pd, &d); 363 int ret = tda18271_lookup_pll_map(MAIN_PLL, &freq, &pd, &d);
364 if (ret < 0)
365 goto fail;
364 366
365 regs[R_MPD] = (0x77 & pd); 367 regs[R_MPD] = (0x77 & pd);
366 368
@@ -378,8 +380,8 @@ static int tda18271_calc_main_pll(struct dvb_frontend *fe, u32 freq)
378 regs[R_MD1] = 0x7f & (div >> 16); 380 regs[R_MD1] = 0x7f & (div >> 16);
379 regs[R_MD2] = 0xff & (div >> 8); 381 regs[R_MD2] = 0xff & (div >> 8);
380 regs[R_MD3] = 0xff & div; 382 regs[R_MD3] = 0xff & div;
381 383fail:
382 return 0; 384 return ret;
383} 385}
384 386
385static int tda18271_calc_cal_pll(struct dvb_frontend *fe, u32 freq) 387static int tda18271_calc_cal_pll(struct dvb_frontend *fe, u32 freq)
@@ -390,7 +392,9 @@ static int tda18271_calc_cal_pll(struct dvb_frontend *fe, u32 freq)
390 u8 d, pd; 392 u8 d, pd;
391 u32 div; 393 u32 div;
392 394
393 tda18271_lookup_cal_pll(&freq, &pd, &d); 395 int ret = tda18271_lookup_pll_map(CAL_PLL, &freq, &pd, &d);
396 if (ret < 0)
397 goto fail;
394 398
395 regs[R_CPD] = pd; 399 regs[R_CPD] = pd;
396 400
@@ -399,8 +403,8 @@ static int tda18271_calc_cal_pll(struct dvb_frontend *fe, u32 freq)
399 regs[R_CD1] = 0x7f & (div >> 16); 403 regs[R_CD1] = 0x7f & (div >> 16);
400 regs[R_CD2] = 0xff & (div >> 8); 404 regs[R_CD2] = 0xff & (div >> 8);
401 regs[R_CD3] = 0xff & div; 405 regs[R_CD3] = 0xff & div;
402 406fail:
403 return 0; 407 return ret;
404} 408}
405 409
406static int tda18271_tune(struct dvb_frontend *fe, 410static int tda18271_tune(struct dvb_frontend *fe,
@@ -418,7 +422,7 @@ static int tda18271_tune(struct dvb_frontend *fe,
418 /* RF tracking filter calibration */ 422 /* RF tracking filter calibration */
419 423
420 /* calculate BP_Filter */ 424 /* calculate BP_Filter */
421 tda18271_lookup_bp_filter(&freq, &val); 425 tda18271_lookup_map(BP_FILTER, &freq, &val);
422 426
423 regs[R_EP1] &= ~0x07; /* clear bp filter bits */ 427 regs[R_EP1] &= ~0x07; /* clear bp filter bits */
424 regs[R_EP1] |= val; 428 regs[R_EP1] |= val;
@@ -470,20 +474,20 @@ static int tda18271_tune(struct dvb_frontend *fe,
470 msleep(5); /* RF tracking filter calibration initialization */ 474 msleep(5); /* RF tracking filter calibration initialization */
471 475
472 /* search for K,M,CO for RF Calibration */ 476 /* search for K,M,CO for RF Calibration */
473 tda18271_lookup_km(&freq, &val); 477 tda18271_lookup_map(RF_CAL_KMCO, &freq, &val);
474 478
475 regs[R_EB13] &= 0x83; 479 regs[R_EB13] &= 0x83;
476 regs[R_EB13] |= val; 480 regs[R_EB13] |= val;
477 tda18271_write_regs(fe, R_EB13, 1); 481 tda18271_write_regs(fe, R_EB13, 1);
478 482
479 /* search for RF_BAND */ 483 /* search for RF_BAND */
480 tda18271_lookup_rf_band(&freq, &val); 484 tda18271_lookup_map(RF_BAND, &freq, &val);
481 485
482 regs[R_EP2] &= ~0xe0; /* clear rf band bits */ 486 regs[R_EP2] &= ~0xe0; /* clear rf band bits */
483 regs[R_EP2] |= (val << 5); 487 regs[R_EP2] |= (val << 5);
484 488
485 /* search for Gain_Taper */ 489 /* search for Gain_Taper */
486 tda18271_lookup_gain_taper(&freq, &val); 490 tda18271_lookup_map(GAIN_TAPER, &freq, &val);
487 491
488 regs[R_EP2] &= ~0x1f; /* clear gain taper bits */ 492 regs[R_EP2] &= ~0x1f; /* clear gain taper bits */
489 regs[R_EP2] |= val; 493 regs[R_EP2] |= val;
@@ -511,7 +515,7 @@ static int tda18271_tune(struct dvb_frontend *fe,
511 tda18271_write_regs(fe, R_EP1, 1); 515 tda18271_write_regs(fe, R_EP1, 1);
512 516
513 /* RF tracking filer correction for VHF_Low band */ 517 /* RF tracking filer correction for VHF_Low band */
514 tda18271_lookup_rf_cal(&freq, &val); 518 tda18271_lookup_map(RF_CAL, &freq, &val);
515 519
516 /* VHF_Low band only */ 520 /* VHF_Low band only */
517 if (val != 0) { 521 if (val != 0) {
@@ -555,7 +559,7 @@ static int tda18271_tune(struct dvb_frontend *fe,
555 regs[R_EP4] &= ~0x80; /* turn this bit on only for fm */ 559 regs[R_EP4] &= ~0x80; /* turn this bit on only for fm */
556 560
557 /* image rejection validity EP5[2:0] */ 561 /* image rejection validity EP5[2:0] */
558 tda18271_lookup_ir_measure(&freq, &val); 562 tda18271_lookup_map(IR_MEASURE, &freq, &val);
559 563
560 regs[R_EP5] &= ~0x07; 564 regs[R_EP5] &= ~0x07;
561 regs[R_EP5] |= val; 565 regs[R_EP5] |= val;
diff --git a/drivers/media/dvb/frontends/tda18271-priv.h b/drivers/media/dvb/frontends/tda18271-priv.h
index 7b9aa9ad53fe..b08bf08aa88f 100644
--- a/drivers/media/dvb/frontends/tda18271-priv.h
+++ b/drivers/media/dvb/frontends/tda18271-priv.h
@@ -104,15 +104,23 @@ extern int tda18271_debug;
104 104
105/*---------------------------------------------------------------------*/ 105/*---------------------------------------------------------------------*/
106 106
107extern void tda18271_lookup_cal_pll(u32 *freq, u8 *post_div, u8 *div); 107enum tda18271_map_type {
108extern void tda18271_lookup_main_pll(u32 *freq, u8 *post_div, u8 *div); 108 /* tda18271_pll_map */
109 109 MAIN_PLL,
110extern void tda18271_lookup_bp_filter(u32 *freq, u8 *val); 110 CAL_PLL,
111extern void tda18271_lookup_km(u32 *freq, u8 *val); 111 /* tda18271_map */
112extern void tda18271_lookup_rf_band(u32 *freq, u8 *val); 112 RF_CAL,
113extern void tda18271_lookup_gain_taper(u32 *freq, u8 *val); 113 RF_CAL_KMCO,
114extern void tda18271_lookup_rf_cal(u32 *freq, u8 *val); 114 BP_FILTER,
115extern void tda18271_lookup_ir_measure(u32 *freq, u8 *val); 115 RF_BAND,
116 GAIN_TAPER,
117 IR_MEASURE,
118};
119
120extern int tda18271_lookup_pll_map(enum tda18271_map_type map_type,
121 u32 *freq, u8 *post_div, u8 *div);
122extern int tda18271_lookup_map(enum tda18271_map_type map_type,
123 u32 *freq, u8 *val);
116 124
117#endif /* __TDA18271_PRIV_H__ */ 125#endif /* __TDA18271_PRIV_H__ */
118 126
diff --git a/drivers/media/dvb/frontends/tda18271-tables.c b/drivers/media/dvb/frontends/tda18271-tables.c
index 02b6d2cb9570..8990bef0cf7e 100644
--- a/drivers/media/dvb/frontends/tda18271-tables.c
+++ b/drivers/media/dvb/frontends/tda18271-tables.c
@@ -267,22 +267,33 @@ static struct tda18271_map tda18271_ir_measure[] = {
267 267
268/*---------------------------------------------------------------------*/ 268/*---------------------------------------------------------------------*/
269 269
270static void tda18271_lookup_map(struct tda18271_map *map, 270int tda18271_lookup_pll_map(enum tda18271_map_type map_type,
271 u32 *freq, u8 *val) 271 u32 *freq, u8 *post_div, u8 *div)
272{ 272{
273 int i = 0; 273 struct tda18271_pll_map *map = NULL;
274 while ((map[i].rfmax * 1000) < *freq) { 274 unsigned int i = 0;
275 if (map[i + 1].rfmax == 0) 275 char *map_name;
276 break; 276
277 i++; 277 switch (map_type) {
278 case MAIN_PLL:
279 map = tda18271_main_pll;
280 map_name = "main_pll";
281 break;
282 case CAL_PLL:
283 map = tda18271_cal_pll;
284 map_name = "cal_pll";
285 break;
286 default:
287 /* we should never get here */
288 map_name = "undefined";
289 break;
290 }
291
292 if (!map) {
293 dbg_info("%s map is not set!\n", map_name);
294 return -EINVAL;
278 } 295 }
279 *val = map[i].val;
280}
281 296
282static void tda18271_lookup_pll_map(struct tda18271_pll_map *map,
283 u32 *freq, u8 *post_div, u8 *div)
284{
285 int i = 0;
286 while ((map[i].lomax * 1000) < *freq) { 297 while ((map[i].lomax * 1000) < *freq) {
287 if (map[i + 1].lomax == 0) 298 if (map[i + 1].lomax == 0)
288 break; 299 break;
@@ -290,56 +301,65 @@ static void tda18271_lookup_pll_map(struct tda18271_pll_map *map,
290 } 301 }
291 *post_div = map[i].pd; 302 *post_div = map[i].pd;
292 *div = map[i].d; 303 *div = map[i].d;
293}
294
295/*---------------------------------------------------------------------*/
296 304
297void tda18271_lookup_cal_pll(u32 *freq, u8 *post_div, u8 *div) 305 dbg_map("%s: post div = 0x%02x, div = 0x%02x\n",
298{ 306 map_name, *post_div, *div);
299 tda18271_lookup_pll_map(tda18271_cal_pll, freq, post_div, div);
300 dbg_map("post div = 0x%02x, div = 0x%02x\n", *post_div, *div);
301}
302 307
303void tda18271_lookup_main_pll(u32 *freq, u8 *post_div, u8 *div) 308 return 0;
304{
305 tda18271_lookup_pll_map(tda18271_main_pll, freq, post_div, div);
306 dbg_map("post div = 0x%02x, div = 0x%02x\n", *post_div, *div);
307} 309}
308 310
309void tda18271_lookup_bp_filter(u32 *freq, u8 *val) 311int tda18271_lookup_map(enum tda18271_map_type map_type, u32 *freq, u8 *val)
310{ 312{
311 tda18271_lookup_map(tda18271_bp_filter, freq, val); 313 struct tda18271_map *map = NULL;
312 dbg_map("0x%02x\n", *val); 314 unsigned int i = 0;
313} 315 char *map_name;
314 316
315void tda18271_lookup_km(u32 *freq, u8 *val) 317 switch (map_type) {
316{ 318 case BP_FILTER:
317 tda18271_lookup_map(tda18271_km, freq, val); 319 map = tda18271_bp_filter;
318 dbg_map("0x%02x\n", *val); 320 map_name = "bp_filter";
319} 321 break;
322 case RF_CAL_KMCO:
323 map = tda18271_km;
324 map_name = "km";
325 break;
326 case RF_BAND:
327 map = tda18271_rf_band;
328 map_name = "rf_band";
329 break;
330 case GAIN_TAPER:
331 map = tda18271_gain_taper;
332 map_name = "gain_taper";
333 break;
334 case RF_CAL:
335 map = tda18271_rf_cal;
336 map_name = "rf_cal";
337 break;
338 case IR_MEASURE:
339 map = tda18271_ir_measure;
340 map_name = "ir_measure";
341 break;
342 default:
343 /* we should never get here */
344 map_name = "undefined";
345 break;
346 }
320 347
321void tda18271_lookup_rf_band(u32 *freq, u8 *val) 348 if (!map) {
322{ 349 dbg_info("%s map is not set!\n", map_name);
323 tda18271_lookup_map(tda18271_rf_band, freq, val); 350 return -EINVAL;
324 dbg_map("0x%02x\n", *val); 351 }
325}
326 352
327void tda18271_lookup_gain_taper(u32 *freq, u8 *val) 353 while ((map[i].rfmax * 1000) < *freq) {
328{ 354 if (map[i + 1].rfmax == 0)
329 tda18271_lookup_map(tda18271_gain_taper, freq, val); 355 break;
330 dbg_map("0x%02x\n", *val); 356 i++;
331} 357 }
358 *val = map[i].val;
332 359
333void tda18271_lookup_rf_cal(u32 *freq, u8 *val) 360 dbg_map("%s: 0x%02x\n", map_name, *val);
334{
335 tda18271_lookup_map(tda18271_rf_cal, freq, val);
336 dbg_map("0x%02x\n", *val);
337}
338 361
339void tda18271_lookup_ir_measure(u32 *freq, u8 *val) 362 return 0;
340{
341 tda18271_lookup_map(tda18271_ir_measure, freq, val);
342 dbg_map("0x%02x\n", *val);
343} 363}
344 364
345/* 365/*