aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorReinhard Nissl <rnissl@gmx.de>2008-07-09 14:38:27 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2008-12-29 14:53:24 -0500
commit9bb17eee39d862611d2f34d5c611661b3dfd2e54 (patch)
treefb69de0d1a60f5769a76fa7a6d9e715db81d1a7f
parentc615a27a533b6f6de6143d4d58cfa0abfdb6970d (diff)
V4L/DVB (9468): Miscellaneous fixes
- Fix a bitfield - Set gain appropriately - Slept for the wrong duration Signed-off-by: Reinhard Nissl <rnissl@gmx.de> Signed-off-by: Manu Abraham <manu@linuxtv.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--drivers/media/dvb/frontends/stb0899_reg.h2
-rw-r--r--drivers/media/dvb/frontends/stb6100.c10
2 files changed, 6 insertions, 6 deletions
diff --git a/drivers/media/dvb/frontends/stb0899_reg.h b/drivers/media/dvb/frontends/stb0899_reg.h
index 4e5b2415847f..ba1ed56304a0 100644
--- a/drivers/media/dvb/frontends/stb0899_reg.h
+++ b/drivers/media/dvb/frontends/stb0899_reg.h
@@ -362,7 +362,7 @@
362 362
363#define STB0899_OFF0_CRL_FREQ 0xf304 363#define STB0899_OFF0_CRL_FREQ 0xf304
364#define STB0899_BASE_CRL_FREQ 0x00000000 364#define STB0899_BASE_CRL_FREQ 0x00000000
365#define STB0899_CARR_FREQ (0x1fffffff << 0) 365#define STB0899_CARR_FREQ (0x3fffffff << 0)
366#define STB0899_OFFST_CARR_FREQ 0 366#define STB0899_OFFST_CARR_FREQ 0
367#define STB0899_WIDTH_CARR_FREQ 30 367#define STB0899_WIDTH_CARR_FREQ 30
368 368
diff --git a/drivers/media/dvb/frontends/stb6100.c b/drivers/media/dvb/frontends/stb6100.c
index f404a4d0fb17..083d6b627189 100644
--- a/drivers/media/dvb/frontends/stb6100.c
+++ b/drivers/media/dvb/frontends/stb6100.c
@@ -338,11 +338,11 @@ static int stb6100_set_frequency(struct dvb_frontend *fe, u32 frequency)
338 338
339 /* Baseband gain. */ 339 /* Baseband gain. */
340 if (srate >= 15000000) 340 if (srate >= 15000000)
341 g = 8; 341 g = 9; // +4 dB
342 else if (state->srate >= 5000000) 342 else if (srate >= 5000000)
343 g = 12; 343 g = 11; // +8 dB
344 else 344 else
345 g = 14; 345 g = 14; // +14 dB
346 346
347 regs[STB6100_G] = (regs[STB6100_G] & ~STB6100_G_G) | g; 347 regs[STB6100_G] = (regs[STB6100_G] & ~STB6100_G_G) | g;
348 regs[STB6100_G] &= ~STB6100_G_GCT; /* mask GCT */ 348 regs[STB6100_G] &= ~STB6100_G_GCT; /* mask GCT */
@@ -403,7 +403,7 @@ static int stb6100_set_frequency(struct dvb_frontend *fe, u32 frequency)
403 if ((rc = stb6100_write_reg(state, STB6100_VCO, regs[STB6100_VCO])) < 0) 403 if ((rc = stb6100_write_reg(state, STB6100_VCO, regs[STB6100_VCO])) < 0)
404 return rc; 404 return rc;
405 405
406 msleep(5); /* wait for LO to lock */ 406 msleep(10); /* wait for LO to lock */
407 regs[STB6100_VCO] &= ~STB6100_VCO_OSCH; /* vco search disabled */ 407 regs[STB6100_VCO] &= ~STB6100_VCO_OSCH; /* vco search disabled */
408 regs[STB6100_VCO] |= STB6100_VCO_OCK; /* search clock off */ 408 regs[STB6100_VCO] |= STB6100_VCO_OCK; /* search clock off */
409 if ((rc = stb6100_write_reg(state, STB6100_VCO, regs[STB6100_VCO])) < 0) 409 if ((rc = stb6100_write_reg(state, STB6100_VCO, regs[STB6100_VCO])) < 0)