[media] rtl2830: prevent .read_status() when sleeping

Hardware is not accessible when device is sleeping.
Preventing such IOCTLs when sleep should be job of DVB CORE...

Signed-off-by: Antti Palosaari <crope@iki.fi>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
Antti Palosaari 2012-01-21 22:40:58 -03:00 committed by Mauro Carvalho Chehab
parent 9935eea5ac
commit a8567cf22e
3 changed files with 17 additions and 5 deletions

View File

@ -608,11 +608,6 @@ static int rtl28xxu_power_ctrl(struct dvb_usb_device *d, int onoff)
sys0 = sys0 & 0x0f; sys0 = sys0 & 0x0f;
sys0 |= 0xe0; sys0 |= 0xe0;
} else { } else {
/*
* FIXME: Use .fe_ioctl_override() to prevent demod
* IOCTLs in case of device is powered off. Or change
* RTL2830 demod not perform requestesd IOCTL & IO when sleep.
*/
gpio &= (~0x01); /* GPIO0 = 0 */ gpio &= (~0x01); /* GPIO0 = 0 */
gpio |= 0x10; /* GPIO4 = 1 */ gpio |= 0x10; /* GPIO4 = 1 */
sys0 = sys0 & (~0xc0); sys0 = sys0 & (~0xc0);

View File

@ -273,12 +273,21 @@ static int rtl2830_init(struct dvb_frontend *fe)
if (ret) if (ret)
goto err; goto err;
priv->sleeping = false;
return ret; return ret;
err: err:
dbg("%s: failed=%d", __func__, ret); dbg("%s: failed=%d", __func__, ret);
return ret; return ret;
} }
static int rtl2830_sleep(struct dvb_frontend *fe)
{
struct rtl2830_priv *priv = fe->demodulator_priv;
priv->sleeping = true;
return 0;
}
int rtl2830_get_tune_settings(struct dvb_frontend *fe, int rtl2830_get_tune_settings(struct dvb_frontend *fe,
struct dvb_frontend_tune_settings *s) struct dvb_frontend_tune_settings *s)
{ {
@ -372,6 +381,9 @@ static int rtl2830_read_status(struct dvb_frontend *fe, fe_status_t *status)
u8 tmp; u8 tmp;
*status = 0; *status = 0;
if (priv->sleeping)
return 0;
ret = rtl2830_rd_reg_mask(priv, 0x351, &tmp, 0x78); /* [6:3] */ ret = rtl2830_rd_reg_mask(priv, 0x351, &tmp, 0x78); /* [6:3] */
if (ret) if (ret)
goto err; goto err;
@ -498,6 +510,8 @@ struct dvb_frontend *rtl2830_attach(const struct rtl2830_config *cfg,
goto err; goto err;
} }
priv->sleeping = true;
return &priv->fe; return &priv->fe;
err: err:
dbg("%s: failed=%d", __func__, ret); dbg("%s: failed=%d", __func__, ret);
@ -530,6 +544,7 @@ static struct dvb_frontend_ops rtl2830_ops = {
.release = rtl2830_release, .release = rtl2830_release,
.init = rtl2830_init, .init = rtl2830_init,
.sleep = rtl2830_sleep,
.get_tune_settings = rtl2830_get_tune_settings, .get_tune_settings = rtl2830_get_tune_settings,

View File

@ -43,6 +43,8 @@ struct rtl2830_priv {
struct rtl2830_config cfg; struct rtl2830_config cfg;
struct i2c_adapter tuner_i2c_adapter; struct i2c_adapter tuner_i2c_adapter;
bool sleeping;
u8 page; /* active register page */ u8 page; /* active register page */
}; };