diff options
Diffstat (limited to 'drivers/media/dvb/ttpci/budget-ci.c')
-rw-r--r-- | drivers/media/dvb/ttpci/budget-ci.c | 136 |
1 files changed, 19 insertions, 117 deletions
diff --git a/drivers/media/dvb/ttpci/budget-ci.c b/drivers/media/dvb/ttpci/budget-ci.c index b9b3cd9c0369..5f91036f5b87 100644 --- a/drivers/media/dvb/ttpci/budget-ci.c +++ b/drivers/media/dvb/ttpci/budget-ci.c | |||
@@ -42,6 +42,9 @@ | |||
42 | #include "stv0299.h" | 42 | #include "stv0299.h" |
43 | #include "stv0297.h" | 43 | #include "stv0297.h" |
44 | #include "tda1004x.h" | 44 | #include "tda1004x.h" |
45 | #include "lnbp21.h" | ||
46 | #include "bsbe1.h" | ||
47 | #include "bsru6.h" | ||
45 | 48 | ||
46 | #define DEBIADDR_IR 0x1234 | 49 | #define DEBIADDR_IR 0x1234 |
47 | #define DEBIADDR_CICONTROL 0x0000 | 50 | #define DEBIADDR_CICONTROL 0x0000 |
@@ -474,123 +477,6 @@ static void budget_ci_irq(struct saa7146_dev *dev, u32 * isr) | |||
474 | tasklet_schedule(&budget_ci->ciintf_irq_tasklet); | 477 | tasklet_schedule(&budget_ci->ciintf_irq_tasklet); |
475 | } | 478 | } |
476 | 479 | ||
477 | |||
478 | static u8 alps_bsru6_inittab[] = { | ||
479 | 0x01, 0x15, | ||
480 | 0x02, 0x00, | ||
481 | 0x03, 0x00, | ||
482 | 0x04, 0x7d, /* F22FR = 0x7d, F22 = f_VCO / 128 / 0x7d = 22 kHz */ | ||
483 | 0x05, 0x35, /* I2CT = 0, SCLT = 1, SDAT = 1 */ | ||
484 | 0x06, 0x40, /* DAC not used, set to high impendance mode */ | ||
485 | 0x07, 0x00, /* DAC LSB */ | ||
486 | 0x08, 0x40, /* DiSEqC off, LNB power on OP2/LOCK pin on */ | ||
487 | 0x09, 0x00, /* FIFO */ | ||
488 | 0x0c, 0x51, /* OP1 ctl = Normal, OP1 val = 1 (LNB Power ON) */ | ||
489 | 0x0d, 0x82, /* DC offset compensation = ON, beta_agc1 = 2 */ | ||
490 | 0x0e, 0x23, /* alpha_tmg = 2, beta_tmg = 3 */ | ||
491 | 0x10, 0x3f, // AGC2 0x3d | ||
492 | 0x11, 0x84, | ||
493 | 0x12, 0xb9, | ||
494 | 0x15, 0xc9, // lock detector threshold | ||
495 | 0x16, 0x00, | ||
496 | 0x17, 0x00, | ||
497 | 0x18, 0x00, | ||
498 | 0x19, 0x00, | ||
499 | 0x1a, 0x00, | ||
500 | 0x1f, 0x50, | ||
501 | 0x20, 0x00, | ||
502 | 0x21, 0x00, | ||
503 | 0x22, 0x00, | ||
504 | 0x23, 0x00, | ||
505 | 0x28, 0x00, // out imp: normal out type: parallel FEC mode:0 | ||
506 | 0x29, 0x1e, // 1/2 threshold | ||
507 | 0x2a, 0x14, // 2/3 threshold | ||
508 | 0x2b, 0x0f, // 3/4 threshold | ||
509 | 0x2c, 0x09, // 5/6 threshold | ||
510 | 0x2d, 0x05, // 7/8 threshold | ||
511 | 0x2e, 0x01, | ||
512 | 0x31, 0x1f, // test all FECs | ||
513 | 0x32, 0x19, // viterbi and synchro search | ||
514 | 0x33, 0xfc, // rs control | ||
515 | 0x34, 0x93, // error control | ||
516 | 0x0f, 0x52, | ||
517 | 0xff, 0xff | ||
518 | }; | ||
519 | |||
520 | static int alps_bsru6_set_symbol_rate(struct dvb_frontend *fe, u32 srate, u32 ratio) | ||
521 | { | ||
522 | u8 aclk = 0; | ||
523 | u8 bclk = 0; | ||
524 | |||
525 | if (srate < 1500000) { | ||
526 | aclk = 0xb7; | ||
527 | bclk = 0x47; | ||
528 | } else if (srate < 3000000) { | ||
529 | aclk = 0xb7; | ||
530 | bclk = 0x4b; | ||
531 | } else if (srate < 7000000) { | ||
532 | aclk = 0xb7; | ||
533 | bclk = 0x4f; | ||
534 | } else if (srate < 14000000) { | ||
535 | aclk = 0xb7; | ||
536 | bclk = 0x53; | ||
537 | } else if (srate < 30000000) { | ||
538 | aclk = 0xb6; | ||
539 | bclk = 0x53; | ||
540 | } else if (srate < 45000000) { | ||
541 | aclk = 0xb4; | ||
542 | bclk = 0x51; | ||
543 | } | ||
544 | |||
545 | stv0299_writereg(fe, 0x13, aclk); | ||
546 | stv0299_writereg(fe, 0x14, bclk); | ||
547 | stv0299_writereg(fe, 0x1f, (ratio >> 16) & 0xff); | ||
548 | stv0299_writereg(fe, 0x20, (ratio >> 8) & 0xff); | ||
549 | stv0299_writereg(fe, 0x21, (ratio) & 0xf0); | ||
550 | |||
551 | return 0; | ||
552 | } | ||
553 | |||
554 | static int alps_bsru6_pll_set(struct dvb_frontend *fe, struct i2c_adapter *i2c, struct dvb_frontend_parameters *params) | ||
555 | { | ||
556 | u8 buf[4]; | ||
557 | u32 div; | ||
558 | struct i2c_msg msg = {.addr = 0x61,.flags = 0,.buf = buf,.len = sizeof(buf) }; | ||
559 | |||
560 | if ((params->frequency < 950000) || (params->frequency > 2150000)) | ||
561 | return -EINVAL; | ||
562 | |||
563 | div = (params->frequency + (125 - 1)) / 125; // round correctly | ||
564 | buf[0] = (div >> 8) & 0x7f; | ||
565 | buf[1] = div & 0xff; | ||
566 | buf[2] = 0x80 | ((div & 0x18000) >> 10) | 4; | ||
567 | buf[3] = 0xC4; | ||
568 | |||
569 | if (params->frequency > 1530000) | ||
570 | buf[3] = 0xc0; | ||
571 | |||
572 | if (i2c_transfer(i2c, &msg, 1) != 1) | ||
573 | return -EIO; | ||
574 | return 0; | ||
575 | } | ||
576 | |||
577 | static struct stv0299_config alps_bsru6_config = { | ||
578 | |||
579 | .demod_address = 0x68, | ||
580 | .inittab = alps_bsru6_inittab, | ||
581 | .mclk = 88000000UL, | ||
582 | .invert = 1, | ||
583 | .skip_reinit = 0, | ||
584 | .lock_output = STV0229_LOCKOUTPUT_1, | ||
585 | .volt13_op0_op1 = STV0299_VOLT13_OP1, | ||
586 | .min_delay_ms = 100, | ||
587 | .set_symbol_rate = alps_bsru6_set_symbol_rate, | ||
588 | .pll_set = alps_bsru6_pll_set, | ||
589 | }; | ||
590 | |||
591 | |||
592 | |||
593 | |||
594 | static u8 philips_su1278_tt_inittab[] = { | 480 | static u8 philips_su1278_tt_inittab[] = { |
595 | 0x01, 0x0f, | 481 | 0x01, 0x0f, |
596 | 0x02, 0x30, | 482 | 0x02, 0x30, |
@@ -1069,6 +955,20 @@ static void frontend_init(struct budget_ci *budget_ci) | |||
1069 | break; | 955 | break; |
1070 | } | 956 | } |
1071 | break; | 957 | break; |
958 | |||
959 | case 0x1017: // TT S-1500 PCI | ||
960 | budget_ci->budget.dvb_frontend = stv0299_attach(&alps_bsbe1_config, &budget_ci->budget.i2c_adap); | ||
961 | if (budget_ci->budget.dvb_frontend) { | ||
962 | budget_ci->budget.dvb_frontend->ops->dishnetwork_send_legacy_command = NULL; | ||
963 | if (lnbp21_init(budget_ci->budget.dvb_frontend, &budget_ci->budget.i2c_adap, LNBP21_LLC, 0)) { | ||
964 | printk("%s: No LNBP21 found!\n", __FUNCTION__); | ||
965 | if (budget_ci->budget.dvb_frontend->ops->release) | ||
966 | budget_ci->budget.dvb_frontend->ops->release(budget_ci->budget.dvb_frontend); | ||
967 | budget_ci->budget.dvb_frontend = NULL; | ||
968 | } | ||
969 | } | ||
970 | |||
971 | break; | ||
1072 | } | 972 | } |
1073 | 973 | ||
1074 | if (budget_ci->budget.dvb_frontend == NULL) { | 974 | if (budget_ci->budget.dvb_frontend == NULL) { |
@@ -1146,6 +1046,7 @@ static int budget_ci_detach(struct saa7146_dev *dev) | |||
1146 | 1046 | ||
1147 | static struct saa7146_extension budget_extension; | 1047 | static struct saa7146_extension budget_extension; |
1148 | 1048 | ||
1049 | MAKE_BUDGET_INFO(ttbs2, "TT-Budget/S-1500 PCI", BUDGET_TT); | ||
1149 | MAKE_BUDGET_INFO(ttbci, "TT-Budget/WinTV-NOVA-CI PCI", BUDGET_TT_HW_DISEQC); | 1050 | MAKE_BUDGET_INFO(ttbci, "TT-Budget/WinTV-NOVA-CI PCI", BUDGET_TT_HW_DISEQC); |
1150 | MAKE_BUDGET_INFO(ttbt2, "TT-Budget/WinTV-NOVA-T PCI", BUDGET_TT); | 1051 | MAKE_BUDGET_INFO(ttbt2, "TT-Budget/WinTV-NOVA-T PCI", BUDGET_TT); |
1151 | MAKE_BUDGET_INFO(ttbtci, "TT-Budget-T-CI PCI", BUDGET_TT); | 1052 | MAKE_BUDGET_INFO(ttbtci, "TT-Budget-T-CI PCI", BUDGET_TT); |
@@ -1157,6 +1058,7 @@ static struct pci_device_id pci_tbl[] = { | |||
1157 | MAKE_EXTENSION_PCI(ttbcci, 0x13c2, 0x1010), | 1058 | MAKE_EXTENSION_PCI(ttbcci, 0x13c2, 0x1010), |
1158 | MAKE_EXTENSION_PCI(ttbt2, 0x13c2, 0x1011), | 1059 | MAKE_EXTENSION_PCI(ttbt2, 0x13c2, 0x1011), |
1159 | MAKE_EXTENSION_PCI(ttbtci, 0x13c2, 0x1012), | 1060 | MAKE_EXTENSION_PCI(ttbtci, 0x13c2, 0x1012), |
1061 | MAKE_EXTENSION_PCI(ttbs2, 0x13c2, 0x1017), | ||
1160 | { | 1062 | { |
1161 | .vendor = 0, | 1063 | .vendor = 0, |
1162 | } | 1064 | } |