Commit d884acad authored by Antti Palosaari's avatar Antti Palosaari Committed by Mauro Carvalho Chehab

[media] rtl2832: improve slave TS control

Add callback parameter to select enable / disable slave TS and use
it when slave demod is in use.
Signed-off-by: default avatarAntti Palosaari <crope@iki.fi>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 7908fad9
...@@ -347,6 +347,10 @@ static int rtl2832_init(struct dvb_frontend *fe) ...@@ -347,6 +347,10 @@ static int rtl2832_init(struct dvb_frontend *fe)
dev_dbg(&client->dev, "\n"); dev_dbg(&client->dev, "\n");
ret = rtl2832_wr_demod_reg(dev, DVBT_SOFT_RST, 0x0);
if (ret)
goto err;
for (i = 0; i < ARRAY_SIZE(rtl2832_initial_regs); i++) { for (i = 0; i < ARRAY_SIZE(rtl2832_initial_regs); i++) {
ret = rtl2832_wr_demod_reg(dev, rtl2832_initial_regs[i].reg, ret = rtl2832_wr_demod_reg(dev, rtl2832_initial_regs[i].reg,
rtl2832_initial_regs[i].value); rtl2832_initial_regs[i].value);
...@@ -491,11 +495,6 @@ static int rtl2832_set_frontend(struct dvb_frontend *fe) ...@@ -491,11 +495,6 @@ static int rtl2832_set_frontend(struct dvb_frontend *fe)
if (fe->ops.tuner_ops.set_params) if (fe->ops.tuner_ops.set_params)
fe->ops.tuner_ops.set_params(fe); fe->ops.tuner_ops.set_params(fe);
/* PIP mode related */
ret = rtl2832_bulk_write(client, 0x192, "\x00\x0f\xff", 3);
if (ret)
goto err;
/* If the frontend has get_if_frequency(), use it */ /* If the frontend has get_if_frequency(), use it */
if (fe->ops.tuner_ops.get_if_frequency) { if (fe->ops.tuner_ops.get_if_frequency) {
u32 if_freq; u32 if_freq;
...@@ -1081,37 +1080,46 @@ static struct i2c_adapter *rtl2832_get_i2c_adapter(struct i2c_client *client) ...@@ -1081,37 +1080,46 @@ static struct i2c_adapter *rtl2832_get_i2c_adapter(struct i2c_client *client)
return dev->i2c_adapter_tuner; return dev->i2c_adapter_tuner;
} }
static int rtl2832_enable_slave_ts(struct i2c_client *client) static int rtl2832_slave_ts_ctrl(struct i2c_client *client, bool enable)
{ {
struct rtl2832_dev *dev = i2c_get_clientdata(client); struct rtl2832_dev *dev = i2c_get_clientdata(client);
int ret; int ret;
dev_dbg(&client->dev, "\n"); dev_dbg(&client->dev, "enable=%d\n", enable);
ret = rtl2832_bulk_write(client, 0x10c, "\x5f\xff", 2);
if (ret)
goto err;
ret = rtl2832_wr_demod_reg(dev, DVBT_PIP_ON, 0x1);
if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x0bc, "\x18", 1);
if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x192, "\x7f\xf7\xff", 3);
if (ret)
goto err;
/* soft reset */
ret = rtl2832_wr_demod_reg(dev, DVBT_SOFT_RST, 0x1);
if (ret)
goto err;
ret = rtl2832_wr_demod_reg(dev, DVBT_SOFT_RST, 0x0); if (enable) {
if (ret) ret = rtl2832_wr_demod_reg(dev, DVBT_SOFT_RST, 0x0);
goto err; if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x10c, "\x5f\xff", 2);
if (ret)
goto err;
ret = rtl2832_wr_demod_reg(dev, DVBT_PIP_ON, 0x1);
if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x0bc, "\x18", 1);
if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x192, "\x7f\xf7\xff", 3);
if (ret)
goto err;
} else {
ret = rtl2832_bulk_write(client, 0x192, "\x00\x0f\xff", 3);
if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x0bc, "\x08", 1);
if (ret)
goto err;
ret = rtl2832_wr_demod_reg(dev, DVBT_PIP_ON, 0x0);
if (ret)
goto err;
ret = rtl2832_bulk_write(client, 0x10c, "\x00\x00", 2);
if (ret)
goto err;
ret = rtl2832_wr_demod_reg(dev, DVBT_SOFT_RST, 0x1);
if (ret)
goto err;
}
return 0; return 0;
err: err:
...@@ -1267,7 +1275,7 @@ static int rtl2832_probe(struct i2c_client *client, ...@@ -1267,7 +1275,7 @@ static int rtl2832_probe(struct i2c_client *client,
/* setup callbacks */ /* setup callbacks */
pdata->get_dvb_frontend = rtl2832_get_dvb_frontend; pdata->get_dvb_frontend = rtl2832_get_dvb_frontend;
pdata->get_i2c_adapter = rtl2832_get_i2c_adapter; pdata->get_i2c_adapter = rtl2832_get_i2c_adapter;
pdata->enable_slave_ts = rtl2832_enable_slave_ts; pdata->slave_ts_ctrl = rtl2832_slave_ts_ctrl;
pdata->pid_filter = rtl2832_pid_filter; pdata->pid_filter = rtl2832_pid_filter;
pdata->pid_filter_ctrl = rtl2832_pid_filter_ctrl; pdata->pid_filter_ctrl = rtl2832_pid_filter_ctrl;
pdata->bulk_read = rtl2832_bulk_read; pdata->bulk_read = rtl2832_bulk_read;
......
...@@ -31,7 +31,7 @@ ...@@ -31,7 +31,7 @@
* @tuner: Used tuner model. * @tuner: Used tuner model.
* @get_dvb_frontend: Get DVB frontend. * @get_dvb_frontend: Get DVB frontend.
* @get_i2c_adapter: Get I2C adapter. * @get_i2c_adapter: Get I2C adapter.
* @enable_slave_ts: Enable slave TS IF. * @slave_ts_ctrl: Control slave TS interface.
* @pid_filter: Set PID to PID filter. * @pid_filter: Set PID to PID filter.
* @pid_filter_ctrl: Control PID filter. * @pid_filter_ctrl: Control PID filter.
*/ */
...@@ -53,7 +53,7 @@ struct rtl2832_platform_data { ...@@ -53,7 +53,7 @@ struct rtl2832_platform_data {
struct dvb_frontend* (*get_dvb_frontend)(struct i2c_client *); struct dvb_frontend* (*get_dvb_frontend)(struct i2c_client *);
struct i2c_adapter* (*get_i2c_adapter)(struct i2c_client *); struct i2c_adapter* (*get_i2c_adapter)(struct i2c_client *);
int (*enable_slave_ts)(struct i2c_client *); int (*slave_ts_ctrl)(struct i2c_client *, bool);
int (*pid_filter)(struct dvb_frontend *, u8, u16, int); int (*pid_filter)(struct dvb_frontend *, u8, u16, int);
int (*pid_filter_ctrl)(struct dvb_frontend *, int); int (*pid_filter_ctrl)(struct dvb_frontend *, int);
/* private: Register access for SDR module use only */ /* private: Register access for SDR module use only */
......
...@@ -1571,19 +1571,19 @@ static int rtl28xxu_frontend_ctrl(struct dvb_frontend *fe, int onoff) ...@@ -1571,19 +1571,19 @@ static int rtl28xxu_frontend_ctrl(struct dvb_frontend *fe, int onoff)
if (dev->chip_id == CHIP_ID_RTL2831U) if (dev->chip_id == CHIP_ID_RTL2831U)
return 0; return 0;
/* control internal demod ADC */ if (fe->id == 0) {
if (fe->id == 0 && onoff) /* control internal demod ADC */
val = 0x48; /* enable ADC */ if (onoff)
else val = 0x48; /* enable ADC */
val = 0x00; /* disable ADC */ else
val = 0x00; /* disable ADC */
ret = rtl28xxu_wr_reg_mask(d, SYS_DEMOD_CTL, val, 0x48);
if (ret)
goto err;
/* bypass slave demod TS through master demod */ ret = rtl28xxu_wr_reg_mask(d, SYS_DEMOD_CTL, val, 0x48);
if (fe->id == 1 && onoff) { if (ret)
ret = pdata->enable_slave_ts(dev->i2c_client_demod); goto err;
} else if (fe->id == 1) {
/* bypass slave demod TS through master demod */
ret = pdata->slave_ts_ctrl(dev->i2c_client_demod, onoff);
if (ret) if (ret)
goto err; goto err;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment