From a17f839b653d8feac5234ba03cc40b7218c4abbc Mon Sep 17 00:00:00 2001 From: Mauro Carvalho Chehab Date: Fri, 22 Mar 2013 06:22:45 -0300 Subject: [PATCH] --- yaml --- r: 366707 b: refs/heads/master c: f35d09db0e61009679e41cc5afa2d205b99c3816 h: refs/heads/master i: 366705: 7dd277e02bf1adf45dfed1188001bbe833b83298 366703: 6d8b53e3ca21adce1c5ed0aa502729e0ca5e8ac8 v: v3 --- [refs] | 2 +- trunk/drivers/media/common/siano/smsdvb-main.c | 9 ++++++--- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 8e3149041aad..957d85d927e9 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: d7104bffcfb7a1a7f1dbb1274443e339588c2cb3 +refs/heads/master: f35d09db0e61009679e41cc5afa2d205b99c3816 diff --git a/trunk/drivers/media/common/siano/smsdvb-main.c b/trunk/drivers/media/common/siano/smsdvb-main.c index d965a7ae5982..297f1b2f9a32 100644 --- a/trunk/drivers/media/common/siano/smsdvb-main.c +++ b/trunk/drivers/media/common/siano/smsdvb-main.c @@ -22,6 +22,7 @@ along with this program. If not, see . #include #include #include +#include #include "dmxdev.h" #include "dvbdev.h" @@ -244,6 +245,7 @@ static void smsdvb_update_per_slices(struct smsdvb_client_t *client, { struct dvb_frontend *fe = &client->frontend; struct dtv_frontend_properties *c = &fe->dtv_property_cache; + u64 tmp; client->fe_status = sms_to_status(p->is_demod_locked, p->is_rf_locked); c->modulation = sms_to_modulation(p->constellation); @@ -272,8 +274,9 @@ static void smsdvb_update_per_slices(struct smsdvb_client_t *client, c->post_bit_count.stat[0].uvalue += p->ber_bit_count; /* Legacy PER/BER */ - client->legacy_per = (p->ets_packets * 65535) / - (p->ts_packets + p->ets_packets); + tmp = p->ets_packets * 65535; + do_div(tmp, p->ts_packets + p->ets_packets); + client->legacy_per = tmp; } static void smsdvb_update_dvb_stats(struct smsdvb_client_t *client, @@ -803,7 +806,7 @@ static int smsdvb_read_snr(struct dvb_frontend *fe, u16 *snr) rc = smsdvb_send_statistics_request(client); /* Preferred scale for SNR with legacy API: 0.1 dB */ - *snr = c->cnr.stat[0].svalue / 100; + *snr = ((u32)c->cnr.stat[0].svalue) / 100; led_feedback(client);