[ALSA] oxygen: allow more sample rates with WM8785
[firefly-linux-kernel-4.4.55.git] / sound / pci / oxygen / oxygen.c
index 78aa969176264aca1be5d967332ab6bfac0cca2e..0a7c6135c0726708498cf966c0a934ec79f1b5fb 100644 (file)
@@ -232,18 +232,6 @@ static void generic_cleanup(struct oxygen *chip)
 {
 }
 
-static void generic_pcm_hardware_filter(unsigned int channel,
-                                       struct snd_pcm_hardware *hardware)
-{
-       if (channel == PCM_A) {
-               hardware->rates = SNDRV_PCM_RATE_44100 |
-                                 SNDRV_PCM_RATE_48000 |
-                                 SNDRV_PCM_RATE_96000 |
-                                 SNDRV_PCM_RATE_192000;
-               hardware->rate_min = 44100;
-       }
-}
-
 static void set_ak4396_params(struct oxygen *chip,
                              struct snd_pcm_hw_params *params)
 {
@@ -300,12 +288,12 @@ static void set_wm8785_params(struct oxygen *chip,
        wm8785_write(chip, WM8785_R7, 0);
 
        value = WM8785_MCR_SLAVE | WM8785_FORMAT_LJUST;
-       if (params_rate(params) == 96000)
+       if (params_rate(params) <= 48000)
+               value |= WM8785_OSR_SINGLE;
+       else if (params_rate(params) <= 96000)
                value |= WM8785_OSR_DOUBLE;
-       else if (params_rate(params) == 192000)
-               value |= WM8785_OSR_QUAD;
        else
-               value |= WM8785_OSR_SINGLE;
+               value |= WM8785_OSR_QUAD;
        wm8785_write(chip, WM8785_R0, value);
 
        if (snd_pcm_format_width(params_format(params)) <= 16)
@@ -349,7 +337,6 @@ static const struct oxygen_model model_generic = {
        .init = generic_init,
        .control_filter = ak4396_control_filter,
        .cleanup = generic_cleanup,
-       .pcm_hardware_filter = generic_pcm_hardware_filter,
        .set_dac_params = set_ak4396_params,
        .set_adc_params = set_wm8785_params,
        .update_dac_volume = update_ak4396_volume,