struct nvmet_pci_epf_irq_vector *iv = cq->iv;
        bool ret;
 
-       if (!test_bit(NVMET_PCI_EPF_Q_IRQ_ENABLED, &cq->flags))
-               return false;
-
        /* IRQ coalescing for the admin queue is not allowed. */
        if (!cq->qid)
                return true;
        struct pci_epf *epf = nvme_epf->epf;
        int ret = 0;
 
-       if (!test_bit(NVMET_PCI_EPF_Q_LIVE, &cq->flags))
+       if (!test_bit(NVMET_PCI_EPF_Q_LIVE, &cq->flags) ||
+           !test_bit(NVMET_PCI_EPF_Q_IRQ_ENABLED, &cq->flags))
                return;
 
        mutex_lock(&ctrl->irq_lock);
        }
 
        if (ret)
-               dev_err(ctrl->dev, "Failed to raise IRQ (err=%d)\n", ret);
+               dev_err_ratelimited(ctrl->dev,
+                                   "CQ[%u]: Failed to raise IRQ (err=%d)\n",
+                                   cq->qid, ret);
 
 unlock:
        mutex_unlock(&ctrl->irq_lock);