mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-02 16:36:41 +07:00
[media] em28xx: fix I2S audio sample rate definitions and info output
The audio configuration in chip config register 0x00 and eeprom are always consistent. But currently the audio configuration #defines for the chip config register say 0x20 means 3 sample rates and 0x30 5 sample rates, while the eeprom info output says 0x20 means 1 sample rate and 0x30 3 sample rates. I've checked the datasheet excerpts I have and it seems that the meaning of these bits is different for em2820/40 (1 and 3 sample rates) and em2860+ (3 and 5 smaple rates). I have also checked my Hauppauge WinTV USB 2 (em2840) and the chip/eeprom audio config 0x20 matches the sample rates reproted by the USB device descriptor (32k only). Signed-off-by: Frank Schäfer <fschaefer.oss@googlemail.com> Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
This commit is contained in:
parent
2a9ecc17ed
commit
687ff8b0c4
@ -517,17 +517,19 @@ int em28xx_audio_setup(struct em28xx *dev)
|
||||
dev->has_alsa_audio = false;
|
||||
dev->audio_mode.has_audio = false;
|
||||
return 0;
|
||||
} else if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) ==
|
||||
EM28XX_CHIPCFG_I2S_3_SAMPRATES) {
|
||||
em28xx_info("I2S Audio (3 sample rates)\n");
|
||||
dev->audio_mode.i2s_3rates = 1;
|
||||
} else if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) ==
|
||||
EM28XX_CHIPCFG_I2S_5_SAMPRATES) {
|
||||
em28xx_info("I2S Audio (5 sample rates)\n");
|
||||
dev->audio_mode.i2s_5rates = 1;
|
||||
}
|
||||
|
||||
if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) != EM28XX_CHIPCFG_AC97) {
|
||||
} else if ((cfg & EM28XX_CHIPCFG_AUDIOMASK) != EM28XX_CHIPCFG_AC97) {
|
||||
if (dev->chip_id < CHIP_ID_EM2860 &&
|
||||
(cfg & EM28XX_CHIPCFG_AUDIOMASK) ==
|
||||
EM2820_CHIPCFG_I2S_1_SAMPRATE)
|
||||
dev->audio_mode.i2s_samplerates = 1;
|
||||
else if (dev->chip_id >= CHIP_ID_EM2860 &&
|
||||
(cfg & EM28XX_CHIPCFG_AUDIOMASK) ==
|
||||
EM2860_CHIPCFG_I2S_5_SAMPRATES)
|
||||
dev->audio_mode.i2s_samplerates = 5;
|
||||
else
|
||||
dev->audio_mode.i2s_samplerates = 3;
|
||||
em28xx_info("I2S Audio (%d sample rate(s))\n",
|
||||
dev->audio_mode.i2s_samplerates);
|
||||
/* Skip the code that does AC97 vendor detection */
|
||||
dev->audio_mode.ac97 = EM28XX_NO_AC97;
|
||||
goto init_audio;
|
||||
|
@ -736,10 +736,16 @@ static int em28xx_i2c_eeprom(struct em28xx *dev, unsigned bus,
|
||||
em28xx_info("\tAC97 audio (5 sample rates)\n");
|
||||
break;
|
||||
case 2:
|
||||
if (dev->chip_id < CHIP_ID_EM2860)
|
||||
em28xx_info("\tI2S audio, sample rate=32k\n");
|
||||
else
|
||||
em28xx_info("\tI2S audio, 3 sample rates\n");
|
||||
break;
|
||||
case 3:
|
||||
if (dev->chip_id < CHIP_ID_EM2860)
|
||||
em28xx_info("\tI2S audio, 3 sample rates\n");
|
||||
else
|
||||
em28xx_info("\tI2S audio, 5 sample rates\n");
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -25,10 +25,12 @@
|
||||
#define EM28XX_R00_CHIPCFG 0x00
|
||||
|
||||
/* em28xx Chip Configuration 0x00 */
|
||||
#define EM28XX_CHIPCFG_VENDOR_AUDIO 0x80
|
||||
#define EM28XX_CHIPCFG_I2S_VOLUME_CAPABLE 0x40
|
||||
#define EM28XX_CHIPCFG_I2S_5_SAMPRATES 0x30
|
||||
#define EM28XX_CHIPCFG_I2S_3_SAMPRATES 0x20
|
||||
#define EM2860_CHIPCFG_VENDOR_AUDIO 0x80
|
||||
#define EM2860_CHIPCFG_I2S_VOLUME_CAPABLE 0x40
|
||||
#define EM2820_CHIPCFG_I2S_3_SAMPRATES 0x30
|
||||
#define EM2860_CHIPCFG_I2S_5_SAMPRATES 0x30
|
||||
#define EM2820_CHIPCFG_I2S_1_SAMPRATE 0x20
|
||||
#define EM2860_CHIPCFG_I2S_3_SAMPRATES 0x20
|
||||
#define EM28XX_CHIPCFG_AC97 0x10
|
||||
#define EM28XX_CHIPCFG_AUDIOMASK 0x30
|
||||
|
||||
|
@ -295,8 +295,7 @@ struct em28xx_audio_mode {
|
||||
|
||||
unsigned int has_audio:1;
|
||||
|
||||
unsigned int i2s_3rates:1;
|
||||
unsigned int i2s_5rates:1;
|
||||
u8 i2s_samplerates;
|
||||
};
|
||||
|
||||
/* em28xx has two audio inputs: tuner and line in.
|
||||
|
Loading…
Reference in New Issue
Block a user