[media] e4000: fix 32-bit build error
authorAntti Palosaari <crope@iki.fi>
Fri, 14 Mar 2014 18:22:24 +0000 (15:22 -0300)
committerMauro Carvalho Chehab <m.chehab@samsung.com>
Fri, 14 Mar 2014 23:23:11 +0000 (20:23 -0300)
All error/warnings:
   drivers/built-in.o: In function `e4000_set_params':
>> e4000.c:(.text+0x1219a1b): undefined reference to `__umoddi3'

Reported-by: kbuild test robot <fengguang.wu@intel.com>
Signed-off-by: Antti Palosaari <crope@iki.fi>
Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
drivers/media/tuners/e4000.c

index 3b5255062a0d721ab0fcd23165d644304a253a16..67ecf1bbfa1f8c451ba1321905eb13485c070bec 100644 (file)
@@ -116,6 +116,7 @@ static int e4000_set_params(struct dvb_frontend *fe)
        struct e4000 *s = fe->tuner_priv;
        struct dtv_frontend_properties *c = &fe->dtv_property_cache;
        int ret, i, sigma_delta;
+       unsigned int pll_n, pll_f;
        u64 f_vco;
        u8 buf[5], i_data[4], q_data[4];
 
@@ -141,8 +142,9 @@ static int e4000_set_params(struct dvb_frontend *fe)
        }
 
        f_vco = 1ull * c->frequency * e4000_pll_lut[i].mul;
-       sigma_delta = div_u64(0x10000ULL * (f_vco % s->clock), s->clock);
-       buf[0] = div_u64(f_vco, s->clock);
+       pll_n = div_u64_rem(f_vco, s->clock, &pll_f);
+       sigma_delta = div_u64(0x10000ULL * pll_f, s->clock);
+       buf[0] = pll_n;
        buf[1] = (sigma_delta >> 0) & 0xff;
        buf[2] = (sigma_delta >> 8) & 0xff;
        buf[3] = 0x00;