aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/dvb/dvb-usb/digitv.c21
-rw-r--r--drivers/media/dvb/dvb-usb/digitv.h4
-rw-r--r--drivers/media/dvb/dvb-usb/dvb-usb-i2c.c22
-rw-r--r--drivers/media/dvb/dvb-usb/dvb-usb.h1
-rw-r--r--drivers/media/dvb/frontends/dvb-pll.c4
-rw-r--r--drivers/media/dvb/frontends/dvb-pll.h3
6 files changed, 23 insertions, 32 deletions
diff --git a/drivers/media/dvb/dvb-usb/digitv.c b/drivers/media/dvb/dvb-usb/digitv.c
index b5acb11c0bc..36e0f8fee37 100644
--- a/drivers/media/dvb/dvb-usb/digitv.c
+++ b/drivers/media/dvb/dvb-usb/digitv.c
@@ -118,7 +118,8 @@ static int digitv_nxt6000_tuner_set_params(struct dvb_frontend *fe, struct dvb_f
118{ 118{
119 struct dvb_usb_adapter *adap = fe->dvb->priv; 119 struct dvb_usb_adapter *adap = fe->dvb->priv;
120 u8 b[5]; 120 u8 b[5];
121 dvb_usb_tuner_calc_regs(fe,fep,b, 5); 121
122 fe->ops.tuner_ops.calc_regs(fe, fep, b, sizeof(b));
122 if (fe->ops.i2c_gate_ctrl) 123 if (fe->ops.i2c_gate_ctrl)
123 fe->ops.i2c_gate_ctrl(fe, 1); 124 fe->ops.i2c_gate_ctrl(fe, 1);
124 return digitv_ctrl_msg(adap->dev, USB_WRITE_TUNER, 0, &b[1], 4, NULL, 0); 125 return digitv_ctrl_msg(adap->dev, USB_WRITE_TUNER, 0, &b[1], 4, NULL, 0);
@@ -130,12 +131,14 @@ static struct nxt6000_config digitv_nxt6000_config = {
130 131
131static int digitv_frontend_attach(struct dvb_usb_adapter *adap) 132static int digitv_frontend_attach(struct dvb_usb_adapter *adap)
132{ 133{
134 struct digitv_state *st = adap->dev->priv;
135
133 if ((adap->fe = dvb_attach(mt352_attach, &digitv_mt352_config, &adap->dev->i2c_adap)) != NULL) { 136 if ((adap->fe = dvb_attach(mt352_attach, &digitv_mt352_config, &adap->dev->i2c_adap)) != NULL) {
134 adap->fe->ops.tuner_ops.calc_regs = dvb_usb_tuner_calc_regs; 137 st->is_nxt6000 = 0;
135 return 0; 138 return 0;
136 } 139 }
137 if ((adap->fe = dvb_attach(nxt6000_attach, &digitv_nxt6000_config, &adap->dev->i2c_adap)) != NULL) { 140 if ((adap->fe = dvb_attach(nxt6000_attach, &digitv_nxt6000_config, &adap->dev->i2c_adap)) != NULL) {
138 adap->fe->ops.tuner_ops.set_params = digitv_nxt6000_tuner_set_params; 141 st->is_nxt6000 = 1;
139 return 0; 142 return 0;
140 } 143 }
141 return -EIO; 144 return -EIO;
@@ -143,8 +146,14 @@ static int digitv_frontend_attach(struct dvb_usb_adapter *adap)
143 146
144static int digitv_tuner_attach(struct dvb_usb_adapter *adap) 147static int digitv_tuner_attach(struct dvb_usb_adapter *adap)
145{ 148{
146 adap->pll_addr = 0x60; 149 struct digitv_state *st = adap->dev->priv;
147 adap->pll_desc = &dvb_pll_tded4; 150
151 if (!dvb_attach(dvb_pll_attach, adap->fe, 0x60, NULL, &dvb_pll_tded4))
152 return -ENODEV;
153
154 if (st->is_nxt6000)
155 adap->fe->ops.tuner_ops.set_params = digitv_nxt6000_tuner_set_params;
156
148 return 0; 157 return 0;
149} 158}
150 159
@@ -273,6 +282,8 @@ static struct dvb_usb_device_properties digitv_properties = {
273 .usb_ctrl = CYPRESS_FX2, 282 .usb_ctrl = CYPRESS_FX2,
274 .firmware = "dvb-usb-digitv-02.fw", 283 .firmware = "dvb-usb-digitv-02.fw",
275 284
285 .size_of_priv = sizeof(struct digitv_state),
286
276 .num_adapters = 1, 287 .num_adapters = 1,
277 .adapter = { 288 .adapter = {
278 { 289 {
diff --git a/drivers/media/dvb/dvb-usb/digitv.h b/drivers/media/dvb/dvb-usb/digitv.h
index 477ee428a70..8b43e3db869 100644
--- a/drivers/media/dvb/dvb-usb/digitv.h
+++ b/drivers/media/dvb/dvb-usb/digitv.h
@@ -4,6 +4,10 @@
4#define DVB_USB_LOG_PREFIX "digitv" 4#define DVB_USB_LOG_PREFIX "digitv"
5#include "dvb-usb.h" 5#include "dvb-usb.h"
6 6
7struct digitv_state {
8 int is_nxt6000;
9};
10
7extern int dvb_usb_digitv_debug; 11extern int dvb_usb_digitv_debug;
8#define deb_rc(args...) dprintk(dvb_usb_digitv_debug,0x01,args) 12#define deb_rc(args...) dprintk(dvb_usb_digitv_debug,0x01,args)
9 13
diff --git a/drivers/media/dvb/dvb-usb/dvb-usb-i2c.c b/drivers/media/dvb/dvb-usb/dvb-usb-i2c.c
index 4c80823d8d0..5792951b990 100644
--- a/drivers/media/dvb/dvb-usb/dvb-usb-i2c.c
+++ b/drivers/media/dvb/dvb-usb/dvb-usb-i2c.c
@@ -78,26 +78,6 @@ int dvb_usb_tuner_init_i2c(struct dvb_frontend *fe)
78} 78}
79EXPORT_SYMBOL(dvb_usb_tuner_init_i2c); 79EXPORT_SYMBOL(dvb_usb_tuner_init_i2c);
80 80
81int dvb_usb_tuner_calc_regs(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep, u8 *b, int buf_len)
82{
83 struct dvb_usb_adapter *adap = fe->dvb->priv;
84
85 if (buf_len != 5)
86 return -EINVAL;
87 if (adap->pll_desc == NULL)
88 return 0;
89
90 deb_pll("pll addr: %x, freq: %d %p\n",adap->pll_addr, fep->frequency, adap->pll_desc);
91
92 b[0] = adap->pll_addr;
93 dvb_pll_configure(adap->pll_desc, &b[1], fep);
94
95 deb_pll("pll-buf: %x %x %x %x %x\n",b[0],b[1],b[2],b[3],b[4]);
96
97 return 5;
98}
99EXPORT_SYMBOL(dvb_usb_tuner_calc_regs);
100
101int dvb_usb_tuner_set_params_i2c(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep) 81int dvb_usb_tuner_set_params_i2c(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep)
102{ 82{
103 struct dvb_usb_adapter *adap = fe->dvb->priv; 83 struct dvb_usb_adapter *adap = fe->dvb->priv;
@@ -105,7 +85,7 @@ int dvb_usb_tuner_set_params_i2c(struct dvb_frontend *fe, struct dvb_frontend_pa
105 u8 b[5]; 85 u8 b[5];
106 struct i2c_msg msg = { .addr = adap->pll_addr, .flags = 0, .buf = &b[1], .len = 4 }; 86 struct i2c_msg msg = { .addr = adap->pll_addr, .flags = 0, .buf = &b[1], .len = 4 };
107 87
108 dvb_usb_tuner_calc_regs(fe,fep,b,5); 88 fe->ops.tuner_ops.calc_regs(fe, fep, b, sizeof(b));
109 89
110 if (adap->tuner_pass_ctrl) 90 if (adap->tuner_pass_ctrl)
111 adap->tuner_pass_ctrl(fe, 1, adap->pll_addr); 91 adap->tuner_pass_ctrl(fe, 1, adap->pll_addr);
diff --git a/drivers/media/dvb/dvb-usb/dvb-usb.h b/drivers/media/dvb/dvb-usb/dvb-usb.h
index 6f824a569e1..d008a24c247 100644
--- a/drivers/media/dvb/dvb-usb/dvb-usb.h
+++ b/drivers/media/dvb/dvb-usb/dvb-usb.h
@@ -390,7 +390,6 @@ extern int dvb_usb_nec_rc_key_to_event(struct dvb_usb_device *, u8[], u32 *, int
390 390
391/* commonly used pll init and set functions */ 391/* commonly used pll init and set functions */
392extern int dvb_usb_tuner_init_i2c(struct dvb_frontend *); 392extern int dvb_usb_tuner_init_i2c(struct dvb_frontend *);
393extern int dvb_usb_tuner_calc_regs(struct dvb_frontend *, struct dvb_frontend_parameters *, u8 *buf, int buf_len);
394extern int dvb_usb_tuner_set_params_i2c(struct dvb_frontend *, struct dvb_frontend_parameters *); 393extern int dvb_usb_tuner_set_params_i2c(struct dvb_frontend *, struct dvb_frontend_parameters *);
395 394
396/* commonly used firmware download types and function */ 395/* commonly used firmware download types and function */
diff --git a/drivers/media/dvb/frontends/dvb-pll.c b/drivers/media/dvb/frontends/dvb-pll.c
index 9fb4decebd9..5c26fa11298 100644
--- a/drivers/media/dvb/frontends/dvb-pll.c
+++ b/drivers/media/dvb/frontends/dvb-pll.c
@@ -522,8 +522,8 @@ static int debug = 0;
522module_param(debug, int, 0644); 522module_param(debug, int, 0644);
523MODULE_PARM_DESC(debug, "enable verbose debug messages"); 523MODULE_PARM_DESC(debug, "enable verbose debug messages");
524 524
525int dvb_pll_configure(struct dvb_pll_desc *desc, u8 *buf, 525static int dvb_pll_configure(struct dvb_pll_desc *desc, u8 *buf,
526 const struct dvb_frontend_parameters *params) 526 const struct dvb_frontend_parameters *params)
527{ 527{
528 u32 div; 528 u32 div;
529 int i; 529 int i;
diff --git a/drivers/media/dvb/frontends/dvb-pll.h b/drivers/media/dvb/frontends/dvb-pll.h
index 83f1279da77..a88ec86bd3b 100644
--- a/drivers/media/dvb/frontends/dvb-pll.h
+++ b/drivers/media/dvb/frontends/dvb-pll.h
@@ -50,9 +50,6 @@ extern struct dvb_pll_desc dvb_pll_philips_td1316;
50extern struct dvb_pll_desc dvb_pll_thomson_fe6600; 50extern struct dvb_pll_desc dvb_pll_thomson_fe6600;
51extern struct dvb_pll_desc dvb_pll_opera1; 51extern struct dvb_pll_desc dvb_pll_opera1;
52 52
53extern int dvb_pll_configure(struct dvb_pll_desc *desc, u8 *buf,
54 const struct dvb_frontend_parameters *params);
55
56/** 53/**
57 * Attach a dvb-pll to the supplied frontend structure. 54 * Attach a dvb-pll to the supplied frontend structure.
58 * 55 *