return desc;
 }
 
-static void fbnic_mbx_init_desc_ring(struct fbnic_dev *fbd, int mbx_idx)
+static void fbnic_mbx_reset_desc_ring(struct fbnic_dev *fbd, int mbx_idx)
 {
        int desc_idx;
 
+       /* Disable DMA transactions from the device,
+        * and flush any transactions triggered during cleaning
+        */
+       switch (mbx_idx) {
+       case FBNIC_IPC_MBX_RX_IDX:
+               wr32(fbd, FBNIC_PUL_OB_TLP_HDR_AW_CFG,
+                    FBNIC_PUL_OB_TLP_HDR_AW_CFG_FLUSH);
+               break;
+       case FBNIC_IPC_MBX_TX_IDX:
+               wr32(fbd, FBNIC_PUL_OB_TLP_HDR_AR_CFG,
+                    FBNIC_PUL_OB_TLP_HDR_AR_CFG_FLUSH);
+               break;
+       }
+
+       wrfl(fbd);
+
        /* Initialize first descriptor to all 0s. Doing this gives us a
         * solid stop for the firmware to hit when it is done looping
         * through the ring.
        wr32(fbd, FBNIC_INTR_CLEAR(0), 1u << FBNIC_FW_MSIX_ENTRY);
 
        for (i = 0; i < FBNIC_IPC_MBX_INDICES; i++)
-               fbnic_mbx_init_desc_ring(fbd, i);
+               fbnic_mbx_reset_desc_ring(fbd, i);
 }
 
 static int fbnic_mbx_map_msg(struct fbnic_dev *fbd, int mbx_idx,
 {
        int i;
 
-       fbnic_mbx_init_desc_ring(fbd, mbx_idx);
+       fbnic_mbx_reset_desc_ring(fbd, mbx_idx);
 
        for (i = FBNIC_IPC_MBX_DESC_LEN; i--;)
                fbnic_mbx_unmap_and_free_msg(fbd, mbx_idx, i);
        return (err == -EOPNOTSUPP) ? 0 : err;
 }
 
-static void fbnic_mbx_postinit_desc_ring(struct fbnic_dev *fbd, int mbx_idx)
+static void fbnic_mbx_init_desc_ring(struct fbnic_dev *fbd, int mbx_idx)
 {
        struct fbnic_fw_mbx *mbx = &fbd->mbx[mbx_idx];
 
 
        switch (mbx_idx) {
        case FBNIC_IPC_MBX_RX_IDX:
+               /* Enable DMA writes from the device */
+               wr32(fbd, FBNIC_PUL_OB_TLP_HDR_AW_CFG,
+                    FBNIC_PUL_OB_TLP_HDR_AW_CFG_BME);
+
                /* Make sure we have a page for the FW to write to */
                fbnic_mbx_alloc_rx_msgs(fbd);
                break;
        case FBNIC_IPC_MBX_TX_IDX:
+               /* Enable DMA reads from the device */
+               wr32(fbd, FBNIC_PUL_OB_TLP_HDR_AR_CFG,
+                    FBNIC_PUL_OB_TLP_HDR_AR_CFG_BME);
+
                /* Force version to 1 if we successfully requested an update
                 * from the firmware. This should be overwritten once we get
                 * the actual version from the firmware in the capabilities
 {
        int i;
 
-       /* We only need to do this on the first interrupt following init.
+       /* We only need to do this on the first interrupt following reset.
         * this primes the mailbox so that we will have cleared all the
         * skip descriptors.
         */
        wr32(fbd, FBNIC_INTR_CLEAR(0), 1u << FBNIC_FW_MSIX_ENTRY);
 
        for (i = 0; i < FBNIC_IPC_MBX_INDICES; i++)
-               fbnic_mbx_postinit_desc_ring(fbd, i);
+               fbnic_mbx_init_desc_ring(fbd, i);
 }
 
 /**
                 * avoid the mailbox getting stuck closed if the interrupt
                 * is reset.
                 */
-               fbnic_mbx_init_desc_ring(fbd, FBNIC_IPC_MBX_TX_IDX);
+               fbnic_mbx_reset_desc_ring(fbd, FBNIC_IPC_MBX_TX_IDX);
 
                msleep(200);
 
 
        fbnic_init_readrq(fbd, FBNIC_QM_RNI_RBP_CTL, cls, readrq);
        fbnic_init_mps(fbd, FBNIC_QM_RNI_RDE_CTL, cls, mps);
        fbnic_init_mps(fbd, FBNIC_QM_RNI_RCM_CTL, cls, mps);
-
-       /* Enable XALI AR/AW outbound */
-       wr32(fbd, FBNIC_PUL_OB_TLP_HDR_AW_CFG,
-            FBNIC_PUL_OB_TLP_HDR_AW_CFG_BME);
-       wr32(fbd, FBNIC_PUL_OB_TLP_HDR_AR_CFG,
-            FBNIC_PUL_OB_TLP_HDR_AR_CFG_BME);
 }
 
 static void fbnic_mac_init_qm(struct fbnic_dev *fbd)