Commit 8aed3f47 authored by Devin Heitmueller's avatar Devin Heitmueller Committed by Mauro Carvalho Chehab

[media] cx231xx: Make the DIF configuration based on the tuner not the board id

The current code was deciding whether a DIF was present based on the board
profile.  However, this is just another thing for someone to get wrong when
adding new boards.  Make the decision based on the tuner instead, so that a
developer adding new boards only needs to specify which tuner the device has.

Of course, the first time somebody adds a board with a tuner other than xc5000
or tda18271, he/she will need to add another line for that tuner.  But we
provide a friendly message in dmesg to let them know that.
Signed-off-by: default avatarDevin Heitmueller <dheitmueller@hauppauge.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent b522591a
...@@ -1175,21 +1175,17 @@ int cx231xx_set_audio_decoder_input(struct cx231xx *dev, ...@@ -1175,21 +1175,17 @@ int cx231xx_set_audio_decoder_input(struct cx231xx *dev,
status = restartAudioFirmware(dev); status = restartAudioFirmware(dev);
switch (dev->model) { switch (dev->board.tuner_type) {
case CX231XX_BOARD_CNXT_CARRAERA: case TUNER_XC5000:
case CX231XX_BOARD_CNXT_RDE_250: /* SIF passthrough at 28.6363 MHz sample rate */
case CX231XX_BOARD_CNXT_SHELBY:
case CX231XX_BOARD_CNXT_RDU_250:
case CX231XX_BOARD_CNXT_VIDEO_GRABBER:
status = cx231xx_read_modify_write_i2c_dword(dev, status = cx231xx_read_modify_write_i2c_dword(dev,
VID_BLK_I2C_ADDRESS, VID_BLK_I2C_ADDRESS,
CHIP_CTRL, CHIP_CTRL,
FLD_SIF_EN, FLD_SIF_EN,
cx231xx_set_field(FLD_SIF_EN, 1)); cx231xx_set_field(FLD_SIF_EN, 1));
break; break;
case CX231XX_BOARD_CNXT_RDE_253S: case TUNER_NXP_TDA18271:
case CX231XX_BOARD_CNXT_RDU_253S: /* Normal mode: SIF passthrough at 14.32 MHz */
case CX231XX_BOARD_HAUPPAUGE_EXETER:
status = cx231xx_read_modify_write_i2c_dword(dev, status = cx231xx_read_modify_write_i2c_dword(dev,
VID_BLK_I2C_ADDRESS, VID_BLK_I2C_ADDRESS,
CHIP_CTRL, CHIP_CTRL,
...@@ -1197,6 +1193,10 @@ int cx231xx_set_audio_decoder_input(struct cx231xx *dev, ...@@ -1197,6 +1193,10 @@ int cx231xx_set_audio_decoder_input(struct cx231xx *dev,
cx231xx_set_field(FLD_SIF_EN, 0)); cx231xx_set_field(FLD_SIF_EN, 0));
break; break;
default: default:
/* This is just a casual suggestion to people adding
new boards in case they use a tuner type we don't
currently know about */
printk(KERN_INFO "Unknown tuner type configuring SIF");
break; break;
} }
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment