mach_params->platform = dev_name(dev);
 }
 
+static void byt_reset_dsp_disable_int(struct snd_sof_dev *sdev)
+{
+       /* Disable Interrupt from both sides */
+       snd_sof_dsp_update_bits64(sdev, BYT_DSP_BAR, SHIM_IMRX, 0x3, 0x3);
+       snd_sof_dsp_update_bits64(sdev, BYT_DSP_BAR, SHIM_IMRD, 0x3, 0x3);
+
+       /* Put DSP into reset, set reset vector */
+       snd_sof_dsp_update_bits64(sdev, BYT_DSP_BAR, SHIM_CSR,
+                                 SHIM_BYT_CSR_RST | SHIM_BYT_CSR_VECTOR_SEL,
+                                 SHIM_BYT_CSR_RST | SHIM_BYT_CSR_VECTOR_SEL);
+}
+
+static int byt_suspend(struct snd_sof_dev *sdev, u32 target_state)
+{
+       byt_reset_dsp_disable_int(sdev);
+
+       return 0;
+}
+
+static int byt_resume(struct snd_sof_dev *sdev)
+{
+       /* Enable Interrupt from both sides */
+       snd_sof_dsp_update_bits64(sdev, BYT_DSP_BAR, SHIM_IMRX, 0x3, 0x0);
+       snd_sof_dsp_update_bits64(sdev, BYT_DSP_BAR, SHIM_IMRD, 0x3, 0x0);
+
+       return 0;
+}
+
 /* Baytrail DAIs */
 static struct snd_soc_dai_driver byt_dai[] = {
 {
        /*Firmware loading */
        .load_firmware  = snd_sof_load_firmware_memcpy,
 
+       /* PM */
+       .suspend = byt_suspend,
+       .resume = byt_resume,
+
        /* DAI drivers */
        .drv = byt_dai,
        .num_drv = 3, /* we have only 3 SSPs on byt*/
        /*Firmware loading */
        .load_firmware  = snd_sof_load_firmware_memcpy,
 
+       /* PM */
+       .suspend = byt_suspend,
+       .resume = byt_resume,
+
        /* DAI drivers */
        .drv = byt_dai,
        /* all 6 SSPs may be available for cherrytrail */