cq->rq.r.rq_bi[i].pa = 0;
                cq->rq.r.rq_bi[i].size = 0;
        }
+       cq->rq.r.rq_bi = NULL;
        devm_kfree(ice_hw_to_dev(hw), cq->rq.dma_head);
+       cq->rq.dma_head = NULL;
 
        return ICE_ERR_NO_MEMORY;
 }
                cq->sq.r.sq_bi[i].pa = 0;
                cq->sq.r.sq_bi[i].size = 0;
        }
+       cq->sq.r.sq_bi = NULL;
        devm_kfree(ice_hw_to_dev(hw), cq->sq.dma_head);
+       cq->sq.dma_head = NULL;
 
        return ICE_ERR_NO_MEMORY;
 }
        return 0;
 }
 
+#define ICE_FREE_CQ_BUFS(hw, qi, ring)                                 \
+do {                                                                   \
+       int i;                                                          \
+       /* free descriptors */                                          \
+       if ((qi)->ring.r.ring##_bi)                                     \
+               for (i = 0; i < (qi)->num_##ring##_entries; i++)        \
+                       if ((qi)->ring.r.ring##_bi[i].pa) {             \
+                               dmam_free_coherent(ice_hw_to_dev(hw),   \
+                                       (qi)->ring.r.ring##_bi[i].size, \
+                                       (qi)->ring.r.ring##_bi[i].va,   \
+                                       (qi)->ring.r.ring##_bi[i].pa);  \
+                                       (qi)->ring.r.ring##_bi[i].va = NULL;\
+                                       (qi)->ring.r.ring##_bi[i].pa = 0;\
+                                       (qi)->ring.r.ring##_bi[i].size = 0;\
+               }                                                       \
+       /* free the buffer info list */                                 \
+       if ((qi)->ring.cmd_buf)                                         \
+               devm_kfree(ice_hw_to_dev(hw), (qi)->ring.cmd_buf);      \
+       /* free DMA head */                                             \
+       devm_kfree(ice_hw_to_dev(hw), (qi)->ring.dma_head);             \
+} while (0)
+
 /**
  * ice_init_sq - main initialization routine for Control ATQ
  * @hw: pointer to the hardware structure
        goto init_ctrlq_exit;
 
 init_ctrlq_free_rings:
+       ICE_FREE_CQ_BUFS(hw, cq, sq);
        ice_free_cq_ring(hw, &cq->sq);
 
 init_ctrlq_exit:
        goto init_ctrlq_exit;
 
 init_ctrlq_free_rings:
+       ICE_FREE_CQ_BUFS(hw, cq, rq);
        ice_free_cq_ring(hw, &cq->rq);
 
 init_ctrlq_exit:
        return ret_code;
 }
 
-#define ICE_FREE_CQ_BUFS(hw, qi, ring)                                 \
-do {                                                                   \
-       int i;                                                          \
-       /* free descriptors */                                          \
-       for (i = 0; i < (qi)->num_##ring##_entries; i++)                \
-               if ((qi)->ring.r.ring##_bi[i].pa) {                     \
-                       dmam_free_coherent(ice_hw_to_dev(hw),           \
-                                          (qi)->ring.r.ring##_bi[i].size,\
-                                          (qi)->ring.r.ring##_bi[i].va,\
-                                          (qi)->ring.r.ring##_bi[i].pa);\
-                       (qi)->ring.r.ring##_bi[i].va = NULL;            \
-                       (qi)->ring.r.ring##_bi[i].pa = 0;               \
-                       (qi)->ring.r.ring##_bi[i].size = 0;             \
-               }                                                       \
-       /* free the buffer info list */                                 \
-       if ((qi)->ring.cmd_buf)                                         \
-               devm_kfree(ice_hw_to_dev(hw), (qi)->ring.cmd_buf);      \
-       /* free DMA head */                                             \
-       devm_kfree(ice_hw_to_dev(hw), (qi)->ring.dma_head);             \
-} while (0)
-
 /**
  * ice_shutdown_sq - shutdown the Control ATQ
  * @hw: pointer to the hardware structure