SNET_CTRL_OP_DESTROY = 1,
        SNET_CTRL_OP_READ_VQ_STATE,
        SNET_CTRL_OP_SUSPEND,
+       SNET_CTRL_OP_RESUME,
 };
 
 #define SNET_CTRL_TIMEOUT              2000000
 {
        return snet_send_ctrl_msg(snet, SNET_CTRL_OP_SUSPEND, 0);
 }
+
+int snet_resume_dev(struct snet *snet)
+{
+       return snet_send_ctrl_msg(snet, SNET_CTRL_OP_RESUME, 0);
+}
 
        return ret;
 }
 
+static int snet_resume(struct vdpa_device *vdev)
+{
+       struct snet *snet = vdpa_to_snet(vdev);
+       int ret;
+
+       ret = snet_resume_dev(snet);
+       if (ret)
+               SNET_ERR(snet->pdev, "SNET[%u] resume failed, err: %d\n", snet->sid, ret);
+       else
+               SNET_DBG(snet->pdev, "Resume SNET[%u] device\n", snet->sid);
+
+       return ret;
+}
+
 static const struct vdpa_config_ops snet_config_ops = {
        .set_vq_address         = snet_set_vq_address,
        .set_vq_num             = snet_set_vq_num,
        .get_config             = snet_get_config,
        .set_config             = snet_set_config,
        .suspend                = snet_suspend,
+       .resume                 = snet_resume,
 };
 
 static int psnet_open_pf_bar(struct pci_dev *pdev, struct psnet *psnet)
 
 int snet_destroy_dev(struct snet *snet);
 int snet_read_vq_state(struct snet *snet, u16 idx, struct vdpa_vq_state *state);
 int snet_suspend_dev(struct snet *snet);
+int snet_resume_dev(struct snet *snet);
 
 #endif //_SNET_VDPA_H_