unsigned long irqflags;
        int nq_work = 0;
        int aq_work = 0;
-       int credits;
 
        /* Don't process AdminQ when it's not up */
        if (!pdsc_adminq_inc_if_up(pdsc)) {
 
 credits:
        /* Return the interrupt credits, one for each completion */
-       credits = nq_work + aq_work;
-       if (credits)
-               pds_core_intr_credits(&pdsc->intr_ctrl[qcq->intx],
-                                     credits,
-                                     PDS_CORE_INTR_CRED_REARM);
+       pds_core_intr_credits(&pdsc->intr_ctrl[qcq->intx],
+                             nq_work + aq_work,
+                             PDS_CORE_INTR_CRED_REARM);
        refcount_dec(&pdsc->adminq_refcnt);
 }
 
 
        qcq = &pdsc->adminqcq;
        queue_work(pdsc->wq, &qcq->work);
-       pds_core_intr_mask(&pdsc->intr_ctrl[qcq->intx], PDS_CORE_INTR_MASK_CLEAR);
        refcount_dec(&pdsc->adminq_refcnt);
 
        return IRQ_HANDLED;