diff options
Diffstat (limited to 'drivers/media/dvb')
-rw-r--r-- | drivers/media/dvb/frontends/nxt200x.c | 82 |
1 files changed, 44 insertions, 38 deletions
diff --git a/drivers/media/dvb/frontends/nxt200x.c b/drivers/media/dvb/frontends/nxt200x.c index 97ee8017dac8..aee170805caf 100644 --- a/drivers/media/dvb/frontends/nxt200x.c +++ b/drivers/media/dvb/frontends/nxt200x.c | |||
@@ -342,50 +342,56 @@ static int nxt200x_writetuner (struct nxt200x_state* state, u8* data) | |||
342 | 342 | ||
343 | dprintk("Tuner Bytes: %02X %02X %02X %02X\n", data[0], data[1], data[2], data[3]); | 343 | dprintk("Tuner Bytes: %02X %02X %02X %02X\n", data[0], data[1], data[2], data[3]); |
344 | 344 | ||
345 | /* if pll is a Philips TUV1236D then write directly to tuner */ | 345 | /* if NXT2004, write directly to tuner. if NXT2002, write through NXT chip. |
346 | if (strcmp(state->config->pll_desc->name, "Philips TUV1236D") == 0) { | 346 | * direct write is required for Philips TUV1236D and ALPS TDHU2 */ |
347 | if (i2c_writebytes(state, state->config->pll_address, data, 4)) | 347 | switch (state->demod_chip) { |
348 | printk(KERN_WARNING "nxt200x: error writing to tuner\n"); | 348 | case NXT2004: |
349 | /* wait until we have a lock */ | 349 | if (i2c_writebytes(state, state->config->pll_address, data, 4)) |
350 | while (count < 20) { | 350 | printk(KERN_WARNING "nxt200x: error writing to tuner\n"); |
351 | i2c_readbytes(state, state->config->pll_address, &buf, 1); | 351 | /* wait until we have a lock */ |
352 | if (buf & 0x40) | 352 | while (count < 20) { |
353 | return 0; | 353 | i2c_readbytes(state, state->config->pll_address, &buf, 1); |
354 | msleep(100); | 354 | if (buf & 0x40) |
355 | count++; | 355 | return 0; |
356 | } | 356 | msleep(100); |
357 | printk("nxt200x: timeout waiting for tuner lock\n"); | 357 | count++; |
358 | return 0; | 358 | } |
359 | } else { | 359 | printk("nxt2004: timeout waiting for tuner lock\n"); |
360 | /* set the i2c transfer speed to the tuner */ | 360 | break; |
361 | buf = 0x03; | 361 | case NXT2002: |
362 | nxt200x_writebytes(state, 0x20, &buf, 1); | 362 | /* set the i2c transfer speed to the tuner */ |
363 | buf = 0x03; | ||
364 | nxt200x_writebytes(state, 0x20, &buf, 1); | ||
363 | 365 | ||
364 | /* setup to transfer 4 bytes via i2c */ | 366 | /* setup to transfer 4 bytes via i2c */ |
365 | buf = 0x04; | 367 | buf = 0x04; |
366 | nxt200x_writebytes(state, 0x34, &buf, 1); | 368 | nxt200x_writebytes(state, 0x34, &buf, 1); |
367 | 369 | ||
368 | /* write actual tuner bytes */ | 370 | /* write actual tuner bytes */ |
369 | nxt200x_writebytes(state, 0x36, data, 4); | 371 | nxt200x_writebytes(state, 0x36, data, 4); |
370 | 372 | ||
371 | /* set tuner i2c address */ | 373 | /* set tuner i2c address */ |
372 | buf = state->config->pll_address; | 374 | buf = state->config->pll_address; |
373 | nxt200x_writebytes(state, 0x35, &buf, 1); | 375 | nxt200x_writebytes(state, 0x35, &buf, 1); |
374 | 376 | ||
375 | /* write UC Opmode to begin transfer */ | 377 | /* write UC Opmode to begin transfer */ |
376 | buf = 0x80; | 378 | buf = 0x80; |
377 | nxt200x_writebytes(state, 0x21, &buf, 1); | 379 | nxt200x_writebytes(state, 0x21, &buf, 1); |
378 | 380 | ||
379 | while (count < 20) { | 381 | while (count < 20) { |
380 | nxt200x_readbytes(state, 0x21, &buf, 1); | 382 | nxt200x_readbytes(state, 0x21, &buf, 1); |
381 | if ((buf & 0x80)== 0x00) | 383 | if ((buf & 0x80)== 0x00) |
382 | return 0; | 384 | return 0; |
383 | msleep(100); | 385 | msleep(100); |
384 | count++; | 386 | count++; |
385 | } | 387 | } |
386 | printk("nxt200x: timeout error writing tuner\n"); | 388 | printk("nxt2002: timeout error writing tuner\n"); |
387 | return 0; | 389 | break; |
390 | default: | ||
391 | return -EINVAL; | ||
392 | break; | ||
388 | } | 393 | } |
394 | return 0; | ||
389 | } | 395 | } |
390 | 396 | ||
391 | static void nxt200x_agc_reset(struct nxt200x_state* state) | 397 | static void nxt200x_agc_reset(struct nxt200x_state* state) |