snd_hdac_ext_stream_release(hext_stream, HDAC_EXT_STREAM_TYPE_LINK);
 }
 
+static void hda_setup_hext_stream(struct snd_sof_dev *sdev, struct hdac_ext_stream *hext_stream,
+                                 unsigned int format_val)
+{
+       snd_hdac_ext_stream_setup(hext_stream, format_val);
+}
+
+static void hda_reset_hext_stream(struct snd_sof_dev *sdev, struct hdac_ext_stream *hext_stream)
+{
+       snd_hdac_ext_stream_reset(hext_stream);
+}
+
 static const struct hda_dai_widget_dma_ops hda_dma_ops = {
        .get_hext_stream = hda_get_hext_stream,
        .assign_hext_stream = hda_assign_hext_stream,
        .release_hext_stream = hda_release_hext_stream,
+       .setup_hext_stream = hda_setup_hext_stream,
+       .reset_hext_stream = hda_reset_hext_stream,
 };
 
 #endif
 
        else
                link_bps = codec_dai->driver->capture.sig_bits;
 
-       snd_hdac_ext_stream_reset(hext_stream);
+       if (ops->reset_hext_stream)
+               ops->reset_hext_stream(sdev, hext_stream);
 
        format_val = snd_hdac_calc_stream_format(params_rate(params), params_channels(params),
                                                 params_format(params), link_bps, 0);
        dev_dbg(bus->dev, "format_val=%d, rate=%d, ch=%d, format=%d\n",
                format_val, params_rate(params), params_channels(params), params_format(params));
 
-       snd_hdac_ext_stream_setup(hext_stream, format_val);
+       if (ops->setup_hext_stream)
+               ops->setup_hext_stream(sdev, hext_stream, format_val);
 
        hext_stream->link_prepared = 1;