blob: 70df31b0a8a9cdecfae95d3f4dea2efc07ad0b5f [file] [log] [blame]
Johannes Stezenbach776338e2005-06-23 22:02:35 -07001/* dvb-usb-i2c.c is part of the DVB USB library.
2 *
Patrick Boettcher4d43e132006-09-30 06:53:48 -03003 * Copyright (C) 2004-6 Patrick Boettcher (patrick.boettcher@desy.de)
Johannes Stezenbach776338e2005-06-23 22:02:35 -07004 * see dvb-usb-init.c for copyright information.
5 *
6 * This file contains functions for (de-)initializing an I2C adapter.
7 */
8#include "dvb-usb-common.h"
9
10int dvb_usb_i2c_init(struct dvb_usb_device *d)
11{
12 int ret = 0;
13
14 if (!(d->props.caps & DVB_USB_IS_AN_I2C_ADAPTER))
15 return 0;
16
17 if (d->props.i2c_algo == NULL) {
18 err("no i2c algorithm specified");
19 return -EINVAL;
20 }
21
22 strncpy(d->i2c_adap.name,d->desc->name,I2C_NAME_SIZE);
23#ifdef I2C_ADAP_CLASS_TV_DIGITAL
24 d->i2c_adap.class = I2C_ADAP_CLASS_TV_DIGITAL,
25#else
26 d->i2c_adap.class = I2C_CLASS_TV_DIGITAL,
27#endif
28 d->i2c_adap.algo = d->props.i2c_algo;
29 d->i2c_adap.algo_data = NULL;
Jean Delvare12a917f2007-02-13 22:09:03 +010030 d->i2c_adap.dev.parent = &d->udev->dev;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070031
32 i2c_set_adapdata(&d->i2c_adap, d);
33
34 if ((ret = i2c_add_adapter(&d->i2c_adap)) < 0)
35 err("could not add i2c adapter");
36
37 d->state |= DVB_USB_STATE_I2C;
38
39 return ret;
40}
41
42int dvb_usb_i2c_exit(struct dvb_usb_device *d)
43{
44 if (d->state & DVB_USB_STATE_I2C)
45 i2c_del_adapter(&d->i2c_adap);
46 d->state &= ~DVB_USB_STATE_I2C;
47 return 0;
48}
49
Andrew de Quinceyee6a2cb2006-04-18 17:47:11 -030050int dvb_usb_tuner_init_i2c(struct dvb_frontend *fe)
Johannes Stezenbach776338e2005-06-23 22:02:35 -070051{
Patrick Boettcher4d43e132006-09-30 06:53:48 -030052 struct dvb_usb_adapter *adap = fe->dvb->priv;
53 struct i2c_msg msg = { .addr = adap->pll_addr, .flags = 0, .buf = adap->pll_init, .len = 4 };
Johannes Stezenbach776338e2005-06-23 22:02:35 -070054 int ret = 0;
55
Patrick Boettchera6bab882006-01-09 18:21:33 -020056 /* if pll_desc is not used */
Patrick Boettcher4d43e132006-09-30 06:53:48 -030057 if (adap->pll_desc == NULL)
Johannes Stezenbach776338e2005-06-23 22:02:35 -070058 return 0;
59
Patrick Boettcher4d43e132006-09-30 06:53:48 -030060 if (adap->tuner_pass_ctrl)
61 adap->tuner_pass_ctrl(fe, 1, adap->pll_addr);
Johannes Stezenbach776338e2005-06-23 22:02:35 -070062
Patrick Boettcher4d43e132006-09-30 06:53:48 -030063 deb_pll("pll init: %x\n",adap->pll_addr);
64 deb_pll("pll-buf: %x %x %x %x\n",adap->pll_init[0], adap->pll_init[1],
65 adap->pll_init[2], adap->pll_init[3]);
Johannes Stezenbach776338e2005-06-23 22:02:35 -070066
Patrick Boettcherdea74862006-05-14 05:01:31 -030067 if (fe->ops.i2c_gate_ctrl)
68 fe->ops.i2c_gate_ctrl(fe, 1);
Patrick Boettcher4d43e132006-09-30 06:53:48 -030069 if (i2c_transfer (&adap->dev->i2c_adap, &msg, 1) != 1) {
Johannes Stezenbach776338e2005-06-23 22:02:35 -070070 err("tuner i2c write failed for pll_init.");
71 ret = -EREMOTEIO;
72 }
73 msleep(1);
74
Patrick Boettcher4d43e132006-09-30 06:53:48 -030075 if (adap->tuner_pass_ctrl)
76 adap->tuner_pass_ctrl(fe,0,adap->pll_addr);
Johannes Stezenbach776338e2005-06-23 22:02:35 -070077 return ret;
78}
Andrew de Quinceyee6a2cb2006-04-18 17:47:11 -030079EXPORT_SYMBOL(dvb_usb_tuner_init_i2c);
Johannes Stezenbach776338e2005-06-23 22:02:35 -070080
Andrew de Quinceyd3b9d622006-04-25 05:36:19 -030081int dvb_usb_tuner_calc_regs(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep, u8 *b, int buf_len)
Johannes Stezenbach776338e2005-06-23 22:02:35 -070082{
Patrick Boettcher4d43e132006-09-30 06:53:48 -030083 struct dvb_usb_adapter *adap = fe->dvb->priv;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070084
Andrew de Quinceyee6a2cb2006-04-18 17:47:11 -030085 if (buf_len != 5)
86 return -EINVAL;
Patrick Boettcher4d43e132006-09-30 06:53:48 -030087 if (adap->pll_desc == NULL)
Patrick Boettchera6bab882006-01-09 18:21:33 -020088 return 0;
89
Patrick Boettcher4d43e132006-09-30 06:53:48 -030090 deb_pll("pll addr: %x, freq: %d %p\n",adap->pll_addr, fep->frequency, adap->pll_desc);
Johannes Stezenbach776338e2005-06-23 22:02:35 -070091
Patrick Boettcher4d43e132006-09-30 06:53:48 -030092 b[0] = adap->pll_addr;
93 dvb_pll_configure(adap->pll_desc, &b[1], fep->frequency, fep->u.ofdm.bandwidth);
Johannes Stezenbach776338e2005-06-23 22:02:35 -070094
95 deb_pll("pll-buf: %x %x %x %x %x\n",b[0],b[1],b[2],b[3],b[4]);
96
Andrew de Quinceyee6a2cb2006-04-18 17:47:11 -030097 return 5;
Johannes Stezenbach776338e2005-06-23 22:02:35 -070098}
Andrew de Quinceyd3b9d622006-04-25 05:36:19 -030099EXPORT_SYMBOL(dvb_usb_tuner_calc_regs);
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700100
Andrew de Quinceyd3b9d622006-04-25 05:36:19 -0300101int dvb_usb_tuner_set_params_i2c(struct dvb_frontend *fe, struct dvb_frontend_parameters *fep)
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700102{
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300103 struct dvb_usb_adapter *adap = fe->dvb->priv;
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700104 int ret = 0;
105 u8 b[5];
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300106 struct i2c_msg msg = { .addr = adap->pll_addr, .flags = 0, .buf = &b[1], .len = 4 };
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700107
Andrew de Quinceyd3b9d622006-04-25 05:36:19 -0300108 dvb_usb_tuner_calc_regs(fe,fep,b,5);
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700109
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300110 if (adap->tuner_pass_ctrl)
111 adap->tuner_pass_ctrl(fe, 1, adap->pll_addr);
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700112
Patrick Boettcherdea74862006-05-14 05:01:31 -0300113 if (fe->ops.i2c_gate_ctrl)
114 fe->ops.i2c_gate_ctrl(fe, 1);
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300115
116 if (i2c_transfer(&adap->dev->i2c_adap, &msg, 1) != 1) {
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700117 err("tuner i2c write failed for pll_set.");
118 ret = -EREMOTEIO;
119 }
120 msleep(1);
121
Patrick Boettcher4d43e132006-09-30 06:53:48 -0300122 if (adap->tuner_pass_ctrl)
123 adap->tuner_pass_ctrl(fe, 0, adap->pll_addr);
Johannes Stezenbach776338e2005-06-23 22:02:35 -0700124
125 return ret;
126}
Andrew de Quinceyd3b9d622006-04-25 05:36:19 -0300127EXPORT_SYMBOL(dvb_usb_tuner_set_params_i2c);