diff options
author | Antti Palosaari <crope@iki.fi> | 2014-12-14 07:59:20 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@osg.samsung.com> | 2015-02-03 13:06:30 -0500 |
commit | 6b4fd01804ced75fb1385df5f6b9cf830cbe15d9 (patch) | |
tree | 3a3e29e870a1a10d3146f1e31910b02606a5a036 /drivers/media/dvb-frontends | |
parent | 19d273d63552ac99d171fd68018a41f496248513 (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.c | 25 | ||||
-rw-r--r-- | drivers/media/dvb-frontends/rtl2832_priv.h | 2 |
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 | |||
907 | err_schedule_delayed_work: | 932 | err_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; |