struct dfl_feature_platform_data *pdata = dev_get_platdata(dev);
        struct platform_device *pdev = to_platform_device(dev);
        void __iomem *base_err, *base_hdr;
-       int ret = -EBUSY;
+       int enable_ret = 0, ret = -EBUSY;
        u64 v;
 
        base_err = dfl_get_feature_ioaddr_by_id(dev, PORT_FEATURE_ID_ERROR);
                v = readq(base_err + PORT_FIRST_ERROR);
                writeq(v, base_err + PORT_FIRST_ERROR);
        } else {
+               dev_warn(dev, "%s: received 0x%llx, expected 0x%llx\n",
+                        __func__, v, err);
                ret = -EINVAL;
        }
 
        /* Clear mask */
        __afu_port_err_mask(dev, false);
 
-       /* Enable the Port by clear the reset */
-       __afu_port_enable(pdev);
+       /* Enable the Port by clearing the reset */
+       enable_ret = __afu_port_enable(pdev);
 
 done:
        mutex_unlock(&pdata->lock);
-       return ret;
+       return enable_ret ? enable_ret : ret;
 }
 
 static ssize_t errors_show(struct device *dev, struct device_attribute *attr,
 
 
 #include "dfl-afu.h"
 
+#define RST_POLL_INVL 10 /* us */
+#define RST_POLL_TIMEOUT 1000 /* us */
+
 /**
  * __afu_port_enable - enable a port by clear reset
  * @pdev: port platform device.
  *
  * The caller needs to hold lock for protection.
  */
-void __afu_port_enable(struct platform_device *pdev)
+int __afu_port_enable(struct platform_device *pdev)
 {
        struct dfl_feature_platform_data *pdata = dev_get_platdata(&pdev->dev);
        void __iomem *base;
        WARN_ON(!pdata->disable_count);
 
        if (--pdata->disable_count != 0)
-               return;
+               return 0;
 
        base = dfl_get_feature_ioaddr_by_id(&pdev->dev, PORT_FEATURE_ID_HEADER);
 
        v = readq(base + PORT_HDR_CTRL);
        v &= ~PORT_CTRL_SFTRST;
        writeq(v, base + PORT_HDR_CTRL);
-}
 
-#define RST_POLL_INVL 10 /* us */
-#define RST_POLL_TIMEOUT 1000 /* us */
+       /*
+        * HW clears the ack bit to indicate that the port is fully out
+        * of reset.
+        */
+       if (readq_poll_timeout(base + PORT_HDR_CTRL, v,
+                              !(v & PORT_CTRL_SFTRST_ACK),
+                              RST_POLL_INVL, RST_POLL_TIMEOUT)) {
+               dev_err(&pdev->dev, "timeout, failure to enable device\n");
+               return -ETIMEDOUT;
+       }
+
+       return 0;
+}
 
 /**
  * __afu_port_disable - disable a port by hold reset
        if (readq_poll_timeout(base + PORT_HDR_CTRL, v,
                               v & PORT_CTRL_SFTRST_ACK,
                               RST_POLL_INVL, RST_POLL_TIMEOUT)) {
-               dev_err(&pdev->dev, "timeout, fail to reset device\n");
+               dev_err(&pdev->dev, "timeout, failure to disable device\n");
                return -ETIMEDOUT;
        }
 
        int ret;
 
        ret = __afu_port_disable(pdev);
-       if (!ret)
-               __afu_port_enable(pdev);
+       if (ret)
+               return ret;
 
-       return ret;
+       return __afu_port_enable(pdev);
 }
 
 static int port_reset(struct platform_device *pdev)
 static int port_enable_set(struct platform_device *pdev, bool enable)
 {
        struct dfl_feature_platform_data *pdata = dev_get_platdata(&pdev->dev);
-       int ret = 0;
+       int ret;
 
        mutex_lock(&pdata->lock);
        if (enable)
-               __afu_port_enable(pdev);
+               ret = __afu_port_enable(pdev);
        else
                ret = __afu_port_disable(pdev);
        mutex_unlock(&pdata->lock);