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

[media] mn88472: implement signal strength statistics

Implement DVBv5 signal strength on relative scale.
Signed-off-by: default avatarAntti Palosaari <crope@iki.fi>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent 0f314f6c
...@@ -28,8 +28,9 @@ static int mn88472_read_status(struct dvb_frontend *fe, enum fe_status *status) ...@@ -28,8 +28,9 @@ static int mn88472_read_status(struct dvb_frontend *fe, enum fe_status *status)
struct i2c_client *client = fe->demodulator_priv; struct i2c_client *client = fe->demodulator_priv;
struct mn88472_dev *dev = i2c_get_clientdata(client); struct mn88472_dev *dev = i2c_get_clientdata(client);
struct dtv_frontend_properties *c = &fe->dtv_property_cache; struct dtv_frontend_properties *c = &fe->dtv_property_cache;
int ret; int ret, i;
unsigned int utmp; unsigned int utmp, utmp1;
u8 buf[2];
if (!dev->active) { if (!dev->active) {
ret = -EAGAIN; ret = -EAGAIN;
...@@ -77,6 +78,24 @@ static int mn88472_read_status(struct dvb_frontend *fe, enum fe_status *status) ...@@ -77,6 +78,24 @@ static int mn88472_read_status(struct dvb_frontend *fe, enum fe_status *status)
goto err; goto err;
} }
/* Signal strength */
if (*status & FE_HAS_SIGNAL) {
for (i = 0; i < 2; i++) {
ret = regmap_bulk_read(dev->regmap[2], 0x8e + i,
&buf[i], 1);
if (ret)
goto err;
}
utmp1 = buf[0] << 8 | buf[1] << 0 | buf[0] >> 2;
dev_dbg(&client->dev, "strength=%u\n", utmp1);
c->strength.stat[0].scale = FE_SCALE_RELATIVE;
c->strength.stat[0].uvalue = utmp1;
} else {
c->strength.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
}
return 0; return 0;
err: err:
dev_dbg(&client->dev, "failed=%d\n", ret); dev_dbg(&client->dev, "failed=%d\n", ret);
...@@ -462,6 +481,7 @@ static int mn88472_probe(struct i2c_client *client, ...@@ -462,6 +481,7 @@ static int mn88472_probe(struct i2c_client *client,
{ {
struct mn88472_config *pdata = client->dev.platform_data; struct mn88472_config *pdata = client->dev.platform_data;
struct mn88472_dev *dev; struct mn88472_dev *dev;
struct dtv_frontend_properties *c;
int ret; int ret;
unsigned int utmp; unsigned int utmp;
static const struct regmap_config regmap_config = { static const struct regmap_config regmap_config = {
...@@ -547,6 +567,10 @@ static int mn88472_probe(struct i2c_client *client, ...@@ -547,6 +567,10 @@ static int mn88472_probe(struct i2c_client *client,
*pdata->fe = &dev->fe; *pdata->fe = &dev->fe;
i2c_set_clientdata(client, dev); i2c_set_clientdata(client, dev);
/* Init stats to indicate which stats are supported */
c = &dev->fe.dtv_property_cache;
c->strength.len = 1;
/* Setup callbacks */ /* Setup callbacks */
pdata->get_dvb_frontend = mn88472_get_dvb_frontend; pdata->get_dvb_frontend = mn88472_get_dvb_frontend;
......
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