IB/qib: Remove DCA support until feature is finished
authorRalph Campbell <ralph.campbell@qlogic.com>
Thu, 27 May 2010 17:59:10 +0000 (10:59 -0700)
committerRoland Dreier <rolandd@cisco.com>
Thu, 27 May 2010 18:04:48 +0000 (11:04 -0700)
The DCA code was left over from internal development to test the
hardware feature and allow performance testing.  The results were
mixed and will require some additional work to make full use of the
feature.  Therefore, it is being removed for now.

Signed-off-by: Ralph Campbell <ralph.campbell@qlogic.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
drivers/infiniband/hw/qib/qib_iba7322.c

index 23fb9ef..503992d 100644 (file)
@@ -42,9 +42,6 @@
 #include <linux/jiffies.h>
 #include <rdma/ib_verbs.h>
 #include <rdma/ib_smi.h>
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-#include <linux/dca.h>
-#endif
 
 #include "qib.h"
 #include "qib_7322_regs.h"
@@ -518,12 +515,6 @@ struct qib_chip_specific {
        u32 lastbuf_for_pio;
        u32 stay_in_freeze;
        u32 recovery_ports_initted;
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       u32 dca_ctrl;
-       int rhdr_cpu[18];
-       int sdma_cpu[2];
-       u64 dca_rcvhdr_ctrl[5]; /* B, C, D, E, F */
-#endif
        struct msix_entry *msix_entries;
        void  **msix_arg;
        unsigned long *sendchkenable;
@@ -642,52 +633,6 @@ static struct {
                SYM_LSB(IntStatus, SDmaCleanupDone_1), 2 },
 };
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-static const struct dca_reg_map {
-       int     shadow_inx;
-       int     lsb;
-       u64     mask;
-       u16     regno;
-} dca_rcvhdr_reg_map[] = {
-       { 0, SYM_LSB(DCACtrlB, RcvHdrq0DCAOPH),
-          ~SYM_MASK(DCACtrlB, RcvHdrq0DCAOPH) , KREG_IDX(DCACtrlB) },
-       { 0, SYM_LSB(DCACtrlB, RcvHdrq1DCAOPH),
-          ~SYM_MASK(DCACtrlB, RcvHdrq1DCAOPH) , KREG_IDX(DCACtrlB) },
-       { 0, SYM_LSB(DCACtrlB, RcvHdrq2DCAOPH),
-          ~SYM_MASK(DCACtrlB, RcvHdrq2DCAOPH) , KREG_IDX(DCACtrlB) },
-       { 0, SYM_LSB(DCACtrlB, RcvHdrq3DCAOPH),
-          ~SYM_MASK(DCACtrlB, RcvHdrq3DCAOPH) , KREG_IDX(DCACtrlB) },
-       { 1, SYM_LSB(DCACtrlC, RcvHdrq4DCAOPH),
-          ~SYM_MASK(DCACtrlC, RcvHdrq4DCAOPH) , KREG_IDX(DCACtrlC) },
-       { 1, SYM_LSB(DCACtrlC, RcvHdrq5DCAOPH),
-          ~SYM_MASK(DCACtrlC, RcvHdrq5DCAOPH) , KREG_IDX(DCACtrlC) },
-       { 1, SYM_LSB(DCACtrlC, RcvHdrq6DCAOPH),
-          ~SYM_MASK(DCACtrlC, RcvHdrq6DCAOPH) , KREG_IDX(DCACtrlC) },
-       { 1, SYM_LSB(DCACtrlC, RcvHdrq7DCAOPH),
-          ~SYM_MASK(DCACtrlC, RcvHdrq7DCAOPH) , KREG_IDX(DCACtrlC) },
-       { 2, SYM_LSB(DCACtrlD, RcvHdrq8DCAOPH),
-          ~SYM_MASK(DCACtrlD, RcvHdrq8DCAOPH) , KREG_IDX(DCACtrlD) },
-       { 2, SYM_LSB(DCACtrlD, RcvHdrq9DCAOPH),
-          ~SYM_MASK(DCACtrlD, RcvHdrq9DCAOPH) , KREG_IDX(DCACtrlD) },
-       { 2, SYM_LSB(DCACtrlD, RcvHdrq10DCAOPH),
-          ~SYM_MASK(DCACtrlD, RcvHdrq10DCAOPH) , KREG_IDX(DCACtrlD) },
-       { 2, SYM_LSB(DCACtrlD, RcvHdrq11DCAOPH),
-          ~SYM_MASK(DCACtrlD, RcvHdrq11DCAOPH) , KREG_IDX(DCACtrlD) },
-       { 3, SYM_LSB(DCACtrlE, RcvHdrq12DCAOPH),
-          ~SYM_MASK(DCACtrlE, RcvHdrq12DCAOPH) , KREG_IDX(DCACtrlE) },
-       { 3, SYM_LSB(DCACtrlE, RcvHdrq13DCAOPH),
-          ~SYM_MASK(DCACtrlE, RcvHdrq13DCAOPH) , KREG_IDX(DCACtrlE) },
-       { 3, SYM_LSB(DCACtrlE, RcvHdrq14DCAOPH),
-          ~SYM_MASK(DCACtrlE, RcvHdrq14DCAOPH) , KREG_IDX(DCACtrlE) },
-       { 3, SYM_LSB(DCACtrlE, RcvHdrq15DCAOPH),
-          ~SYM_MASK(DCACtrlE, RcvHdrq15DCAOPH) , KREG_IDX(DCACtrlE) },
-       { 4, SYM_LSB(DCACtrlF, RcvHdrq16DCAOPH),
-          ~SYM_MASK(DCACtrlF, RcvHdrq16DCAOPH) , KREG_IDX(DCACtrlF) },
-       { 4, SYM_LSB(DCACtrlF, RcvHdrq17DCAOPH),
-          ~SYM_MASK(DCACtrlF, RcvHdrq17DCAOPH) , KREG_IDX(DCACtrlF) },
-};
-#endif
-
 /* ibcctrl bits */
 #define QLOGIC_IB_IBCC_LINKINITCMD_DISABLE 1
 /* cycle through TS1/TS2 till OK */
@@ -2538,95 +2483,6 @@ static void qib_setup_7322_setextled(struct qib_pportdata *ppd, u32 on)
                qib_write_kreg_port(ppd, krp_rcvpktledcnt, ledblink);
 }
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-static void qib_update_rhdrq_dca(struct qib_ctxtdata *rcd)
-{
-       struct qib_devdata *dd = rcd->dd;
-       struct qib_chip_specific *cspec = dd->cspec;
-       int cpu = get_cpu();
-
-       if (cspec->rhdr_cpu[rcd->ctxt] != cpu) {
-               const struct dca_reg_map *rmp;
-
-               cspec->rhdr_cpu[rcd->ctxt] = cpu;
-               rmp = &dca_rcvhdr_reg_map[rcd->ctxt];
-               cspec->dca_rcvhdr_ctrl[rmp->shadow_inx] &= rmp->mask;
-               cspec->dca_rcvhdr_ctrl[rmp->shadow_inx] |=
-                       (u64) dca3_get_tag(&dd->pcidev->dev, cpu) << rmp->lsb;
-               qib_write_kreg(dd, rmp->regno,
-                              cspec->dca_rcvhdr_ctrl[rmp->shadow_inx]);
-               cspec->dca_ctrl |= SYM_MASK(DCACtrlA, RcvHdrqDCAEnable);
-               qib_write_kreg(dd, KREG_IDX(DCACtrlA), cspec->dca_ctrl);
-       }
-       put_cpu();
-}
-
-static void qib_update_sdma_dca(struct qib_pportdata *ppd)
-{
-       struct qib_devdata *dd = ppd->dd;
-       struct qib_chip_specific *cspec = dd->cspec;
-       int cpu = get_cpu();
-       unsigned pidx = ppd->port - 1;
-
-       if (cspec->sdma_cpu[pidx] != cpu) {
-               cspec->sdma_cpu[pidx] = cpu;
-               cspec->dca_rcvhdr_ctrl[4] &= ~(ppd->hw_pidx ?
-                       SYM_MASK(DCACtrlF, SendDma1DCAOPH) :
-                       SYM_MASK(DCACtrlF, SendDma0DCAOPH));
-               cspec->dca_rcvhdr_ctrl[4] |=
-                       (u64) dca3_get_tag(&dd->pcidev->dev, cpu) <<
-                               (ppd->hw_pidx ?
-                                       SYM_LSB(DCACtrlF, SendDma1DCAOPH) :
-                                       SYM_LSB(DCACtrlF, SendDma0DCAOPH));
-               qib_write_kreg(dd, KREG_IDX(DCACtrlF),
-                              cspec->dca_rcvhdr_ctrl[4]);
-               cspec->dca_ctrl |= ppd->hw_pidx ?
-                       SYM_MASK(DCACtrlA, SendDMAHead1DCAEnable) :
-                       SYM_MASK(DCACtrlA, SendDMAHead0DCAEnable);
-               qib_write_kreg(dd, KREG_IDX(DCACtrlA), cspec->dca_ctrl);
-       }
-       put_cpu();
-}
-
-static void qib_setup_dca(struct qib_devdata *dd)
-{
-       struct qib_chip_specific *cspec = dd->cspec;
-       int i;
-
-       for (i = 0; i < ARRAY_SIZE(cspec->rhdr_cpu); i++)
-               cspec->rhdr_cpu[i] = -1;
-       for (i = 0; i < ARRAY_SIZE(cspec->sdma_cpu); i++)
-               cspec->sdma_cpu[i] = -1;
-       cspec->dca_rcvhdr_ctrl[0] =
-               (1ULL << SYM_LSB(DCACtrlB, RcvHdrq0DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlB, RcvHdrq1DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlB, RcvHdrq2DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlB, RcvHdrq3DCAXfrCnt));
-       cspec->dca_rcvhdr_ctrl[1] =
-               (1ULL << SYM_LSB(DCACtrlC, RcvHdrq4DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlC, RcvHdrq5DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlC, RcvHdrq6DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlC, RcvHdrq7DCAXfrCnt));
-       cspec->dca_rcvhdr_ctrl[2] =
-               (1ULL << SYM_LSB(DCACtrlD, RcvHdrq8DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlD, RcvHdrq9DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlD, RcvHdrq10DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlD, RcvHdrq11DCAXfrCnt));
-       cspec->dca_rcvhdr_ctrl[3] =
-               (1ULL << SYM_LSB(DCACtrlE, RcvHdrq12DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlE, RcvHdrq13DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlE, RcvHdrq14DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlE, RcvHdrq15DCAXfrCnt));
-       cspec->dca_rcvhdr_ctrl[4] =
-               (1ULL << SYM_LSB(DCACtrlF, RcvHdrq16DCAXfrCnt)) |
-               (1ULL << SYM_LSB(DCACtrlF, RcvHdrq17DCAXfrCnt));
-       for (i = 0; i < ARRAY_SIZE(cspec->sdma_cpu); i++)
-               qib_write_kreg(dd, KREG_IDX(DCACtrlB) + i,
-                              cspec->dca_rcvhdr_ctrl[i]);
-}
-
-#endif
-
 /*
  * Disable MSIx interrupt if enabled, call generic MSIx code
  * to cleanup, and clear pending MSIx interrupts.
@@ -2667,15 +2523,6 @@ static void qib_setup_7322_cleanup(struct qib_devdata *dd)
 {
        int i;
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       if (dd->flags & QIB_DCA_ENABLED) {
-               dca_remove_requester(&dd->pcidev->dev);
-               dd->flags &= ~QIB_DCA_ENABLED;
-               dd->cspec->dca_ctrl = 0;
-               qib_write_kreg(dd, KREG_IDX(DCACtrlA), dd->cspec->dca_ctrl);
-       }
-#endif
-
        qib_7322_free_irq(dd);
        kfree(dd->cspec->cntrs);
        kfree(dd->cspec->sendchkenable);
@@ -2983,11 +2830,6 @@ static irqreturn_t qib_7322pintr(int irq, void *data)
        if (dd->int_counter != (u32) -1)
                dd->int_counter++;
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       if (dd->flags & QIB_DCA_ENABLED)
-               qib_update_rhdrq_dca(rcd);
-#endif
-
        /* Clear the interrupt bit we expect to be set. */
        qib_write_kreg(dd, kr_intclear, ((1ULL << QIB_I_RCVAVAIL_LSB) |
                       (1ULL << QIB_I_RCVURG_LSB)) << rcd->ctxt);
@@ -3051,11 +2893,6 @@ static irqreturn_t sdma_intr(int irq, void *data)
        if (dd->int_counter != (u32) -1)
                dd->int_counter++;
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       if (dd->flags & QIB_DCA_ENABLED)
-               qib_update_sdma_dca(ppd);
-#endif
-
        /* Clear the interrupt bit we expect to be set. */
        qib_write_kreg(dd, kr_intclear, ppd->hw_pidx ?
                       INT_MASK_P(SDma, 1) : INT_MASK_P(SDma, 0));
@@ -3085,11 +2922,6 @@ static irqreturn_t sdma_idle_intr(int irq, void *data)
        if (dd->int_counter != (u32) -1)
                dd->int_counter++;
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       if (dd->flags & QIB_DCA_ENABLED)
-               qib_update_sdma_dca(ppd);
-#endif
-
        /* Clear the interrupt bit we expect to be set. */
        qib_write_kreg(dd, kr_intclear, ppd->hw_pidx ?
                       INT_MASK_P(SDmaIdle, 1) : INT_MASK_P(SDmaIdle, 0));
@@ -3119,11 +2951,6 @@ static irqreturn_t sdma_progress_intr(int irq, void *data)
        if (dd->int_counter != (u32) -1)
                dd->int_counter++;
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       if (dd->flags & QIB_DCA_ENABLED)
-               qib_update_sdma_dca(ppd);
-#endif
-
        /* Clear the interrupt bit we expect to be set. */
        qib_write_kreg(dd, kr_intclear, ppd->hw_pidx ?
                       INT_MASK_P(SDmaProgress, 1) :
@@ -3154,11 +2981,6 @@ static irqreturn_t sdma_cleanup_intr(int irq, void *data)
        if (dd->int_counter != (u32) -1)
                dd->int_counter++;
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       if (dd->flags & QIB_DCA_ENABLED)
-               qib_update_sdma_dca(ppd);
-#endif
-
        /* Clear the interrupt bit we expect to be set. */
        qib_write_kreg(dd, kr_intclear, ppd->hw_pidx ?
                       INT_MASK_PM(SDmaCleanupDone, 1) :
@@ -4265,10 +4087,6 @@ static void rcvctrl_7322_mod(struct qib_pportdata *ppd, unsigned int op,
                qib_write_kreg_ctxt(dd, krc_rcvhdraddr, ctxt,
                                    rcd->rcvhdrq_phys);
                rcd->seq_cnt = 1;
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-               if (dd->flags & QIB_DCA_ENABLED)
-                       qib_update_rhdrq_dca(rcd);
-#endif
        }
        if (op & QIB_RCVCTRL_CTXT_DIS)
                ppd->p_rcvctrl &=
@@ -6893,13 +6711,6 @@ struct qib_devdata *qib_init_iba7322_funcs(struct pci_dev *pdev,
        /* clear diagctrl register, in case diags were running and crashed */
        qib_write_kreg(dd, kr_hwdiagctrl, 0);
 
-#if defined(CONFIG_DCA) || defined(CONFIG_DCA_MODULE)
-       ret = dca_add_requester(&pdev->dev);
-       if (!ret) {
-               dd->flags |= QIB_DCA_ENABLED;
-               qib_setup_dca(dd);
-       }
-#endif
        goto bail;
 
 bail_cleanup: