PCI: dwc: Replace magic number by defines
authorGustavo Pimentel <gustavo.pimentel@synopsys.com>
Mon, 14 May 2018 15:09:50 +0000 (16:09 +0100)
committerLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Mon, 14 May 2018 16:32:04 +0000 (17:32 +0100)
Replace magic numbers by a self-explained define to ease human
comprehension.

Signed-off-by: Gustavo Pimentel <gustavo.pimentel@synopsys.com>
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Acked-by: Jingoo Han <jingoohan1@gmail.com>
Acked-by: Joao Pinto <jpinto@synopsys.com>
drivers/pci/dwc/pcie-designware-host.c
drivers/pci/dwc/pcie-designware.h

index fc55fde8742e2ddf7f7299b9d29a2bae510c9bae..a7657ab3a6e067ee50a6169a32ae488aac8d1d28 100644 (file)
@@ -83,18 +83,23 @@ irqreturn_t dw_handle_msi_irq(struct pcie_port *pp)
        num_ctrls = pp->num_vectors / MAX_MSI_IRQS_PER_CTRL;
 
        for (i = 0; i < num_ctrls; i++) {
-               dw_pcie_rd_own_conf(pp, PCIE_MSI_INTR0_STATUS + i * 12, 4,
-                                   &val);
+               dw_pcie_rd_own_conf(pp, PCIE_MSI_INTR0_STATUS +
+                                       (i * MSI_REG_CTRL_BLOCK_SIZE),
+                                   4, &val);
                if (!val)
                        continue;
 
                ret = IRQ_HANDLED;
                pos = 0;
-               while ((pos = find_next_bit((unsigned long *) &val, 32,
-                                           pos)) != 32) {
-                       irq = irq_find_mapping(pp->irq_domain, i * 32 + pos);
+               while ((pos = find_next_bit((unsigned long *) &val,
+                                           MAX_MSI_IRQS_PER_CTRL,
+                                           pos)) != MAX_MSI_IRQS_PER_CTRL) {
+                       irq = irq_find_mapping(pp->irq_domain,
+                                              (i * MAX_MSI_IRQS_PER_CTRL) +
+                                              pos);
                        generic_handle_irq(irq);
-                       dw_pcie_wr_own_conf(pp, PCIE_MSI_INTR0_STATUS + i * 12,
+                       dw_pcie_wr_own_conf(pp, PCIE_MSI_INTR0_STATUS +
+                                               (i * MSI_REG_CTRL_BLOCK_SIZE),
                                            4, 1 << pos);
                        pos++;
                }
@@ -157,9 +162,9 @@ static void dw_pci_bottom_mask(struct irq_data *data)
        if (pp->ops->msi_clear_irq) {
                pp->ops->msi_clear_irq(pp, data->hwirq);
        } else {
-               ctrl = data->hwirq / 32;
-               res = ctrl * 12;
-               bit = data->hwirq % 32;
+               ctrl = data->hwirq / MAX_MSI_IRQS_PER_CTRL;
+               res = ctrl * MSI_REG_CTRL_BLOCK_SIZE;
+               bit = data->hwirq % MAX_MSI_IRQS_PER_CTRL;
 
                pp->irq_status[ctrl] &= ~(1 << bit);
                dw_pcie_wr_own_conf(pp, PCIE_MSI_INTR0_ENABLE + res, 4,
@@ -180,9 +185,9 @@ static void dw_pci_bottom_unmask(struct irq_data *data)
        if (pp->ops->msi_set_irq) {
                pp->ops->msi_set_irq(pp, data->hwirq);
        } else {
-               ctrl = data->hwirq / 32;
-               res = ctrl * 12;
-               bit = data->hwirq % 32;
+               ctrl = data->hwirq / MAX_MSI_IRQS_PER_CTRL;
+               res = ctrl * MSI_REG_CTRL_BLOCK_SIZE;
+               bit = data->hwirq % MAX_MSI_IRQS_PER_CTRL;
 
                pp->irq_status[ctrl] |= 1 << bit;
                dw_pcie_wr_own_conf(pp, PCIE_MSI_INTR0_ENABLE + res, 4,
@@ -652,8 +657,9 @@ void dw_pcie_setup_rc(struct pcie_port *pp)
 
        /* Initialize IRQ Status array */
        for (ctrl = 0; ctrl < num_ctrls; ctrl++)
-               dw_pcie_rd_own_conf(pp, PCIE_MSI_INTR0_ENABLE + (ctrl * 12), 4,
-                                   &pp->irq_status[ctrl]);
+               dw_pcie_rd_own_conf(pp, PCIE_MSI_INTR0_ENABLE +
+                                       (ctrl * MSI_REG_CTRL_BLOCK_SIZE),
+                                   4, &pp->irq_status[ctrl]);
 
        /* Setup RC BARs */
        dw_pcie_writel_dbi(pci, PCI_BASE_ADDRESS_0, 0x00000004);
index fe811dbc12cf7c854e76704f2e52153527252b98..bee4e2535a6121da3901a0c3f80725e9f64357c4 100644 (file)
 #define MAX_MSI_IRQS                   256
 #define MAX_MSI_IRQS_PER_CTRL          32
 #define MAX_MSI_CTRLS                  (MAX_MSI_IRQS / MAX_MSI_IRQS_PER_CTRL)
+#define MSI_REG_CTRL_BLOCK_SIZE                12
 #define MSI_DEF_NUM_VECTORS            32
 
 /* Maximum number of inbound/outbound iATUs */