aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/dvb-frontends
diff options
context:
space:
mode:
authorAntti Palosaari <crope@iki.fi>2014-12-14 07:59:20 -0500
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>2015-02-03 13:06:30 -0500
commit6b4fd01804ced75fb1385df5f6b9cf830cbe15d9 (patch)
tree3a3e29e870a1a10d3146f1e31910b02606a5a036 /drivers/media/dvb-frontends
parent19d273d63552ac99d171fd68018a41f496248513 (diff)
[media] rtl2832: implement DVBv5 BER statistic
DVBv5 BER. Signed-off-by: Antti Palosaari <crope@iki.fi> Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
Diffstat (limited to 'drivers/media/dvb-frontends')
-rw-r--r--drivers/media/dvb-frontends/rtl2832.c25
-rw-r--r--drivers/media/dvb-frontends/rtl2832_priv.h2
2 files changed, 27 insertions, 0 deletions
diff --git a/drivers/media/dvb-frontends/rtl2832.c b/drivers/media/dvb-frontends/rtl2832.c
index 239472b4ce72..0a0899d2a6b2 100644
--- a/drivers/media/dvb-frontends/rtl2832.c
+++ b/drivers/media/dvb-frontends/rtl2832.c
@@ -476,6 +476,10 @@ static int rtl2832_init(struct dvb_frontend *fe)
476 /* init stats here in order signal app which stats are supported */ 476 /* init stats here in order signal app which stats are supported */
477 c->cnr.len = 1; 477 c->cnr.len = 1;
478 c->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE; 478 c->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
479 c->post_bit_error.len = 1;
480 c->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
481 c->post_bit_count.len = 1;
482 c->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
479 /* start statistics polling */ 483 /* start statistics polling */
480 schedule_delayed_work(&dev->stat_work, msecs_to_jiffies(2000)); 484 schedule_delayed_work(&dev->stat_work, msecs_to_jiffies(2000));
481 dev->sleeping = false; 485 dev->sleeping = false;
@@ -904,6 +908,27 @@ static void rtl2832_stat_work(struct work_struct *work)
904 c->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE; 908 c->cnr.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
905 } 909 }
906 910
911 /* BER */
912 if (dev->fe_status & FE_HAS_LOCK) {
913 ret = rtl2832_bulk_read(client, 0x34e, buf, 2);
914 if (ret)
915 goto err;
916
917 u16tmp = buf[0] << 8 | buf[1] << 0;
918 dev->post_bit_error += u16tmp;
919 dev->post_bit_count += 1000000;
920
921 dev_dbg(&client->dev, "ber errors=%u total=1000000\n", u16tmp);
922
923 c->post_bit_error.stat[0].scale = FE_SCALE_COUNTER;
924 c->post_bit_error.stat[0].uvalue = dev->post_bit_error;
925 c->post_bit_count.stat[0].scale = FE_SCALE_COUNTER;
926 c->post_bit_count.stat[0].uvalue = dev->post_bit_count;
927 } else {
928 c->post_bit_error.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
929 c->post_bit_count.stat[0].scale = FE_SCALE_NOT_AVAILABLE;
930 }
931
907err_schedule_delayed_work: 932err_schedule_delayed_work:
908 schedule_delayed_work(&dev->stat_work, msecs_to_jiffies(2000)); 933 schedule_delayed_work(&dev->stat_work, msecs_to_jiffies(2000));
909 return; 934 return;
diff --git a/drivers/media/dvb-frontends/rtl2832_priv.h b/drivers/media/dvb-frontends/rtl2832_priv.h
index 3c44983b95a0..a5f5ccdf10d8 100644
--- a/drivers/media/dvb-frontends/rtl2832_priv.h
+++ b/drivers/media/dvb-frontends/rtl2832_priv.h
@@ -35,6 +35,8 @@ struct rtl2832_dev {
35 struct dvb_frontend fe; 35 struct dvb_frontend fe;
36 struct delayed_work stat_work; 36 struct delayed_work stat_work;
37 fe_status_t fe_status; 37 fe_status_t fe_status;
38 u64 post_bit_error;
39 u64 post_bit_count;
38 bool i2c_gate_state; 40 bool i2c_gate_state;
39 bool sleeping; 41 bool sleeping;
40 struct delayed_work i2c_gate_work; 42 struct delayed_work i2c_gate_work;