mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-17 17:24:17 +08:00
[media] stb0899: sign extend raw CRL_FREQ value
Contrary to the chip's specs, the register's value is signed, so we need to sign extend the value before using it in calculations like when determining the offset frequency. Signed-off-by: Reinhard Nißl <rnissl@gmx.de> Signed-off-by: Michael Krufky <mkrufky@linuxtv.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
parent
703e60655c
commit
ccac68f981
@ -1487,6 +1487,10 @@ enum stb0899_status stb0899_dvbs2_algo(struct stb0899_state *state)
|
||||
/* Store signal parameters */
|
||||
offsetfreq = STB0899_READ_S2REG(STB0899_S2DEMOD, CRL_FREQ);
|
||||
|
||||
/* sign extend 30 bit value before using it in calculations */
|
||||
if (offsetfreq & (1 << 29))
|
||||
offsetfreq |= -1 << 30;
|
||||
|
||||
offsetfreq = offsetfreq / ((1 << 30) / 1000);
|
||||
offsetfreq *= (internal->master_clk / 1000000);
|
||||
reg = STB0899_READ_S2REG(STB0899_S2DEMOD, DMD_CNTRL2);
|
||||
|
Loading…
Reference in New Issue
Block a user