}
 EXPORT_SYMBOL(sof_ipc_tx_message_no_pm);
 
+/* Generic helper function to retrieve the reply */
+void snd_sof_ipc_get_reply(struct snd_sof_dev *sdev)
+{
+       struct snd_sof_ipc_msg *msg = sdev->msg;
+       struct sof_ipc_reply reply;
+       int ret = 0;
+
+       /*
+        * Sometimes, there is unexpected reply ipc arriving. The reply
+        * ipc belongs to none of the ipcs sent from driver.
+        * In this case, the driver must ignore the ipc.
+        */
+       if (!msg) {
+               dev_warn(sdev->dev, "unexpected ipc interrupt raised!\n");
+               return;
+       }
+
+       /* get the generic reply */
+       snd_sof_dsp_mailbox_read(sdev, sdev->host_box.offset, &reply,
+                                sizeof(reply));
+
+       if (reply.error < 0) {
+               memcpy(msg->reply_data, &reply, sizeof(reply));
+               ret = reply.error;
+       } else if (!reply.hdr.size) {
+               /* Reply should always be >= sizeof(struct sof_ipc_reply) */
+               if (msg->reply_size)
+                       dev_err(sdev->dev,
+                               "empty reply received, expected %zu bytes\n",
+                               msg->reply_size);
+               else
+                       dev_err(sdev->dev, "empty reply received\n");
+
+               ret = -EINVAL;
+       } else if (msg->reply_size > 0) {
+               if (reply.hdr.size == msg->reply_size) {
+                       ret = 0;
+               } else if (reply.hdr.size < msg->reply_size) {
+                       dev_dbg(sdev->dev,
+                               "reply size (%u) is less than expected (%zu)\n",
+                               reply.hdr.size, msg->reply_size);
+
+                       msg->reply_size = reply.hdr.size;
+                       ret = 0;
+               } else {
+                       dev_err(sdev->dev,
+                               "reply size (%u) exceeds the buffer size (%zu)\n",
+                               reply.hdr.size, msg->reply_size);
+                       ret = -EINVAL;
+               }
+
+               /* get the full message if reply.hdr.size <= msg->reply_size */
+               if (!ret)
+                       snd_sof_dsp_mailbox_read(sdev, sdev->host_box.offset,
+                                                msg->reply_data, msg->reply_size);
+       }
+
+       msg->reply_error = ret;
+}
+EXPORT_SYMBOL(snd_sof_ipc_get_reply);
+
 /* handle reply message from DSP */
 void snd_sof_ipc_reply(struct snd_sof_dev *sdev, u32 msg_id)
 {
 
  */
 struct snd_sof_ipc *snd_sof_ipc_init(struct snd_sof_dev *sdev);
 void snd_sof_ipc_free(struct snd_sof_dev *sdev);
+void snd_sof_ipc_get_reply(struct snd_sof_dev *sdev);
 void snd_sof_ipc_reply(struct snd_sof_dev *sdev, u32 msg_id);
 void snd_sof_ipc_msgs_rx(struct snd_sof_dev *sdev);
 int snd_sof_ipc_stream_pcm_params(struct snd_sof_dev *sdev,
                             void *msg_data, size_t msg_bytes,
                             void *reply_data, size_t reply_bytes);
 int sof_ipc_init_msg_memory(struct snd_sof_dev *sdev);
+static inline void snd_sof_ipc_process_reply(struct snd_sof_dev *sdev, u32 msg_id)
+{
+       snd_sof_ipc_get_reply(sdev);
+       snd_sof_ipc_reply(sdev, msg_id);
+}
 
 /*
  * Trace/debug