{
        struct cs42l42_private *cs42l42 = snd_soc_component_get_drvdata(component);
        int i;
-       u32 fsync;
 
        /* Don't reconfigure if there is an audio stream running */
        if (cs42l42->stream_use) {
                                        (pll_ratio_table[i].mclk_int !=
                                        24000000)) <<
                                        CS42L42_INTERNAL_FS_SHIFT);
-
-                       /* Set up the LRCLK */
-                       fsync = clk / cs42l42->srate;
-                       if (((fsync * cs42l42->srate) != clk)
-                               || ((fsync % 2) != 0)) {
-                               dev_err(component->dev,
-                                       "Unsupported sclk %d/sample rate %d\n",
-                                       clk,
-                                       cs42l42->srate);
-                               return -EINVAL;
-                       }
-                       /* Set the LRCLK period */
-                       snd_soc_component_update_bits(component,
-                                       CS42L42_FSYNC_P_LOWER,
-                                       CS42L42_FSYNC_PERIOD_MASK,
-                                       CS42L42_FRAC0_VAL(fsync - 1) <<
-                                       CS42L42_FSYNC_PERIOD_SHIFT);
-                       snd_soc_component_update_bits(component,
-                                       CS42L42_FSYNC_P_UPPER,
-                                       CS42L42_FSYNC_PERIOD_MASK,
-                                       CS42L42_FRAC1_VAL(fsync - 1) <<
-                                       CS42L42_FSYNC_PERIOD_SHIFT);
-                       /* Set the LRCLK to 50% duty cycle */
-                       fsync = fsync / 2;
-                       snd_soc_component_update_bits(component,
-                                       CS42L42_FSYNC_PW_LOWER,
-                                       CS42L42_FSYNC_PULSE_WIDTH_MASK,
-                                       CS42L42_FRAC0_VAL(fsync - 1) <<
-                                       CS42L42_FSYNC_PULSE_WIDTH_SHIFT);
-                       snd_soc_component_update_bits(component,
-                                       CS42L42_FSYNC_PW_UPPER,
-                                       CS42L42_FSYNC_PULSE_WIDTH_MASK,
-                                       CS42L42_FRAC1_VAL(fsync - 1) <<
-                                       CS42L42_FSYNC_PULSE_WIDTH_SHIFT);
                        if (pll_ratio_table[i].mclk_src_sel == 0) {
                                /* Pass the clock straight through */
                                snd_soc_component_update_bits(component,
                                      fs << CS42L42_CLK_OASRC_SEL_SHIFT);
 }
 
+static int cs42l42_asp_config(struct snd_soc_component *component,
+                             unsigned int sclk, unsigned int sample_rate)
+{
+       u32 fsync = sclk / sample_rate;
+
+       /* Set up the LRCLK */
+       if (((fsync * sample_rate) != sclk) || ((fsync % 2) != 0)) {
+               dev_err(component->dev,
+                       "Unsupported sclk %d/sample rate %d\n",
+                       sclk,
+                       sample_rate);
+               return -EINVAL;
+       }
+       /* Set the LRCLK period */
+       snd_soc_component_update_bits(component,
+                                     CS42L42_FSYNC_P_LOWER,
+                                     CS42L42_FSYNC_PERIOD_MASK,
+                                     CS42L42_FRAC0_VAL(fsync - 1) <<
+                                     CS42L42_FSYNC_PERIOD_SHIFT);
+       snd_soc_component_update_bits(component,
+                                     CS42L42_FSYNC_P_UPPER,
+                                     CS42L42_FSYNC_PERIOD_MASK,
+                                     CS42L42_FRAC1_VAL(fsync - 1) <<
+                                     CS42L42_FSYNC_PERIOD_SHIFT);
+       /* Set the LRCLK to 50% duty cycle */
+       fsync = fsync / 2;
+       snd_soc_component_update_bits(component,
+                                     CS42L42_FSYNC_PW_LOWER,
+                                     CS42L42_FSYNC_PULSE_WIDTH_MASK,
+                                     CS42L42_FRAC0_VAL(fsync - 1) <<
+                                     CS42L42_FSYNC_PULSE_WIDTH_SHIFT);
+       snd_soc_component_update_bits(component,
+                                     CS42L42_FSYNC_PW_UPPER,
+                                     CS42L42_FSYNC_PULSE_WIDTH_MASK,
+                                     CS42L42_FRAC1_VAL(fsync - 1) <<
+                                     CS42L42_FSYNC_PULSE_WIDTH_SHIFT);
+
+       return 0;
+}
+
 static int cs42l42_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
 {
        struct snd_soc_component *component = codec_dai->component;
        unsigned int bclk;
        int ret;
 
-       cs42l42->srate = params_rate(params);
-
        if (cs42l42->bclk_ratio) {
                /* machine driver has set the BCLK/samp-rate ratio */
                bclk = cs42l42->bclk_ratio * params_rate(params);
        if (ret)
                return ret;
 
+       ret = cs42l42_asp_config(component, bclk, sample_rate);
+       if (ret)
+               return ret;
+
        cs42l42_src_config(component, sample_rate);
 
        return 0;