V4L/DVB (11591): stv090x: code simplification
authorManu Abraham <abraham.manu@gmail.com>
Wed, 8 Apr 2009 23:30:29 +0000 (20:30 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Tue, 16 Jun 2009 21:20:40 +0000 (18:20 -0300)
Signed-off-by: Manu Abraham <manu@linuxtv.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/dvb/frontends/stv090x.c

index b3a02790c9a210f239af83b8939dad7ebfa8322a..3e0acd7cc822170d299689b0250f625ed80929ff 100644 (file)
@@ -2222,23 +2222,22 @@ static enum stv090x_delsys stv090x_get_std(struct stv090x_state *state)
 static s32 stv090x_get_car_freq(struct stv090x_state *state, u32 mclk)
 {
        s32 derot, int_1, int_2, tmp_1, tmp_2;
-       u32 pow2;
 
        derot  = STV090x_READ_DEMOD(state, CFR2) << 16;
        derot |= STV090x_READ_DEMOD(state, CFR1) <<  8;
        derot |= STV090x_READ_DEMOD(state, CFR0);
 
        derot = comp2(derot, 24);
-       pow2 = 1 << 12;
-       int_1 = state->mclk / pow2;
-       int_2 = derot / pow2;
+       int_1 = state->mclk >> 12;
+       int_2 = derot >> 12;
 
-       tmp_1 = state->mclk % pow2;
-       tmp_2 = derot % pow2;
+       /* carrier_frequency = MasterClock * Reg / 2^24 */
+       tmp_1 = state->mclk % 0x1000;
+       tmp_2 = derot % 0x1000;
 
        derot = (int_1 * int_2) +
-               ((int_1 * tmp_2) / pow2) +
-               ((int_1 * tmp_1) / pow2);
+               ((int_1 * tmp_2) >> 12) +
+               ((int_1 * tmp_1) >> 12);
 
        return derot;
 }