Message ID | 20161007164026.26090.42844.stgit@bhelgaas-glaptop2.roam.corp.google.com (mailing list archive) |
---|---|
State | New, archived |
Delegated to: | Bjorn Helgaas |
Headers | show |
On 10/07/2016 12:40 PM, Bjorn Helgaas wrote: > Use a device-specific name, "keystone", for struct keystone_pcie pointers referring to keystone pcie as keystone is not right. keystone_pcie make sense. To use a short name ks_pcie was used. So what is wrong with the naming? I believe this patch is unnecessary. Murali > to hint that this is device-specific information. No functional change > intended. > > Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> > --- > drivers/pci/host/pci-keystone-dw.c | 122 ++++++++++++++++++----------------- > drivers/pci/host/pci-keystone.c | 125 ++++++++++++++++++------------------ > drivers/pci/host/pci-keystone.h | 12 ++- > 3 files changed, 129 insertions(+), 130 deletions(-) > > diff --git a/drivers/pci/host/pci-keystone-dw.c b/drivers/pci/host/pci-keystone-dw.c > index 4151509..d09e3c6 100644 > --- a/drivers/pci/host/pci-keystone-dw.c > +++ b/drivers/pci/host/pci-keystone-dw.c > @@ -83,18 +83,18 @@ static inline void update_reg_offset_bit_pos(u32 offset, u32 *reg_offset, > > phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp) > { > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > - return ks_pcie->app.start + MSI_IRQ; > + return keystone->app.start + MSI_IRQ; > } > > -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) > +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset) > { > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > u32 pending, vector; > int src, virq; > > - pending = readl(ks_pcie->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); > + pending = readl(keystone->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); > > /* > * MSI0 status bit 0-3 shows vectors 0, 8, 16, 24, MSI1 status bit > @@ -114,51 +114,51 @@ void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) > static void ks_dw_pcie_msi_irq_ack(struct irq_data *d) > { > u32 offset, reg_offset, bit_pos; > - struct keystone_pcie *ks_pcie; > + struct keystone_pcie *keystone; > struct msi_desc *msi; > struct pcie_port *pp; > > msi = irq_data_get_msi_desc(d); > pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); > - ks_pcie = to_keystone_pcie(pp); > + keystone = to_keystone_pcie(pp); > offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); > update_reg_offset_bit_pos(offset, ®_offset, &bit_pos); > > writel(BIT(bit_pos), > - ks_pcie->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); > - writel(reg_offset + MSI_IRQ_OFFSET, ks_pcie->va_app_base + IRQ_EOI); > + keystone->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); > + writel(reg_offset + MSI_IRQ_OFFSET, keystone->va_app_base + IRQ_EOI); > } > > void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq) > { > u32 reg_offset, bit_pos; > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); > writel(BIT(bit_pos), > - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); > + keystone->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); > } > > void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq) > { > u32 reg_offset, bit_pos; > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); > writel(BIT(bit_pos), > - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); > + keystone->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); > } > > static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) > { > - struct keystone_pcie *ks_pcie; > + struct keystone_pcie *keystone; > struct msi_desc *msi; > struct pcie_port *pp; > u32 offset; > > msi = irq_data_get_msi_desc(d); > pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); > - ks_pcie = to_keystone_pcie(pp); > + keystone = to_keystone_pcie(pp); > offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); > > /* Mask the end point if PVM implemented */ > @@ -172,14 +172,14 @@ static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) > > static void ks_dw_pcie_msi_irq_unmask(struct irq_data *d) > { > - struct keystone_pcie *ks_pcie; > + struct keystone_pcie *keystone; > struct msi_desc *msi; > struct pcie_port *pp; > u32 offset; > > msi = irq_data_get_msi_desc(d); > pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); > - ks_pcie = to_keystone_pcie(pp); > + keystone = to_keystone_pcie(pp); > offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); > > /* Mask the end point if PVM implemented */ > @@ -214,10 +214,10 @@ static const struct irq_domain_ops ks_dw_pcie_msi_domain_ops = { > > int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) > { > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > int i; > > - pp->irq_domain = irq_domain_add_linear(ks_pcie->msi_intc_np, > + pp->irq_domain = irq_domain_add_linear(keystone->msi_intc_np, > MAX_MSI_IRQS, > &ks_dw_pcie_msi_domain_ops, > chip); > @@ -232,31 +232,31 @@ int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) > return 0; > } > > -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie) > +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone) > { > int i; > > for (i = 0; i < MAX_LEGACY_IRQS; i++) > - writel(0x1, ks_pcie->va_app_base + IRQ_ENABLE_SET + (i << 4)); > + writel(0x1, keystone->va_app_base + IRQ_ENABLE_SET + (i << 4)); > } > > -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset) > +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset) > { > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > u32 pending; > int virq; > > - pending = readl(ks_pcie->va_app_base + IRQ_STATUS + (offset << 4)); > + pending = readl(keystone->va_app_base + IRQ_STATUS + (offset << 4)); > > if (BIT(0) & pending) { > - virq = irq_linear_revmap(ks_pcie->legacy_irq_domain, offset); > + virq = irq_linear_revmap(keystone->legacy_irq_domain, offset); > dev_dbg(pp->dev, ": irq: irq_offset %d, virq %d\n", offset, > virq); > generic_handle_irq(virq); > } > > /* EOI the INTx interrupt */ > - writel(offset, ks_pcie->va_app_base + IRQ_EOI); > + writel(offset, keystone->va_app_base + IRQ_EOI); > } > > void ks_dw_pcie_enable_error_irq(void __iomem *reg_base) > @@ -352,39 +352,39 @@ static void ks_dw_pcie_clear_dbi_mode(void __iomem *reg_virt) > } while (val & DBI_CS2_EN_VAL); > } > > -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) > +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone) > { > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > u32 start = pp->mem->start, end = pp->mem->end; > int i, tr_size; > > /* Disable BARs for inbound access */ > - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); > + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); > writel(0, pp->dbi_base + PCI_BASE_ADDRESS_0); > writel(0, pp->dbi_base + PCI_BASE_ADDRESS_1); > - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); > + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); > > /* Set outbound translation size per window division */ > - writel(CFG_PCIM_WIN_SZ_IDX & 0x7, ks_pcie->va_app_base + OB_SIZE); > + writel(CFG_PCIM_WIN_SZ_IDX & 0x7, keystone->va_app_base + OB_SIZE); > > tr_size = (1 << (CFG_PCIM_WIN_SZ_IDX & 0x7)) * SZ_1M; > > /* Using Direct 1:1 mapping of RC <-> PCI memory space */ > for (i = 0; (i < CFG_PCIM_WIN_CNT) && (start < end); i++) { > - writel(start | 1, ks_pcie->va_app_base + OB_OFFSET_INDEX(i)); > - writel(0, ks_pcie->va_app_base + OB_OFFSET_HI(i)); > + writel(start | 1, keystone->va_app_base + OB_OFFSET_INDEX(i)); > + writel(0, keystone->va_app_base + OB_OFFSET_HI(i)); > start += tr_size; > } > > /* Enable OB translation */ > - writel(OB_XLAT_EN_VAL | readl(ks_pcie->va_app_base + CMD_STATUS), > - ks_pcie->va_app_base + CMD_STATUS); > + writel(OB_XLAT_EN_VAL | readl(keystone->va_app_base + CMD_STATUS), > + keystone->va_app_base + CMD_STATUS); > } > > /** > * ks_pcie_cfg_setup() - Set up configuration space address for a device > * > - * @ks_pcie: ptr to keystone_pcie structure > + * @keystone: ptr to keystone_pcie structure > * @bus: Bus number the device is residing on > * @devfn: device, function number info > * > @@ -398,11 +398,11 @@ void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) > * we will do TYPE 0 access as it will be on our secondary bus (logical). > * CFG_SETUP is needed only for remote configuration access. > */ > -static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, > +static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *keystone, u8 bus, > unsigned int devfn) > { > u8 device = PCI_SLOT(devfn), function = PCI_FUNC(devfn); > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > u32 regval; > > if (bus == 0) > @@ -418,18 +418,18 @@ static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, > if (bus != 1) > regval |= BIT(24); > > - writel(regval, ks_pcie->va_app_base + CFG_SETUP); > + writel(regval, keystone->va_app_base + CFG_SETUP); > return pp->va_cfg0_base; > } > > int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, > unsigned int devfn, int where, int size, u32 *val) > { > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > u8 bus_num = bus->number; > void __iomem *addr; > > - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); > + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); > > return dw_pcie_cfg_read(addr + where, size, val); > } > @@ -437,11 +437,11 @@ int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, > int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, > unsigned int devfn, int where, int size, u32 val) > { > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > u8 bus_num = bus->number; > void __iomem *addr; > > - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); > + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); > > return dw_pcie_cfg_write(addr + where, size, val); > } > @@ -453,22 +453,22 @@ int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, > */ > void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp) > { > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > /* Configure and set up BAR0 */ > - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); > + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); > > /* Enable BAR0 */ > writel(1, pp->dbi_base + PCI_BASE_ADDRESS_0); > writel(SZ_4K - 1, pp->dbi_base + PCI_BASE_ADDRESS_0); > > - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); > + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); > > /* > * For BAR0, just setting bus address for inbound writes (MSI) should > * be sufficient. Use physical address to avoid any conflicts. > */ > - writel(ks_pcie->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); > + writel(keystone->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); > } > > /** > @@ -481,18 +481,18 @@ int ks_dw_pcie_link_up(struct pcie_port *pp) > return (val & LTSSM_STATE_MASK) == LTSSM_STATE_L0; > } > > -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) > +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone) > { > u32 val; > > /* Disable Link training */ > - val = readl(ks_pcie->va_app_base + CMD_STATUS); > + val = readl(keystone->va_app_base + CMD_STATUS); > val &= ~LTSSM_EN_VAL; > - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); > + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); > > /* Initiate Link Training */ > - val = readl(ks_pcie->va_app_base + CMD_STATUS); > - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); > + val = readl(keystone->va_app_base + CMD_STATUS); > + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); > } > > /** > @@ -502,10 +502,10 @@ void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) > * and call dw_pcie_v3_65_host_init() API to initialize the Keystone > * PCI host controller. > */ > -int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, > +int __init ks_dw_pcie_host_init(struct keystone_pcie *keystone, > struct device_node *msi_intc_np) > { > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > struct platform_device *pdev = to_platform_device(pp->dev); > struct resource *res; > > @@ -524,19 +524,19 @@ int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, > > /* Index 1 is the application reg. space address */ > res = platform_get_resource(pdev, IORESOURCE_MEM, 1); > - ks_pcie->va_app_base = devm_ioremap_resource(pp->dev, res); > - if (IS_ERR(ks_pcie->va_app_base)) > - return PTR_ERR(ks_pcie->va_app_base); > + keystone->va_app_base = devm_ioremap_resource(pp->dev, res); > + if (IS_ERR(keystone->va_app_base)) > + return PTR_ERR(keystone->va_app_base); > > - ks_pcie->app = *res; > + keystone->app = *res; > > /* Create legacy IRQ domain */ > - ks_pcie->legacy_irq_domain = > - irq_domain_add_linear(ks_pcie->legacy_intc_np, > + keystone->legacy_irq_domain = > + irq_domain_add_linear(keystone->legacy_intc_np, > MAX_LEGACY_IRQS, > &ks_dw_pcie_legacy_irq_domain_ops, > NULL); > - if (!ks_pcie->legacy_irq_domain) { > + if (!keystone->legacy_irq_domain) { > dev_err(pp->dev, "Failed to add irq domain for legacy irqs\n"); > return -EINVAL; > } > diff --git a/drivers/pci/host/pci-keystone.c b/drivers/pci/host/pci-keystone.c > index 82b461b..55b2be7 100644 > --- a/drivers/pci/host/pci-keystone.c > +++ b/drivers/pci/host/pci-keystone.c > @@ -86,9 +86,9 @@ static void quirk_limit_mrrs(struct pci_dev *dev) > } > DECLARE_PCI_FIXUP_ENABLE(PCI_ANY_ID, PCI_ANY_ID, quirk_limit_mrrs); > > -static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) > +static int ks_pcie_establish_link(struct keystone_pcie *keystone) > { > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > unsigned int retries; > > dw_pcie_setup_rc(pp); > @@ -100,7 +100,7 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) > > /* check if the link is up or not */ > for (retries = 0; retries < 5; retries++) { > - ks_dw_pcie_initiate_link_train(ks_pcie); > + ks_dw_pcie_initiate_link_train(keystone); > if (!dw_pcie_wait_for_link(pp)) > return 0; > } > @@ -112,9 +112,9 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) > static void ks_pcie_msi_irq_handler(struct irq_desc *desc) > { > unsigned int irq = irq_desc_get_irq(desc); > - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); > - u32 offset = irq - ks_pcie->msi_host_irqs[0]; > - struct pcie_port *pp = &ks_pcie->pp; > + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); > + u32 offset = irq - keystone->msi_host_irqs[0]; > + struct pcie_port *pp = &keystone->pp; > struct irq_chip *chip = irq_desc_get_chip(desc); > > dev_dbg(pp->dev, "%s, irq %d\n", __func__, irq); > @@ -125,7 +125,7 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) > * ack operation. > */ > chained_irq_enter(chip, desc); > - ks_dw_pcie_handle_msi_irq(ks_pcie, offset); > + ks_dw_pcie_handle_msi_irq(keystone, offset); > chained_irq_exit(chip, desc); > } > > @@ -140,9 +140,9 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) > static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) > { > unsigned int irq = irq_desc_get_irq(desc); > - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); > - struct pcie_port *pp = &ks_pcie->pp; > - u32 irq_offset = irq - ks_pcie->legacy_host_irqs[0]; > + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); > + struct pcie_port *pp = &keystone->pp; > + u32 irq_offset = irq - keystone->legacy_host_irqs[0]; > struct irq_chip *chip = irq_desc_get_chip(desc); > > dev_dbg(pp->dev, ": Handling legacy irq %d\n", irq); > @@ -153,28 +153,28 @@ static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) > * ack operation. > */ > chained_irq_enter(chip, desc); > - ks_dw_pcie_handle_legacy_irq(ks_pcie, irq_offset); > + ks_dw_pcie_handle_legacy_irq(keystone, irq_offset); > chained_irq_exit(chip, desc); > } > > -static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, > +static int ks_pcie_get_irq_controller_info(struct keystone_pcie *keystone, > char *controller, int *num_irqs) > { > int temp, max_host_irqs, legacy = 1, *host_irqs; > - struct device *dev = ks_pcie->pp.dev; > + struct device *dev = keystone->pp.dev; > struct device_node *np_pcie = dev->of_node, **np_temp; > > if (!strcmp(controller, "msi-interrupt-controller")) > legacy = 0; > > if (legacy) { > - np_temp = &ks_pcie->legacy_intc_np; > + np_temp = &keystone->legacy_intc_np; > max_host_irqs = MAX_LEGACY_HOST_IRQS; > - host_irqs = &ks_pcie->legacy_host_irqs[0]; > + host_irqs = &keystone->legacy_host_irqs[0]; > } else { > - np_temp = &ks_pcie->msi_intc_np; > + np_temp = &keystone->msi_intc_np; > max_host_irqs = MAX_MSI_HOST_IRQS; > - host_irqs = &ks_pcie->msi_host_irqs[0]; > + host_irqs = &keystone->msi_host_irqs[0]; > } > > /* interrupt controller is in a child node */ > @@ -212,29 +212,29 @@ static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, > return -EINVAL; > } > > -static void ks_pcie_setup_interrupts(struct keystone_pcie *ks_pcie) > +static void ks_pcie_setup_interrupts(struct keystone_pcie *keystone) > { > int i; > > /* Legacy IRQ */ > - for (i = 0; i < ks_pcie->num_legacy_host_irqs; i++) { > - irq_set_chained_handler_and_data(ks_pcie->legacy_host_irqs[i], > + for (i = 0; i < keystone->num_legacy_host_irqs; i++) { > + irq_set_chained_handler_and_data(keystone->legacy_host_irqs[i], > ks_pcie_legacy_irq_handler, > - ks_pcie); > + keystone); > } > - ks_dw_pcie_enable_legacy_irqs(ks_pcie); > + ks_dw_pcie_enable_legacy_irqs(keystone); > > /* MSI IRQ */ > if (IS_ENABLED(CONFIG_PCI_MSI)) { > - for (i = 0; i < ks_pcie->num_msi_host_irqs; i++) { > - irq_set_chained_handler_and_data(ks_pcie->msi_host_irqs[i], > + for (i = 0; i < keystone->num_msi_host_irqs; i++) { > + irq_set_chained_handler_and_data(keystone->msi_host_irqs[i], > ks_pcie_msi_irq_handler, > - ks_pcie); > + keystone); > } > } > > - if (ks_pcie->error_irq > 0) > - ks_dw_pcie_enable_error_irq(ks_pcie->va_app_base); > + if (keystone->error_irq > 0) > + ks_dw_pcie_enable_error_irq(keystone->va_app_base); > } > > /* > @@ -259,17 +259,17 @@ static int keystone_pcie_fault(unsigned long addr, unsigned int fsr, > > static void __init ks_pcie_host_init(struct pcie_port *pp) > { > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > u32 val; > > - ks_pcie_establish_link(ks_pcie); > - ks_dw_pcie_setup_rc_app_regs(ks_pcie); > - ks_pcie_setup_interrupts(ks_pcie); > + ks_pcie_establish_link(keystone); > + ks_dw_pcie_setup_rc_app_regs(keystone); > + ks_pcie_setup_interrupts(keystone); > writew(PCI_IO_RANGE_TYPE_32 | (PCI_IO_RANGE_TYPE_32 << 8), > pp->dbi_base + PCI_IO_BASE); > > /* update the Vendor ID */ > - writew(ks_pcie->device_id, pp->dbi_base + PCI_DEVICE_ID); > + writew(keystone->device_id, pp->dbi_base + PCI_DEVICE_ID); > > /* update the DEV_STAT_CTRL to publish right mrrs */ > val = readl(pp->dbi_base + PCIE_CAP_BASE + PCI_EXP_DEVCTL); > @@ -300,28 +300,28 @@ static struct pcie_host_ops keystone_pcie_host_ops = { > > static irqreturn_t pcie_err_irq_handler(int irq, void *priv) > { > - struct keystone_pcie *ks_pcie = priv; > + struct keystone_pcie *keystone = priv; > > - return ks_dw_pcie_handle_error_irq(ks_pcie->pp.dev, > - ks_pcie->va_app_base); > + return ks_dw_pcie_handle_error_irq(keystone->pp.dev, > + keystone->va_app_base); > } > > -static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, > +static int __init ks_add_pcie_port(struct keystone_pcie *keystone, > struct platform_device *pdev) > { > - struct pcie_port *pp = &ks_pcie->pp; > + struct pcie_port *pp = &keystone->pp; > int ret; > > - ret = ks_pcie_get_irq_controller_info(ks_pcie, > + ret = ks_pcie_get_irq_controller_info(keystone, > "legacy-interrupt-controller", > - &ks_pcie->num_legacy_host_irqs); > + &keystone->num_legacy_host_irqs); > if (ret) > return ret; > > if (IS_ENABLED(CONFIG_PCI_MSI)) { > - ret = ks_pcie_get_irq_controller_info(ks_pcie, > + ret = ks_pcie_get_irq_controller_info(keystone, > "msi-interrupt-controller", > - &ks_pcie->num_msi_host_irqs); > + &keystone->num_msi_host_irqs); > if (ret) > return ret; > } > @@ -330,22 +330,22 @@ static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, > * Index 0 is the platform interrupt for error interrupt > * from RC. This is optional. > */ > - ks_pcie->error_irq = irq_of_parse_and_map(ks_pcie->np, 0); > - if (ks_pcie->error_irq <= 0) > + keystone->error_irq = irq_of_parse_and_map(keystone->np, 0); > + if (keystone->error_irq <= 0) > dev_info(&pdev->dev, "no error IRQ defined\n"); > else { > - ret = request_irq(ks_pcie->error_irq, pcie_err_irq_handler, > - IRQF_SHARED, "pcie-error-irq", ks_pcie); > + ret = request_irq(keystone->error_irq, pcie_err_irq_handler, > + IRQF_SHARED, "pcie-error-irq", keystone); > if (ret < 0) { > dev_err(&pdev->dev, "failed to request error IRQ %d\n", > - ks_pcie->error_irq); > + keystone->error_irq); > return ret; > } > } > > pp->root_bus_nr = -1; > pp->ops = &keystone_pcie_host_ops; > - ret = ks_dw_pcie_host_init(ks_pcie, ks_pcie->msi_intc_np); > + ret = ks_dw_pcie_host_init(keystone, keystone->msi_intc_np); > if (ret) { > dev_err(&pdev->dev, "failed to initialize host\n"); > return ret; > @@ -364,9 +364,9 @@ static const struct of_device_id ks_pcie_of_match[] = { > > static int __exit ks_pcie_remove(struct platform_device *pdev) > { > - struct keystone_pcie *ks_pcie = platform_get_drvdata(pdev); > + struct keystone_pcie *keystone = platform_get_drvdata(pdev); > > - clk_disable_unprepare(ks_pcie->clk); > + clk_disable_unprepare(keystone->clk); > > return 0; > } > @@ -374,19 +374,18 @@ static int __exit ks_pcie_remove(struct platform_device *pdev) > static int __init ks_pcie_probe(struct platform_device *pdev) > { > struct device *dev = &pdev->dev; > - struct keystone_pcie *ks_pcie; > + struct keystone_pcie *keystone; > struct pcie_port *pp; > struct resource *res; > void __iomem *reg_p; > struct phy *phy; > int ret; > > - ks_pcie = devm_kzalloc(&pdev->dev, sizeof(*ks_pcie), > - GFP_KERNEL); > - if (!ks_pcie) > + keystone = devm_kzalloc(&pdev->dev, sizeof(*keystone), GFP_KERNEL); > + if (!keystone) > return -ENOMEM; > > - pp = &ks_pcie->pp; > + pp = &keystone->pp; > > /* initialize SerDes Phy if present */ > phy = devm_phy_get(dev, "pcie-phy"); > @@ -404,29 +403,29 @@ static int __init ks_pcie_probe(struct platform_device *pdev) > reg_p = devm_ioremap_resource(dev, res); > if (IS_ERR(reg_p)) > return PTR_ERR(reg_p); > - ks_pcie->device_id = readl(reg_p) >> 16; > + keystone->device_id = readl(reg_p) >> 16; > devm_iounmap(dev, reg_p); > devm_release_mem_region(dev, res->start, resource_size(res)); > > pp->dev = dev; > - ks_pcie->np = dev->of_node; > - platform_set_drvdata(pdev, ks_pcie); > - ks_pcie->clk = devm_clk_get(dev, "pcie"); > - if (IS_ERR(ks_pcie->clk)) { > + keystone->np = dev->of_node; > + platform_set_drvdata(pdev, keystone); > + keystone->clk = devm_clk_get(dev, "pcie"); > + if (IS_ERR(keystone->clk)) { > dev_err(dev, "Failed to get pcie rc clock\n"); > - return PTR_ERR(ks_pcie->clk); > + return PTR_ERR(keystone->clk); > } > - ret = clk_prepare_enable(ks_pcie->clk); > + ret = clk_prepare_enable(keystone->clk); > if (ret) > return ret; > > - ret = ks_add_pcie_port(ks_pcie, pdev); > + ret = ks_add_pcie_port(keystone, pdev); > if (ret < 0) > goto fail_clk; > > return 0; > fail_clk: > - clk_disable_unprepare(ks_pcie->clk); > + clk_disable_unprepare(keystone->clk); > > return ret; > } > diff --git a/drivers/pci/host/pci-keystone.h b/drivers/pci/host/pci-keystone.h > index a5b0cb2..379213c 100644 > --- a/drivers/pci/host/pci-keystone.h > +++ b/drivers/pci/host/pci-keystone.h > @@ -39,24 +39,24 @@ struct keystone_pcie { > }; > > /* Keystone DW specific MSI controller APIs/definitions */ > -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset); > +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset); > phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp); > > /* Keystone specific PCI controller APIs */ > -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie); > -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset); > +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone); > +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset); > void ks_dw_pcie_enable_error_irq(void __iomem *reg_base); > irqreturn_t ks_dw_pcie_handle_error_irq(struct device *dev, > void __iomem *reg_base); > -int ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, > +int ks_dw_pcie_host_init(struct keystone_pcie *keystone, > struct device_node *msi_intc_np); > int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, > unsigned int devfn, int where, int size, u32 val); > int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, > unsigned int devfn, int where, int size, u32 *val); > -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie); > +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone); > int ks_dw_pcie_link_up(struct pcie_port *pp); > -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie); > +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone); > void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq); > void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq); > void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp); >
On 10/07/2016 12:53 PM, Murali Karicheri wrote: > On 10/07/2016 12:40 PM, Bjorn Helgaas wrote: >> Use a device-specific name, "keystone", for struct keystone_pcie pointers > referring to keystone pcie as keystone is not right. keystone_pcie make sense. > To use a short name ks_pcie was used. So what is wrong with the naming? > I believe this patch is unnecessary. Forgot to add. keystone is the SoC name. > > Murali >> to hint that this is device-specific information. No functional change >> intended. >> >> Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> >> --- >> drivers/pci/host/pci-keystone-dw.c | 122 ++++++++++++++++++----------------- >> drivers/pci/host/pci-keystone.c | 125 ++++++++++++++++++------------------ >> drivers/pci/host/pci-keystone.h | 12 ++- >> 3 files changed, 129 insertions(+), 130 deletions(-) >> >> diff --git a/drivers/pci/host/pci-keystone-dw.c b/drivers/pci/host/pci-keystone-dw.c >> index 4151509..d09e3c6 100644 >> --- a/drivers/pci/host/pci-keystone-dw.c >> +++ b/drivers/pci/host/pci-keystone-dw.c >> @@ -83,18 +83,18 @@ static inline void update_reg_offset_bit_pos(u32 offset, u32 *reg_offset, >> >> phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp) >> { >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> >> - return ks_pcie->app.start + MSI_IRQ; >> + return keystone->app.start + MSI_IRQ; >> } >> >> -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) >> +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset) >> { >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> u32 pending, vector; >> int src, virq; >> >> - pending = readl(ks_pcie->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); >> + pending = readl(keystone->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); >> >> /* >> * MSI0 status bit 0-3 shows vectors 0, 8, 16, 24, MSI1 status bit >> @@ -114,51 +114,51 @@ void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) >> static void ks_dw_pcie_msi_irq_ack(struct irq_data *d) >> { >> u32 offset, reg_offset, bit_pos; >> - struct keystone_pcie *ks_pcie; >> + struct keystone_pcie *keystone; >> struct msi_desc *msi; >> struct pcie_port *pp; >> >> msi = irq_data_get_msi_desc(d); >> pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); >> - ks_pcie = to_keystone_pcie(pp); >> + keystone = to_keystone_pcie(pp); >> offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); >> update_reg_offset_bit_pos(offset, ®_offset, &bit_pos); >> >> writel(BIT(bit_pos), >> - ks_pcie->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); >> - writel(reg_offset + MSI_IRQ_OFFSET, ks_pcie->va_app_base + IRQ_EOI); >> + keystone->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); >> + writel(reg_offset + MSI_IRQ_OFFSET, keystone->va_app_base + IRQ_EOI); >> } >> >> void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq) >> { >> u32 reg_offset, bit_pos; >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> >> update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); >> writel(BIT(bit_pos), >> - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); >> + keystone->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); >> } >> >> void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq) >> { >> u32 reg_offset, bit_pos; >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> >> update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); >> writel(BIT(bit_pos), >> - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); >> + keystone->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); >> } >> >> static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) >> { >> - struct keystone_pcie *ks_pcie; >> + struct keystone_pcie *keystone; >> struct msi_desc *msi; >> struct pcie_port *pp; >> u32 offset; >> >> msi = irq_data_get_msi_desc(d); >> pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); >> - ks_pcie = to_keystone_pcie(pp); >> + keystone = to_keystone_pcie(pp); >> offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); >> >> /* Mask the end point if PVM implemented */ >> @@ -172,14 +172,14 @@ static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) >> >> static void ks_dw_pcie_msi_irq_unmask(struct irq_data *d) >> { >> - struct keystone_pcie *ks_pcie; >> + struct keystone_pcie *keystone; >> struct msi_desc *msi; >> struct pcie_port *pp; >> u32 offset; >> >> msi = irq_data_get_msi_desc(d); >> pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); >> - ks_pcie = to_keystone_pcie(pp); >> + keystone = to_keystone_pcie(pp); >> offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); >> >> /* Mask the end point if PVM implemented */ >> @@ -214,10 +214,10 @@ static const struct irq_domain_ops ks_dw_pcie_msi_domain_ops = { >> >> int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) >> { >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> int i; >> >> - pp->irq_domain = irq_domain_add_linear(ks_pcie->msi_intc_np, >> + pp->irq_domain = irq_domain_add_linear(keystone->msi_intc_np, >> MAX_MSI_IRQS, >> &ks_dw_pcie_msi_domain_ops, >> chip); >> @@ -232,31 +232,31 @@ int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) >> return 0; >> } >> >> -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie) >> +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone) >> { >> int i; >> >> for (i = 0; i < MAX_LEGACY_IRQS; i++) >> - writel(0x1, ks_pcie->va_app_base + IRQ_ENABLE_SET + (i << 4)); >> + writel(0x1, keystone->va_app_base + IRQ_ENABLE_SET + (i << 4)); >> } >> >> -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset) >> +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset) >> { >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> u32 pending; >> int virq; >> >> - pending = readl(ks_pcie->va_app_base + IRQ_STATUS + (offset << 4)); >> + pending = readl(keystone->va_app_base + IRQ_STATUS + (offset << 4)); >> >> if (BIT(0) & pending) { >> - virq = irq_linear_revmap(ks_pcie->legacy_irq_domain, offset); >> + virq = irq_linear_revmap(keystone->legacy_irq_domain, offset); >> dev_dbg(pp->dev, ": irq: irq_offset %d, virq %d\n", offset, >> virq); >> generic_handle_irq(virq); >> } >> >> /* EOI the INTx interrupt */ >> - writel(offset, ks_pcie->va_app_base + IRQ_EOI); >> + writel(offset, keystone->va_app_base + IRQ_EOI); >> } >> >> void ks_dw_pcie_enable_error_irq(void __iomem *reg_base) >> @@ -352,39 +352,39 @@ static void ks_dw_pcie_clear_dbi_mode(void __iomem *reg_virt) >> } while (val & DBI_CS2_EN_VAL); >> } >> >> -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) >> +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone) >> { >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> u32 start = pp->mem->start, end = pp->mem->end; >> int i, tr_size; >> >> /* Disable BARs for inbound access */ >> - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); >> + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); >> writel(0, pp->dbi_base + PCI_BASE_ADDRESS_0); >> writel(0, pp->dbi_base + PCI_BASE_ADDRESS_1); >> - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); >> + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); >> >> /* Set outbound translation size per window division */ >> - writel(CFG_PCIM_WIN_SZ_IDX & 0x7, ks_pcie->va_app_base + OB_SIZE); >> + writel(CFG_PCIM_WIN_SZ_IDX & 0x7, keystone->va_app_base + OB_SIZE); >> >> tr_size = (1 << (CFG_PCIM_WIN_SZ_IDX & 0x7)) * SZ_1M; >> >> /* Using Direct 1:1 mapping of RC <-> PCI memory space */ >> for (i = 0; (i < CFG_PCIM_WIN_CNT) && (start < end); i++) { >> - writel(start | 1, ks_pcie->va_app_base + OB_OFFSET_INDEX(i)); >> - writel(0, ks_pcie->va_app_base + OB_OFFSET_HI(i)); >> + writel(start | 1, keystone->va_app_base + OB_OFFSET_INDEX(i)); >> + writel(0, keystone->va_app_base + OB_OFFSET_HI(i)); >> start += tr_size; >> } >> >> /* Enable OB translation */ >> - writel(OB_XLAT_EN_VAL | readl(ks_pcie->va_app_base + CMD_STATUS), >> - ks_pcie->va_app_base + CMD_STATUS); >> + writel(OB_XLAT_EN_VAL | readl(keystone->va_app_base + CMD_STATUS), >> + keystone->va_app_base + CMD_STATUS); >> } >> >> /** >> * ks_pcie_cfg_setup() - Set up configuration space address for a device >> * >> - * @ks_pcie: ptr to keystone_pcie structure >> + * @keystone: ptr to keystone_pcie structure >> * @bus: Bus number the device is residing on >> * @devfn: device, function number info >> * >> @@ -398,11 +398,11 @@ void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) >> * we will do TYPE 0 access as it will be on our secondary bus (logical). >> * CFG_SETUP is needed only for remote configuration access. >> */ >> -static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, >> +static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *keystone, u8 bus, >> unsigned int devfn) >> { >> u8 device = PCI_SLOT(devfn), function = PCI_FUNC(devfn); >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> u32 regval; >> >> if (bus == 0) >> @@ -418,18 +418,18 @@ static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, >> if (bus != 1) >> regval |= BIT(24); >> >> - writel(regval, ks_pcie->va_app_base + CFG_SETUP); >> + writel(regval, keystone->va_app_base + CFG_SETUP); >> return pp->va_cfg0_base; >> } >> >> int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, >> unsigned int devfn, int where, int size, u32 *val) >> { >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> u8 bus_num = bus->number; >> void __iomem *addr; >> >> - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); >> + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); >> >> return dw_pcie_cfg_read(addr + where, size, val); >> } >> @@ -437,11 +437,11 @@ int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, >> int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, >> unsigned int devfn, int where, int size, u32 val) >> { >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> u8 bus_num = bus->number; >> void __iomem *addr; >> >> - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); >> + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); >> >> return dw_pcie_cfg_write(addr + where, size, val); >> } >> @@ -453,22 +453,22 @@ int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, >> */ >> void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp) >> { >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> >> /* Configure and set up BAR0 */ >> - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); >> + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); >> >> /* Enable BAR0 */ >> writel(1, pp->dbi_base + PCI_BASE_ADDRESS_0); >> writel(SZ_4K - 1, pp->dbi_base + PCI_BASE_ADDRESS_0); >> >> - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); >> + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); >> >> /* >> * For BAR0, just setting bus address for inbound writes (MSI) should >> * be sufficient. Use physical address to avoid any conflicts. >> */ >> - writel(ks_pcie->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); >> + writel(keystone->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); >> } >> >> /** >> @@ -481,18 +481,18 @@ int ks_dw_pcie_link_up(struct pcie_port *pp) >> return (val & LTSSM_STATE_MASK) == LTSSM_STATE_L0; >> } >> >> -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) >> +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone) >> { >> u32 val; >> >> /* Disable Link training */ >> - val = readl(ks_pcie->va_app_base + CMD_STATUS); >> + val = readl(keystone->va_app_base + CMD_STATUS); >> val &= ~LTSSM_EN_VAL; >> - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); >> + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); >> >> /* Initiate Link Training */ >> - val = readl(ks_pcie->va_app_base + CMD_STATUS); >> - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); >> + val = readl(keystone->va_app_base + CMD_STATUS); >> + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); >> } >> >> /** >> @@ -502,10 +502,10 @@ void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) >> * and call dw_pcie_v3_65_host_init() API to initialize the Keystone >> * PCI host controller. >> */ >> -int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, >> +int __init ks_dw_pcie_host_init(struct keystone_pcie *keystone, >> struct device_node *msi_intc_np) >> { >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> struct platform_device *pdev = to_platform_device(pp->dev); >> struct resource *res; >> >> @@ -524,19 +524,19 @@ int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, >> >> /* Index 1 is the application reg. space address */ >> res = platform_get_resource(pdev, IORESOURCE_MEM, 1); >> - ks_pcie->va_app_base = devm_ioremap_resource(pp->dev, res); >> - if (IS_ERR(ks_pcie->va_app_base)) >> - return PTR_ERR(ks_pcie->va_app_base); >> + keystone->va_app_base = devm_ioremap_resource(pp->dev, res); >> + if (IS_ERR(keystone->va_app_base)) >> + return PTR_ERR(keystone->va_app_base); >> >> - ks_pcie->app = *res; >> + keystone->app = *res; >> >> /* Create legacy IRQ domain */ >> - ks_pcie->legacy_irq_domain = >> - irq_domain_add_linear(ks_pcie->legacy_intc_np, >> + keystone->legacy_irq_domain = >> + irq_domain_add_linear(keystone->legacy_intc_np, >> MAX_LEGACY_IRQS, >> &ks_dw_pcie_legacy_irq_domain_ops, >> NULL); >> - if (!ks_pcie->legacy_irq_domain) { >> + if (!keystone->legacy_irq_domain) { >> dev_err(pp->dev, "Failed to add irq domain for legacy irqs\n"); >> return -EINVAL; >> } >> diff --git a/drivers/pci/host/pci-keystone.c b/drivers/pci/host/pci-keystone.c >> index 82b461b..55b2be7 100644 >> --- a/drivers/pci/host/pci-keystone.c >> +++ b/drivers/pci/host/pci-keystone.c >> @@ -86,9 +86,9 @@ static void quirk_limit_mrrs(struct pci_dev *dev) >> } >> DECLARE_PCI_FIXUP_ENABLE(PCI_ANY_ID, PCI_ANY_ID, quirk_limit_mrrs); >> >> -static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) >> +static int ks_pcie_establish_link(struct keystone_pcie *keystone) >> { >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> unsigned int retries; >> >> dw_pcie_setup_rc(pp); >> @@ -100,7 +100,7 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) >> >> /* check if the link is up or not */ >> for (retries = 0; retries < 5; retries++) { >> - ks_dw_pcie_initiate_link_train(ks_pcie); >> + ks_dw_pcie_initiate_link_train(keystone); >> if (!dw_pcie_wait_for_link(pp)) >> return 0; >> } >> @@ -112,9 +112,9 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) >> static void ks_pcie_msi_irq_handler(struct irq_desc *desc) >> { >> unsigned int irq = irq_desc_get_irq(desc); >> - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); >> - u32 offset = irq - ks_pcie->msi_host_irqs[0]; >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); >> + u32 offset = irq - keystone->msi_host_irqs[0]; >> + struct pcie_port *pp = &keystone->pp; >> struct irq_chip *chip = irq_desc_get_chip(desc); >> >> dev_dbg(pp->dev, "%s, irq %d\n", __func__, irq); >> @@ -125,7 +125,7 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) >> * ack operation. >> */ >> chained_irq_enter(chip, desc); >> - ks_dw_pcie_handle_msi_irq(ks_pcie, offset); >> + ks_dw_pcie_handle_msi_irq(keystone, offset); >> chained_irq_exit(chip, desc); >> } >> >> @@ -140,9 +140,9 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) >> static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) >> { >> unsigned int irq = irq_desc_get_irq(desc); >> - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); >> - struct pcie_port *pp = &ks_pcie->pp; >> - u32 irq_offset = irq - ks_pcie->legacy_host_irqs[0]; >> + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); >> + struct pcie_port *pp = &keystone->pp; >> + u32 irq_offset = irq - keystone->legacy_host_irqs[0]; >> struct irq_chip *chip = irq_desc_get_chip(desc); >> >> dev_dbg(pp->dev, ": Handling legacy irq %d\n", irq); >> @@ -153,28 +153,28 @@ static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) >> * ack operation. >> */ >> chained_irq_enter(chip, desc); >> - ks_dw_pcie_handle_legacy_irq(ks_pcie, irq_offset); >> + ks_dw_pcie_handle_legacy_irq(keystone, irq_offset); >> chained_irq_exit(chip, desc); >> } >> >> -static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, >> +static int ks_pcie_get_irq_controller_info(struct keystone_pcie *keystone, >> char *controller, int *num_irqs) >> { >> int temp, max_host_irqs, legacy = 1, *host_irqs; >> - struct device *dev = ks_pcie->pp.dev; >> + struct device *dev = keystone->pp.dev; >> struct device_node *np_pcie = dev->of_node, **np_temp; >> >> if (!strcmp(controller, "msi-interrupt-controller")) >> legacy = 0; >> >> if (legacy) { >> - np_temp = &ks_pcie->legacy_intc_np; >> + np_temp = &keystone->legacy_intc_np; >> max_host_irqs = MAX_LEGACY_HOST_IRQS; >> - host_irqs = &ks_pcie->legacy_host_irqs[0]; >> + host_irqs = &keystone->legacy_host_irqs[0]; >> } else { >> - np_temp = &ks_pcie->msi_intc_np; >> + np_temp = &keystone->msi_intc_np; >> max_host_irqs = MAX_MSI_HOST_IRQS; >> - host_irqs = &ks_pcie->msi_host_irqs[0]; >> + host_irqs = &keystone->msi_host_irqs[0]; >> } >> >> /* interrupt controller is in a child node */ >> @@ -212,29 +212,29 @@ static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, >> return -EINVAL; >> } >> >> -static void ks_pcie_setup_interrupts(struct keystone_pcie *ks_pcie) >> +static void ks_pcie_setup_interrupts(struct keystone_pcie *keystone) >> { >> int i; >> >> /* Legacy IRQ */ >> - for (i = 0; i < ks_pcie->num_legacy_host_irqs; i++) { >> - irq_set_chained_handler_and_data(ks_pcie->legacy_host_irqs[i], >> + for (i = 0; i < keystone->num_legacy_host_irqs; i++) { >> + irq_set_chained_handler_and_data(keystone->legacy_host_irqs[i], >> ks_pcie_legacy_irq_handler, >> - ks_pcie); >> + keystone); >> } >> - ks_dw_pcie_enable_legacy_irqs(ks_pcie); >> + ks_dw_pcie_enable_legacy_irqs(keystone); >> >> /* MSI IRQ */ >> if (IS_ENABLED(CONFIG_PCI_MSI)) { >> - for (i = 0; i < ks_pcie->num_msi_host_irqs; i++) { >> - irq_set_chained_handler_and_data(ks_pcie->msi_host_irqs[i], >> + for (i = 0; i < keystone->num_msi_host_irqs; i++) { >> + irq_set_chained_handler_and_data(keystone->msi_host_irqs[i], >> ks_pcie_msi_irq_handler, >> - ks_pcie); >> + keystone); >> } >> } >> >> - if (ks_pcie->error_irq > 0) >> - ks_dw_pcie_enable_error_irq(ks_pcie->va_app_base); >> + if (keystone->error_irq > 0) >> + ks_dw_pcie_enable_error_irq(keystone->va_app_base); >> } >> >> /* >> @@ -259,17 +259,17 @@ static int keystone_pcie_fault(unsigned long addr, unsigned int fsr, >> >> static void __init ks_pcie_host_init(struct pcie_port *pp) >> { >> - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); >> + struct keystone_pcie *keystone = to_keystone_pcie(pp); >> u32 val; >> >> - ks_pcie_establish_link(ks_pcie); >> - ks_dw_pcie_setup_rc_app_regs(ks_pcie); >> - ks_pcie_setup_interrupts(ks_pcie); >> + ks_pcie_establish_link(keystone); >> + ks_dw_pcie_setup_rc_app_regs(keystone); >> + ks_pcie_setup_interrupts(keystone); >> writew(PCI_IO_RANGE_TYPE_32 | (PCI_IO_RANGE_TYPE_32 << 8), >> pp->dbi_base + PCI_IO_BASE); >> >> /* update the Vendor ID */ >> - writew(ks_pcie->device_id, pp->dbi_base + PCI_DEVICE_ID); >> + writew(keystone->device_id, pp->dbi_base + PCI_DEVICE_ID); >> >> /* update the DEV_STAT_CTRL to publish right mrrs */ >> val = readl(pp->dbi_base + PCIE_CAP_BASE + PCI_EXP_DEVCTL); >> @@ -300,28 +300,28 @@ static struct pcie_host_ops keystone_pcie_host_ops = { >> >> static irqreturn_t pcie_err_irq_handler(int irq, void *priv) >> { >> - struct keystone_pcie *ks_pcie = priv; >> + struct keystone_pcie *keystone = priv; >> >> - return ks_dw_pcie_handle_error_irq(ks_pcie->pp.dev, >> - ks_pcie->va_app_base); >> + return ks_dw_pcie_handle_error_irq(keystone->pp.dev, >> + keystone->va_app_base); >> } >> >> -static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, >> +static int __init ks_add_pcie_port(struct keystone_pcie *keystone, >> struct platform_device *pdev) >> { >> - struct pcie_port *pp = &ks_pcie->pp; >> + struct pcie_port *pp = &keystone->pp; >> int ret; >> >> - ret = ks_pcie_get_irq_controller_info(ks_pcie, >> + ret = ks_pcie_get_irq_controller_info(keystone, >> "legacy-interrupt-controller", >> - &ks_pcie->num_legacy_host_irqs); >> + &keystone->num_legacy_host_irqs); >> if (ret) >> return ret; >> >> if (IS_ENABLED(CONFIG_PCI_MSI)) { >> - ret = ks_pcie_get_irq_controller_info(ks_pcie, >> + ret = ks_pcie_get_irq_controller_info(keystone, >> "msi-interrupt-controller", >> - &ks_pcie->num_msi_host_irqs); >> + &keystone->num_msi_host_irqs); >> if (ret) >> return ret; >> } >> @@ -330,22 +330,22 @@ static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, >> * Index 0 is the platform interrupt for error interrupt >> * from RC. This is optional. >> */ >> - ks_pcie->error_irq = irq_of_parse_and_map(ks_pcie->np, 0); >> - if (ks_pcie->error_irq <= 0) >> + keystone->error_irq = irq_of_parse_and_map(keystone->np, 0); >> + if (keystone->error_irq <= 0) >> dev_info(&pdev->dev, "no error IRQ defined\n"); >> else { >> - ret = request_irq(ks_pcie->error_irq, pcie_err_irq_handler, >> - IRQF_SHARED, "pcie-error-irq", ks_pcie); >> + ret = request_irq(keystone->error_irq, pcie_err_irq_handler, >> + IRQF_SHARED, "pcie-error-irq", keystone); >> if (ret < 0) { >> dev_err(&pdev->dev, "failed to request error IRQ %d\n", >> - ks_pcie->error_irq); >> + keystone->error_irq); >> return ret; >> } >> } >> >> pp->root_bus_nr = -1; >> pp->ops = &keystone_pcie_host_ops; >> - ret = ks_dw_pcie_host_init(ks_pcie, ks_pcie->msi_intc_np); >> + ret = ks_dw_pcie_host_init(keystone, keystone->msi_intc_np); >> if (ret) { >> dev_err(&pdev->dev, "failed to initialize host\n"); >> return ret; >> @@ -364,9 +364,9 @@ static const struct of_device_id ks_pcie_of_match[] = { >> >> static int __exit ks_pcie_remove(struct platform_device *pdev) >> { >> - struct keystone_pcie *ks_pcie = platform_get_drvdata(pdev); >> + struct keystone_pcie *keystone = platform_get_drvdata(pdev); >> >> - clk_disable_unprepare(ks_pcie->clk); >> + clk_disable_unprepare(keystone->clk); >> >> return 0; >> } >> @@ -374,19 +374,18 @@ static int __exit ks_pcie_remove(struct platform_device *pdev) >> static int __init ks_pcie_probe(struct platform_device *pdev) >> { >> struct device *dev = &pdev->dev; >> - struct keystone_pcie *ks_pcie; >> + struct keystone_pcie *keystone; >> struct pcie_port *pp; >> struct resource *res; >> void __iomem *reg_p; >> struct phy *phy; >> int ret; >> >> - ks_pcie = devm_kzalloc(&pdev->dev, sizeof(*ks_pcie), >> - GFP_KERNEL); >> - if (!ks_pcie) >> + keystone = devm_kzalloc(&pdev->dev, sizeof(*keystone), GFP_KERNEL); >> + if (!keystone) >> return -ENOMEM; >> >> - pp = &ks_pcie->pp; >> + pp = &keystone->pp; >> >> /* initialize SerDes Phy if present */ >> phy = devm_phy_get(dev, "pcie-phy"); >> @@ -404,29 +403,29 @@ static int __init ks_pcie_probe(struct platform_device *pdev) >> reg_p = devm_ioremap_resource(dev, res); >> if (IS_ERR(reg_p)) >> return PTR_ERR(reg_p); >> - ks_pcie->device_id = readl(reg_p) >> 16; >> + keystone->device_id = readl(reg_p) >> 16; >> devm_iounmap(dev, reg_p); >> devm_release_mem_region(dev, res->start, resource_size(res)); >> >> pp->dev = dev; >> - ks_pcie->np = dev->of_node; >> - platform_set_drvdata(pdev, ks_pcie); >> - ks_pcie->clk = devm_clk_get(dev, "pcie"); >> - if (IS_ERR(ks_pcie->clk)) { >> + keystone->np = dev->of_node; >> + platform_set_drvdata(pdev, keystone); >> + keystone->clk = devm_clk_get(dev, "pcie"); >> + if (IS_ERR(keystone->clk)) { >> dev_err(dev, "Failed to get pcie rc clock\n"); >> - return PTR_ERR(ks_pcie->clk); >> + return PTR_ERR(keystone->clk); >> } >> - ret = clk_prepare_enable(ks_pcie->clk); >> + ret = clk_prepare_enable(keystone->clk); >> if (ret) >> return ret; >> >> - ret = ks_add_pcie_port(ks_pcie, pdev); >> + ret = ks_add_pcie_port(keystone, pdev); >> if (ret < 0) >> goto fail_clk; >> >> return 0; >> fail_clk: >> - clk_disable_unprepare(ks_pcie->clk); >> + clk_disable_unprepare(keystone->clk); >> >> return ret; >> } >> diff --git a/drivers/pci/host/pci-keystone.h b/drivers/pci/host/pci-keystone.h >> index a5b0cb2..379213c 100644 >> --- a/drivers/pci/host/pci-keystone.h >> +++ b/drivers/pci/host/pci-keystone.h >> @@ -39,24 +39,24 @@ struct keystone_pcie { >> }; >> >> /* Keystone DW specific MSI controller APIs/definitions */ >> -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset); >> +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset); >> phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp); >> >> /* Keystone specific PCI controller APIs */ >> -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie); >> -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset); >> +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone); >> +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset); >> void ks_dw_pcie_enable_error_irq(void __iomem *reg_base); >> irqreturn_t ks_dw_pcie_handle_error_irq(struct device *dev, >> void __iomem *reg_base); >> -int ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, >> +int ks_dw_pcie_host_init(struct keystone_pcie *keystone, >> struct device_node *msi_intc_np); >> int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, >> unsigned int devfn, int where, int size, u32 val); >> int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, >> unsigned int devfn, int where, int size, u32 *val); >> -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie); >> +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone); >> int ks_dw_pcie_link_up(struct pcie_port *pp); >> -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie); >> +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone); >> void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq); >> void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq); >> void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp); >> > >
On Fri, Oct 07, 2016 at 12:53:45PM -0400, Murali Karicheri wrote: > On 10/07/2016 12:40 PM, Bjorn Helgaas wrote: > > Use a device-specific name, "keystone", for struct keystone_pcie pointers > referring to keystone pcie as keystone is not right. keystone_pcie make sense. > To use a short name ks_pcie was used. So what is wrong with the naming? > I believe this patch is unnecessary. Yeah, you're right. I'm sure that's the case for several of the other drivers, too. I think it's more wordy than necessary to include the "_pcie" part for every mention in the file, but I guess we do that for all the function names, too. I do like the fact that you included "ks_" already, which gives us a hint that this is keystone-specific. I dropped this one and re-pushed the branch. Thanks for taking a look. > Murali > > to hint that this is device-specific information. No functional change > > intended. > > > > Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> > > --- > > drivers/pci/host/pci-keystone-dw.c | 122 ++++++++++++++++++----------------- > > drivers/pci/host/pci-keystone.c | 125 ++++++++++++++++++------------------ > > drivers/pci/host/pci-keystone.h | 12 ++- > > 3 files changed, 129 insertions(+), 130 deletions(-) > > > > diff --git a/drivers/pci/host/pci-keystone-dw.c b/drivers/pci/host/pci-keystone-dw.c > > index 4151509..d09e3c6 100644 > > --- a/drivers/pci/host/pci-keystone-dw.c > > +++ b/drivers/pci/host/pci-keystone-dw.c > > @@ -83,18 +83,18 @@ static inline void update_reg_offset_bit_pos(u32 offset, u32 *reg_offset, > > > > phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp) > > { > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > > > - return ks_pcie->app.start + MSI_IRQ; > > + return keystone->app.start + MSI_IRQ; > > } > > > > -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) > > +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset) > > { > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > u32 pending, vector; > > int src, virq; > > > > - pending = readl(ks_pcie->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); > > + pending = readl(keystone->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); > > > > /* > > * MSI0 status bit 0-3 shows vectors 0, 8, 16, 24, MSI1 status bit > > @@ -114,51 +114,51 @@ void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) > > static void ks_dw_pcie_msi_irq_ack(struct irq_data *d) > > { > > u32 offset, reg_offset, bit_pos; > > - struct keystone_pcie *ks_pcie; > > + struct keystone_pcie *keystone; > > struct msi_desc *msi; > > struct pcie_port *pp; > > > > msi = irq_data_get_msi_desc(d); > > pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); > > - ks_pcie = to_keystone_pcie(pp); > > + keystone = to_keystone_pcie(pp); > > offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); > > update_reg_offset_bit_pos(offset, ®_offset, &bit_pos); > > > > writel(BIT(bit_pos), > > - ks_pcie->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); > > - writel(reg_offset + MSI_IRQ_OFFSET, ks_pcie->va_app_base + IRQ_EOI); > > + keystone->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); > > + writel(reg_offset + MSI_IRQ_OFFSET, keystone->va_app_base + IRQ_EOI); > > } > > > > void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq) > > { > > u32 reg_offset, bit_pos; > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > > > update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); > > writel(BIT(bit_pos), > > - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); > > + keystone->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); > > } > > > > void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq) > > { > > u32 reg_offset, bit_pos; > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > > > update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); > > writel(BIT(bit_pos), > > - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); > > + keystone->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); > > } > > > > static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) > > { > > - struct keystone_pcie *ks_pcie; > > + struct keystone_pcie *keystone; > > struct msi_desc *msi; > > struct pcie_port *pp; > > u32 offset; > > > > msi = irq_data_get_msi_desc(d); > > pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); > > - ks_pcie = to_keystone_pcie(pp); > > + keystone = to_keystone_pcie(pp); > > offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); > > > > /* Mask the end point if PVM implemented */ > > @@ -172,14 +172,14 @@ static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) > > > > static void ks_dw_pcie_msi_irq_unmask(struct irq_data *d) > > { > > - struct keystone_pcie *ks_pcie; > > + struct keystone_pcie *keystone; > > struct msi_desc *msi; > > struct pcie_port *pp; > > u32 offset; > > > > msi = irq_data_get_msi_desc(d); > > pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); > > - ks_pcie = to_keystone_pcie(pp); > > + keystone = to_keystone_pcie(pp); > > offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); > > > > /* Mask the end point if PVM implemented */ > > @@ -214,10 +214,10 @@ static const struct irq_domain_ops ks_dw_pcie_msi_domain_ops = { > > > > int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) > > { > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > int i; > > > > - pp->irq_domain = irq_domain_add_linear(ks_pcie->msi_intc_np, > > + pp->irq_domain = irq_domain_add_linear(keystone->msi_intc_np, > > MAX_MSI_IRQS, > > &ks_dw_pcie_msi_domain_ops, > > chip); > > @@ -232,31 +232,31 @@ int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) > > return 0; > > } > > > > -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie) > > +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone) > > { > > int i; > > > > for (i = 0; i < MAX_LEGACY_IRQS; i++) > > - writel(0x1, ks_pcie->va_app_base + IRQ_ENABLE_SET + (i << 4)); > > + writel(0x1, keystone->va_app_base + IRQ_ENABLE_SET + (i << 4)); > > } > > > > -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset) > > +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset) > > { > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > u32 pending; > > int virq; > > > > - pending = readl(ks_pcie->va_app_base + IRQ_STATUS + (offset << 4)); > > + pending = readl(keystone->va_app_base + IRQ_STATUS + (offset << 4)); > > > > if (BIT(0) & pending) { > > - virq = irq_linear_revmap(ks_pcie->legacy_irq_domain, offset); > > + virq = irq_linear_revmap(keystone->legacy_irq_domain, offset); > > dev_dbg(pp->dev, ": irq: irq_offset %d, virq %d\n", offset, > > virq); > > generic_handle_irq(virq); > > } > > > > /* EOI the INTx interrupt */ > > - writel(offset, ks_pcie->va_app_base + IRQ_EOI); > > + writel(offset, keystone->va_app_base + IRQ_EOI); > > } > > > > void ks_dw_pcie_enable_error_irq(void __iomem *reg_base) > > @@ -352,39 +352,39 @@ static void ks_dw_pcie_clear_dbi_mode(void __iomem *reg_virt) > > } while (val & DBI_CS2_EN_VAL); > > } > > > > -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) > > +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone) > > { > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > u32 start = pp->mem->start, end = pp->mem->end; > > int i, tr_size; > > > > /* Disable BARs for inbound access */ > > - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); > > + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); > > writel(0, pp->dbi_base + PCI_BASE_ADDRESS_0); > > writel(0, pp->dbi_base + PCI_BASE_ADDRESS_1); > > - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); > > + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); > > > > /* Set outbound translation size per window division */ > > - writel(CFG_PCIM_WIN_SZ_IDX & 0x7, ks_pcie->va_app_base + OB_SIZE); > > + writel(CFG_PCIM_WIN_SZ_IDX & 0x7, keystone->va_app_base + OB_SIZE); > > > > tr_size = (1 << (CFG_PCIM_WIN_SZ_IDX & 0x7)) * SZ_1M; > > > > /* Using Direct 1:1 mapping of RC <-> PCI memory space */ > > for (i = 0; (i < CFG_PCIM_WIN_CNT) && (start < end); i++) { > > - writel(start | 1, ks_pcie->va_app_base + OB_OFFSET_INDEX(i)); > > - writel(0, ks_pcie->va_app_base + OB_OFFSET_HI(i)); > > + writel(start | 1, keystone->va_app_base + OB_OFFSET_INDEX(i)); > > + writel(0, keystone->va_app_base + OB_OFFSET_HI(i)); > > start += tr_size; > > } > > > > /* Enable OB translation */ > > - writel(OB_XLAT_EN_VAL | readl(ks_pcie->va_app_base + CMD_STATUS), > > - ks_pcie->va_app_base + CMD_STATUS); > > + writel(OB_XLAT_EN_VAL | readl(keystone->va_app_base + CMD_STATUS), > > + keystone->va_app_base + CMD_STATUS); > > } > > > > /** > > * ks_pcie_cfg_setup() - Set up configuration space address for a device > > * > > - * @ks_pcie: ptr to keystone_pcie structure > > + * @keystone: ptr to keystone_pcie structure > > * @bus: Bus number the device is residing on > > * @devfn: device, function number info > > * > > @@ -398,11 +398,11 @@ void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) > > * we will do TYPE 0 access as it will be on our secondary bus (logical). > > * CFG_SETUP is needed only for remote configuration access. > > */ > > -static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, > > +static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *keystone, u8 bus, > > unsigned int devfn) > > { > > u8 device = PCI_SLOT(devfn), function = PCI_FUNC(devfn); > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > u32 regval; > > > > if (bus == 0) > > @@ -418,18 +418,18 @@ static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, > > if (bus != 1) > > regval |= BIT(24); > > > > - writel(regval, ks_pcie->va_app_base + CFG_SETUP); > > + writel(regval, keystone->va_app_base + CFG_SETUP); > > return pp->va_cfg0_base; > > } > > > > int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, > > unsigned int devfn, int where, int size, u32 *val) > > { > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > u8 bus_num = bus->number; > > void __iomem *addr; > > > > - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); > > + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); > > > > return dw_pcie_cfg_read(addr + where, size, val); > > } > > @@ -437,11 +437,11 @@ int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, > > int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, > > unsigned int devfn, int where, int size, u32 val) > > { > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > u8 bus_num = bus->number; > > void __iomem *addr; > > > > - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); > > + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); > > > > return dw_pcie_cfg_write(addr + where, size, val); > > } > > @@ -453,22 +453,22 @@ int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, > > */ > > void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp) > > { > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > > > /* Configure and set up BAR0 */ > > - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); > > + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); > > > > /* Enable BAR0 */ > > writel(1, pp->dbi_base + PCI_BASE_ADDRESS_0); > > writel(SZ_4K - 1, pp->dbi_base + PCI_BASE_ADDRESS_0); > > > > - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); > > + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); > > > > /* > > * For BAR0, just setting bus address for inbound writes (MSI) should > > * be sufficient. Use physical address to avoid any conflicts. > > */ > > - writel(ks_pcie->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); > > + writel(keystone->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); > > } > > > > /** > > @@ -481,18 +481,18 @@ int ks_dw_pcie_link_up(struct pcie_port *pp) > > return (val & LTSSM_STATE_MASK) == LTSSM_STATE_L0; > > } > > > > -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) > > +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone) > > { > > u32 val; > > > > /* Disable Link training */ > > - val = readl(ks_pcie->va_app_base + CMD_STATUS); > > + val = readl(keystone->va_app_base + CMD_STATUS); > > val &= ~LTSSM_EN_VAL; > > - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); > > + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); > > > > /* Initiate Link Training */ > > - val = readl(ks_pcie->va_app_base + CMD_STATUS); > > - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); > > + val = readl(keystone->va_app_base + CMD_STATUS); > > + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); > > } > > > > /** > > @@ -502,10 +502,10 @@ void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) > > * and call dw_pcie_v3_65_host_init() API to initialize the Keystone > > * PCI host controller. > > */ > > -int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, > > +int __init ks_dw_pcie_host_init(struct keystone_pcie *keystone, > > struct device_node *msi_intc_np) > > { > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > struct platform_device *pdev = to_platform_device(pp->dev); > > struct resource *res; > > > > @@ -524,19 +524,19 @@ int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, > > > > /* Index 1 is the application reg. space address */ > > res = platform_get_resource(pdev, IORESOURCE_MEM, 1); > > - ks_pcie->va_app_base = devm_ioremap_resource(pp->dev, res); > > - if (IS_ERR(ks_pcie->va_app_base)) > > - return PTR_ERR(ks_pcie->va_app_base); > > + keystone->va_app_base = devm_ioremap_resource(pp->dev, res); > > + if (IS_ERR(keystone->va_app_base)) > > + return PTR_ERR(keystone->va_app_base); > > > > - ks_pcie->app = *res; > > + keystone->app = *res; > > > > /* Create legacy IRQ domain */ > > - ks_pcie->legacy_irq_domain = > > - irq_domain_add_linear(ks_pcie->legacy_intc_np, > > + keystone->legacy_irq_domain = > > + irq_domain_add_linear(keystone->legacy_intc_np, > > MAX_LEGACY_IRQS, > > &ks_dw_pcie_legacy_irq_domain_ops, > > NULL); > > - if (!ks_pcie->legacy_irq_domain) { > > + if (!keystone->legacy_irq_domain) { > > dev_err(pp->dev, "Failed to add irq domain for legacy irqs\n"); > > return -EINVAL; > > } > > diff --git a/drivers/pci/host/pci-keystone.c b/drivers/pci/host/pci-keystone.c > > index 82b461b..55b2be7 100644 > > --- a/drivers/pci/host/pci-keystone.c > > +++ b/drivers/pci/host/pci-keystone.c > > @@ -86,9 +86,9 @@ static void quirk_limit_mrrs(struct pci_dev *dev) > > } > > DECLARE_PCI_FIXUP_ENABLE(PCI_ANY_ID, PCI_ANY_ID, quirk_limit_mrrs); > > > > -static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) > > +static int ks_pcie_establish_link(struct keystone_pcie *keystone) > > { > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > unsigned int retries; > > > > dw_pcie_setup_rc(pp); > > @@ -100,7 +100,7 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) > > > > /* check if the link is up or not */ > > for (retries = 0; retries < 5; retries++) { > > - ks_dw_pcie_initiate_link_train(ks_pcie); > > + ks_dw_pcie_initiate_link_train(keystone); > > if (!dw_pcie_wait_for_link(pp)) > > return 0; > > } > > @@ -112,9 +112,9 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) > > static void ks_pcie_msi_irq_handler(struct irq_desc *desc) > > { > > unsigned int irq = irq_desc_get_irq(desc); > > - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); > > - u32 offset = irq - ks_pcie->msi_host_irqs[0]; > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); > > + u32 offset = irq - keystone->msi_host_irqs[0]; > > + struct pcie_port *pp = &keystone->pp; > > struct irq_chip *chip = irq_desc_get_chip(desc); > > > > dev_dbg(pp->dev, "%s, irq %d\n", __func__, irq); > > @@ -125,7 +125,7 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) > > * ack operation. > > */ > > chained_irq_enter(chip, desc); > > - ks_dw_pcie_handle_msi_irq(ks_pcie, offset); > > + ks_dw_pcie_handle_msi_irq(keystone, offset); > > chained_irq_exit(chip, desc); > > } > > > > @@ -140,9 +140,9 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) > > static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) > > { > > unsigned int irq = irq_desc_get_irq(desc); > > - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); > > - struct pcie_port *pp = &ks_pcie->pp; > > - u32 irq_offset = irq - ks_pcie->legacy_host_irqs[0]; > > + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); > > + struct pcie_port *pp = &keystone->pp; > > + u32 irq_offset = irq - keystone->legacy_host_irqs[0]; > > struct irq_chip *chip = irq_desc_get_chip(desc); > > > > dev_dbg(pp->dev, ": Handling legacy irq %d\n", irq); > > @@ -153,28 +153,28 @@ static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) > > * ack operation. > > */ > > chained_irq_enter(chip, desc); > > - ks_dw_pcie_handle_legacy_irq(ks_pcie, irq_offset); > > + ks_dw_pcie_handle_legacy_irq(keystone, irq_offset); > > chained_irq_exit(chip, desc); > > } > > > > -static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, > > +static int ks_pcie_get_irq_controller_info(struct keystone_pcie *keystone, > > char *controller, int *num_irqs) > > { > > int temp, max_host_irqs, legacy = 1, *host_irqs; > > - struct device *dev = ks_pcie->pp.dev; > > + struct device *dev = keystone->pp.dev; > > struct device_node *np_pcie = dev->of_node, **np_temp; > > > > if (!strcmp(controller, "msi-interrupt-controller")) > > legacy = 0; > > > > if (legacy) { > > - np_temp = &ks_pcie->legacy_intc_np; > > + np_temp = &keystone->legacy_intc_np; > > max_host_irqs = MAX_LEGACY_HOST_IRQS; > > - host_irqs = &ks_pcie->legacy_host_irqs[0]; > > + host_irqs = &keystone->legacy_host_irqs[0]; > > } else { > > - np_temp = &ks_pcie->msi_intc_np; > > + np_temp = &keystone->msi_intc_np; > > max_host_irqs = MAX_MSI_HOST_IRQS; > > - host_irqs = &ks_pcie->msi_host_irqs[0]; > > + host_irqs = &keystone->msi_host_irqs[0]; > > } > > > > /* interrupt controller is in a child node */ > > @@ -212,29 +212,29 @@ static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, > > return -EINVAL; > > } > > > > -static void ks_pcie_setup_interrupts(struct keystone_pcie *ks_pcie) > > +static void ks_pcie_setup_interrupts(struct keystone_pcie *keystone) > > { > > int i; > > > > /* Legacy IRQ */ > > - for (i = 0; i < ks_pcie->num_legacy_host_irqs; i++) { > > - irq_set_chained_handler_and_data(ks_pcie->legacy_host_irqs[i], > > + for (i = 0; i < keystone->num_legacy_host_irqs; i++) { > > + irq_set_chained_handler_and_data(keystone->legacy_host_irqs[i], > > ks_pcie_legacy_irq_handler, > > - ks_pcie); > > + keystone); > > } > > - ks_dw_pcie_enable_legacy_irqs(ks_pcie); > > + ks_dw_pcie_enable_legacy_irqs(keystone); > > > > /* MSI IRQ */ > > if (IS_ENABLED(CONFIG_PCI_MSI)) { > > - for (i = 0; i < ks_pcie->num_msi_host_irqs; i++) { > > - irq_set_chained_handler_and_data(ks_pcie->msi_host_irqs[i], > > + for (i = 0; i < keystone->num_msi_host_irqs; i++) { > > + irq_set_chained_handler_and_data(keystone->msi_host_irqs[i], > > ks_pcie_msi_irq_handler, > > - ks_pcie); > > + keystone); > > } > > } > > > > - if (ks_pcie->error_irq > 0) > > - ks_dw_pcie_enable_error_irq(ks_pcie->va_app_base); > > + if (keystone->error_irq > 0) > > + ks_dw_pcie_enable_error_irq(keystone->va_app_base); > > } > > > > /* > > @@ -259,17 +259,17 @@ static int keystone_pcie_fault(unsigned long addr, unsigned int fsr, > > > > static void __init ks_pcie_host_init(struct pcie_port *pp) > > { > > - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); > > + struct keystone_pcie *keystone = to_keystone_pcie(pp); > > u32 val; > > > > - ks_pcie_establish_link(ks_pcie); > > - ks_dw_pcie_setup_rc_app_regs(ks_pcie); > > - ks_pcie_setup_interrupts(ks_pcie); > > + ks_pcie_establish_link(keystone); > > + ks_dw_pcie_setup_rc_app_regs(keystone); > > + ks_pcie_setup_interrupts(keystone); > > writew(PCI_IO_RANGE_TYPE_32 | (PCI_IO_RANGE_TYPE_32 << 8), > > pp->dbi_base + PCI_IO_BASE); > > > > /* update the Vendor ID */ > > - writew(ks_pcie->device_id, pp->dbi_base + PCI_DEVICE_ID); > > + writew(keystone->device_id, pp->dbi_base + PCI_DEVICE_ID); > > > > /* update the DEV_STAT_CTRL to publish right mrrs */ > > val = readl(pp->dbi_base + PCIE_CAP_BASE + PCI_EXP_DEVCTL); > > @@ -300,28 +300,28 @@ static struct pcie_host_ops keystone_pcie_host_ops = { > > > > static irqreturn_t pcie_err_irq_handler(int irq, void *priv) > > { > > - struct keystone_pcie *ks_pcie = priv; > > + struct keystone_pcie *keystone = priv; > > > > - return ks_dw_pcie_handle_error_irq(ks_pcie->pp.dev, > > - ks_pcie->va_app_base); > > + return ks_dw_pcie_handle_error_irq(keystone->pp.dev, > > + keystone->va_app_base); > > } > > > > -static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, > > +static int __init ks_add_pcie_port(struct keystone_pcie *keystone, > > struct platform_device *pdev) > > { > > - struct pcie_port *pp = &ks_pcie->pp; > > + struct pcie_port *pp = &keystone->pp; > > int ret; > > > > - ret = ks_pcie_get_irq_controller_info(ks_pcie, > > + ret = ks_pcie_get_irq_controller_info(keystone, > > "legacy-interrupt-controller", > > - &ks_pcie->num_legacy_host_irqs); > > + &keystone->num_legacy_host_irqs); > > if (ret) > > return ret; > > > > if (IS_ENABLED(CONFIG_PCI_MSI)) { > > - ret = ks_pcie_get_irq_controller_info(ks_pcie, > > + ret = ks_pcie_get_irq_controller_info(keystone, > > "msi-interrupt-controller", > > - &ks_pcie->num_msi_host_irqs); > > + &keystone->num_msi_host_irqs); > > if (ret) > > return ret; > > } > > @@ -330,22 +330,22 @@ static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, > > * Index 0 is the platform interrupt for error interrupt > > * from RC. This is optional. > > */ > > - ks_pcie->error_irq = irq_of_parse_and_map(ks_pcie->np, 0); > > - if (ks_pcie->error_irq <= 0) > > + keystone->error_irq = irq_of_parse_and_map(keystone->np, 0); > > + if (keystone->error_irq <= 0) > > dev_info(&pdev->dev, "no error IRQ defined\n"); > > else { > > - ret = request_irq(ks_pcie->error_irq, pcie_err_irq_handler, > > - IRQF_SHARED, "pcie-error-irq", ks_pcie); > > + ret = request_irq(keystone->error_irq, pcie_err_irq_handler, > > + IRQF_SHARED, "pcie-error-irq", keystone); > > if (ret < 0) { > > dev_err(&pdev->dev, "failed to request error IRQ %d\n", > > - ks_pcie->error_irq); > > + keystone->error_irq); > > return ret; > > } > > } > > > > pp->root_bus_nr = -1; > > pp->ops = &keystone_pcie_host_ops; > > - ret = ks_dw_pcie_host_init(ks_pcie, ks_pcie->msi_intc_np); > > + ret = ks_dw_pcie_host_init(keystone, keystone->msi_intc_np); > > if (ret) { > > dev_err(&pdev->dev, "failed to initialize host\n"); > > return ret; > > @@ -364,9 +364,9 @@ static const struct of_device_id ks_pcie_of_match[] = { > > > > static int __exit ks_pcie_remove(struct platform_device *pdev) > > { > > - struct keystone_pcie *ks_pcie = platform_get_drvdata(pdev); > > + struct keystone_pcie *keystone = platform_get_drvdata(pdev); > > > > - clk_disable_unprepare(ks_pcie->clk); > > + clk_disable_unprepare(keystone->clk); > > > > return 0; > > } > > @@ -374,19 +374,18 @@ static int __exit ks_pcie_remove(struct platform_device *pdev) > > static int __init ks_pcie_probe(struct platform_device *pdev) > > { > > struct device *dev = &pdev->dev; > > - struct keystone_pcie *ks_pcie; > > + struct keystone_pcie *keystone; > > struct pcie_port *pp; > > struct resource *res; > > void __iomem *reg_p; > > struct phy *phy; > > int ret; > > > > - ks_pcie = devm_kzalloc(&pdev->dev, sizeof(*ks_pcie), > > - GFP_KERNEL); > > - if (!ks_pcie) > > + keystone = devm_kzalloc(&pdev->dev, sizeof(*keystone), GFP_KERNEL); > > + if (!keystone) > > return -ENOMEM; > > > > - pp = &ks_pcie->pp; > > + pp = &keystone->pp; > > > > /* initialize SerDes Phy if present */ > > phy = devm_phy_get(dev, "pcie-phy"); > > @@ -404,29 +403,29 @@ static int __init ks_pcie_probe(struct platform_device *pdev) > > reg_p = devm_ioremap_resource(dev, res); > > if (IS_ERR(reg_p)) > > return PTR_ERR(reg_p); > > - ks_pcie->device_id = readl(reg_p) >> 16; > > + keystone->device_id = readl(reg_p) >> 16; > > devm_iounmap(dev, reg_p); > > devm_release_mem_region(dev, res->start, resource_size(res)); > > > > pp->dev = dev; > > - ks_pcie->np = dev->of_node; > > - platform_set_drvdata(pdev, ks_pcie); > > - ks_pcie->clk = devm_clk_get(dev, "pcie"); > > - if (IS_ERR(ks_pcie->clk)) { > > + keystone->np = dev->of_node; > > + platform_set_drvdata(pdev, keystone); > > + keystone->clk = devm_clk_get(dev, "pcie"); > > + if (IS_ERR(keystone->clk)) { > > dev_err(dev, "Failed to get pcie rc clock\n"); > > - return PTR_ERR(ks_pcie->clk); > > + return PTR_ERR(keystone->clk); > > } > > - ret = clk_prepare_enable(ks_pcie->clk); > > + ret = clk_prepare_enable(keystone->clk); > > if (ret) > > return ret; > > > > - ret = ks_add_pcie_port(ks_pcie, pdev); > > + ret = ks_add_pcie_port(keystone, pdev); > > if (ret < 0) > > goto fail_clk; > > > > return 0; > > fail_clk: > > - clk_disable_unprepare(ks_pcie->clk); > > + clk_disable_unprepare(keystone->clk); > > > > return ret; > > } > > diff --git a/drivers/pci/host/pci-keystone.h b/drivers/pci/host/pci-keystone.h > > index a5b0cb2..379213c 100644 > > --- a/drivers/pci/host/pci-keystone.h > > +++ b/drivers/pci/host/pci-keystone.h > > @@ -39,24 +39,24 @@ struct keystone_pcie { > > }; > > > > /* Keystone DW specific MSI controller APIs/definitions */ > > -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset); > > +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset); > > phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp); > > > > /* Keystone specific PCI controller APIs */ > > -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie); > > -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset); > > +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone); > > +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset); > > void ks_dw_pcie_enable_error_irq(void __iomem *reg_base); > > irqreturn_t ks_dw_pcie_handle_error_irq(struct device *dev, > > void __iomem *reg_base); > > -int ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, > > +int ks_dw_pcie_host_init(struct keystone_pcie *keystone, > > struct device_node *msi_intc_np); > > int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, > > unsigned int devfn, int where, int size, u32 val); > > int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, > > unsigned int devfn, int where, int size, u32 *val); > > -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie); > > +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone); > > int ks_dw_pcie_link_up(struct pcie_port *pp); > > -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie); > > +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone); > > void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq); > > void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq); > > void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp); > > > > > -- > Murali Karicheri > Linux Kernel, Keystone > -- > To unsubscribe from this list: send the line "unsubscribe linux-pci" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/drivers/pci/host/pci-keystone-dw.c b/drivers/pci/host/pci-keystone-dw.c index 4151509..d09e3c6 100644 --- a/drivers/pci/host/pci-keystone-dw.c +++ b/drivers/pci/host/pci-keystone-dw.c @@ -83,18 +83,18 @@ static inline void update_reg_offset_bit_pos(u32 offset, u32 *reg_offset, phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp) { - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); - return ks_pcie->app.start + MSI_IRQ; + return keystone->app.start + MSI_IRQ; } -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset) { - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; u32 pending, vector; int src, virq; - pending = readl(ks_pcie->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); + pending = readl(keystone->va_app_base + MSI0_IRQ_STATUS + (offset << 4)); /* * MSI0 status bit 0-3 shows vectors 0, 8, 16, 24, MSI1 status bit @@ -114,51 +114,51 @@ void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset) static void ks_dw_pcie_msi_irq_ack(struct irq_data *d) { u32 offset, reg_offset, bit_pos; - struct keystone_pcie *ks_pcie; + struct keystone_pcie *keystone; struct msi_desc *msi; struct pcie_port *pp; msi = irq_data_get_msi_desc(d); pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); - ks_pcie = to_keystone_pcie(pp); + keystone = to_keystone_pcie(pp); offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); update_reg_offset_bit_pos(offset, ®_offset, &bit_pos); writel(BIT(bit_pos), - ks_pcie->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); - writel(reg_offset + MSI_IRQ_OFFSET, ks_pcie->va_app_base + IRQ_EOI); + keystone->va_app_base + MSI0_IRQ_STATUS + (reg_offset << 4)); + writel(reg_offset + MSI_IRQ_OFFSET, keystone->va_app_base + IRQ_EOI); } void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq) { u32 reg_offset, bit_pos; - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); writel(BIT(bit_pos), - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); + keystone->va_app_base + MSI0_IRQ_ENABLE_SET + (reg_offset << 4)); } void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq) { u32 reg_offset, bit_pos; - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); update_reg_offset_bit_pos(irq, ®_offset, &bit_pos); writel(BIT(bit_pos), - ks_pcie->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); + keystone->va_app_base + MSI0_IRQ_ENABLE_CLR + (reg_offset << 4)); } static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) { - struct keystone_pcie *ks_pcie; + struct keystone_pcie *keystone; struct msi_desc *msi; struct pcie_port *pp; u32 offset; msi = irq_data_get_msi_desc(d); pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); - ks_pcie = to_keystone_pcie(pp); + keystone = to_keystone_pcie(pp); offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); /* Mask the end point if PVM implemented */ @@ -172,14 +172,14 @@ static void ks_dw_pcie_msi_irq_mask(struct irq_data *d) static void ks_dw_pcie_msi_irq_unmask(struct irq_data *d) { - struct keystone_pcie *ks_pcie; + struct keystone_pcie *keystone; struct msi_desc *msi; struct pcie_port *pp; u32 offset; msi = irq_data_get_msi_desc(d); pp = (struct pcie_port *) msi_desc_to_pci_sysdata(msi); - ks_pcie = to_keystone_pcie(pp); + keystone = to_keystone_pcie(pp); offset = d->irq - irq_linear_revmap(pp->irq_domain, 0); /* Mask the end point if PVM implemented */ @@ -214,10 +214,10 @@ static const struct irq_domain_ops ks_dw_pcie_msi_domain_ops = { int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) { - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); int i; - pp->irq_domain = irq_domain_add_linear(ks_pcie->msi_intc_np, + pp->irq_domain = irq_domain_add_linear(keystone->msi_intc_np, MAX_MSI_IRQS, &ks_dw_pcie_msi_domain_ops, chip); @@ -232,31 +232,31 @@ int ks_dw_pcie_msi_host_init(struct pcie_port *pp, struct msi_controller *chip) return 0; } -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie) +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone) { int i; for (i = 0; i < MAX_LEGACY_IRQS; i++) - writel(0x1, ks_pcie->va_app_base + IRQ_ENABLE_SET + (i << 4)); + writel(0x1, keystone->va_app_base + IRQ_ENABLE_SET + (i << 4)); } -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset) +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset) { - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; u32 pending; int virq; - pending = readl(ks_pcie->va_app_base + IRQ_STATUS + (offset << 4)); + pending = readl(keystone->va_app_base + IRQ_STATUS + (offset << 4)); if (BIT(0) & pending) { - virq = irq_linear_revmap(ks_pcie->legacy_irq_domain, offset); + virq = irq_linear_revmap(keystone->legacy_irq_domain, offset); dev_dbg(pp->dev, ": irq: irq_offset %d, virq %d\n", offset, virq); generic_handle_irq(virq); } /* EOI the INTx interrupt */ - writel(offset, ks_pcie->va_app_base + IRQ_EOI); + writel(offset, keystone->va_app_base + IRQ_EOI); } void ks_dw_pcie_enable_error_irq(void __iomem *reg_base) @@ -352,39 +352,39 @@ static void ks_dw_pcie_clear_dbi_mode(void __iomem *reg_virt) } while (val & DBI_CS2_EN_VAL); } -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone) { - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; u32 start = pp->mem->start, end = pp->mem->end; int i, tr_size; /* Disable BARs for inbound access */ - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); writel(0, pp->dbi_base + PCI_BASE_ADDRESS_0); writel(0, pp->dbi_base + PCI_BASE_ADDRESS_1); - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); /* Set outbound translation size per window division */ - writel(CFG_PCIM_WIN_SZ_IDX & 0x7, ks_pcie->va_app_base + OB_SIZE); + writel(CFG_PCIM_WIN_SZ_IDX & 0x7, keystone->va_app_base + OB_SIZE); tr_size = (1 << (CFG_PCIM_WIN_SZ_IDX & 0x7)) * SZ_1M; /* Using Direct 1:1 mapping of RC <-> PCI memory space */ for (i = 0; (i < CFG_PCIM_WIN_CNT) && (start < end); i++) { - writel(start | 1, ks_pcie->va_app_base + OB_OFFSET_INDEX(i)); - writel(0, ks_pcie->va_app_base + OB_OFFSET_HI(i)); + writel(start | 1, keystone->va_app_base + OB_OFFSET_INDEX(i)); + writel(0, keystone->va_app_base + OB_OFFSET_HI(i)); start += tr_size; } /* Enable OB translation */ - writel(OB_XLAT_EN_VAL | readl(ks_pcie->va_app_base + CMD_STATUS), - ks_pcie->va_app_base + CMD_STATUS); + writel(OB_XLAT_EN_VAL | readl(keystone->va_app_base + CMD_STATUS), + keystone->va_app_base + CMD_STATUS); } /** * ks_pcie_cfg_setup() - Set up configuration space address for a device * - * @ks_pcie: ptr to keystone_pcie structure + * @keystone: ptr to keystone_pcie structure * @bus: Bus number the device is residing on * @devfn: device, function number info * @@ -398,11 +398,11 @@ void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie) * we will do TYPE 0 access as it will be on our secondary bus (logical). * CFG_SETUP is needed only for remote configuration access. */ -static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, +static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *keystone, u8 bus, unsigned int devfn) { u8 device = PCI_SLOT(devfn), function = PCI_FUNC(devfn); - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; u32 regval; if (bus == 0) @@ -418,18 +418,18 @@ static void __iomem *ks_pcie_cfg_setup(struct keystone_pcie *ks_pcie, u8 bus, if (bus != 1) regval |= BIT(24); - writel(regval, ks_pcie->va_app_base + CFG_SETUP); + writel(regval, keystone->va_app_base + CFG_SETUP); return pp->va_cfg0_base; } int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, unsigned int devfn, int where, int size, u32 *val) { - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); u8 bus_num = bus->number; void __iomem *addr; - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); return dw_pcie_cfg_read(addr + where, size, val); } @@ -437,11 +437,11 @@ int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, unsigned int devfn, int where, int size, u32 val) { - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); u8 bus_num = bus->number; void __iomem *addr; - addr = ks_pcie_cfg_setup(ks_pcie, bus_num, devfn); + addr = ks_pcie_cfg_setup(keystone, bus_num, devfn); return dw_pcie_cfg_write(addr + where, size, val); } @@ -453,22 +453,22 @@ int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, */ void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp) { - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); /* Configure and set up BAR0 */ - ks_dw_pcie_set_dbi_mode(ks_pcie->va_app_base); + ks_dw_pcie_set_dbi_mode(keystone->va_app_base); /* Enable BAR0 */ writel(1, pp->dbi_base + PCI_BASE_ADDRESS_0); writel(SZ_4K - 1, pp->dbi_base + PCI_BASE_ADDRESS_0); - ks_dw_pcie_clear_dbi_mode(ks_pcie->va_app_base); + ks_dw_pcie_clear_dbi_mode(keystone->va_app_base); /* * For BAR0, just setting bus address for inbound writes (MSI) should * be sufficient. Use physical address to avoid any conflicts. */ - writel(ks_pcie->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); + writel(keystone->app.start, pp->dbi_base + PCI_BASE_ADDRESS_0); } /** @@ -481,18 +481,18 @@ int ks_dw_pcie_link_up(struct pcie_port *pp) return (val & LTSSM_STATE_MASK) == LTSSM_STATE_L0; } -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone) { u32 val; /* Disable Link training */ - val = readl(ks_pcie->va_app_base + CMD_STATUS); + val = readl(keystone->va_app_base + CMD_STATUS); val &= ~LTSSM_EN_VAL; - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); /* Initiate Link Training */ - val = readl(ks_pcie->va_app_base + CMD_STATUS); - writel(LTSSM_EN_VAL | val, ks_pcie->va_app_base + CMD_STATUS); + val = readl(keystone->va_app_base + CMD_STATUS); + writel(LTSSM_EN_VAL | val, keystone->va_app_base + CMD_STATUS); } /** @@ -502,10 +502,10 @@ void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie) * and call dw_pcie_v3_65_host_init() API to initialize the Keystone * PCI host controller. */ -int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, +int __init ks_dw_pcie_host_init(struct keystone_pcie *keystone, struct device_node *msi_intc_np) { - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; struct platform_device *pdev = to_platform_device(pp->dev); struct resource *res; @@ -524,19 +524,19 @@ int __init ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, /* Index 1 is the application reg. space address */ res = platform_get_resource(pdev, IORESOURCE_MEM, 1); - ks_pcie->va_app_base = devm_ioremap_resource(pp->dev, res); - if (IS_ERR(ks_pcie->va_app_base)) - return PTR_ERR(ks_pcie->va_app_base); + keystone->va_app_base = devm_ioremap_resource(pp->dev, res); + if (IS_ERR(keystone->va_app_base)) + return PTR_ERR(keystone->va_app_base); - ks_pcie->app = *res; + keystone->app = *res; /* Create legacy IRQ domain */ - ks_pcie->legacy_irq_domain = - irq_domain_add_linear(ks_pcie->legacy_intc_np, + keystone->legacy_irq_domain = + irq_domain_add_linear(keystone->legacy_intc_np, MAX_LEGACY_IRQS, &ks_dw_pcie_legacy_irq_domain_ops, NULL); - if (!ks_pcie->legacy_irq_domain) { + if (!keystone->legacy_irq_domain) { dev_err(pp->dev, "Failed to add irq domain for legacy irqs\n"); return -EINVAL; } diff --git a/drivers/pci/host/pci-keystone.c b/drivers/pci/host/pci-keystone.c index 82b461b..55b2be7 100644 --- a/drivers/pci/host/pci-keystone.c +++ b/drivers/pci/host/pci-keystone.c @@ -86,9 +86,9 @@ static void quirk_limit_mrrs(struct pci_dev *dev) } DECLARE_PCI_FIXUP_ENABLE(PCI_ANY_ID, PCI_ANY_ID, quirk_limit_mrrs); -static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) +static int ks_pcie_establish_link(struct keystone_pcie *keystone) { - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; unsigned int retries; dw_pcie_setup_rc(pp); @@ -100,7 +100,7 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) /* check if the link is up or not */ for (retries = 0; retries < 5; retries++) { - ks_dw_pcie_initiate_link_train(ks_pcie); + ks_dw_pcie_initiate_link_train(keystone); if (!dw_pcie_wait_for_link(pp)) return 0; } @@ -112,9 +112,9 @@ static int ks_pcie_establish_link(struct keystone_pcie *ks_pcie) static void ks_pcie_msi_irq_handler(struct irq_desc *desc) { unsigned int irq = irq_desc_get_irq(desc); - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); - u32 offset = irq - ks_pcie->msi_host_irqs[0]; - struct pcie_port *pp = &ks_pcie->pp; + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); + u32 offset = irq - keystone->msi_host_irqs[0]; + struct pcie_port *pp = &keystone->pp; struct irq_chip *chip = irq_desc_get_chip(desc); dev_dbg(pp->dev, "%s, irq %d\n", __func__, irq); @@ -125,7 +125,7 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) * ack operation. */ chained_irq_enter(chip, desc); - ks_dw_pcie_handle_msi_irq(ks_pcie, offset); + ks_dw_pcie_handle_msi_irq(keystone, offset); chained_irq_exit(chip, desc); } @@ -140,9 +140,9 @@ static void ks_pcie_msi_irq_handler(struct irq_desc *desc) static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) { unsigned int irq = irq_desc_get_irq(desc); - struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); - struct pcie_port *pp = &ks_pcie->pp; - u32 irq_offset = irq - ks_pcie->legacy_host_irqs[0]; + struct keystone_pcie *keystone = irq_desc_get_handler_data(desc); + struct pcie_port *pp = &keystone->pp; + u32 irq_offset = irq - keystone->legacy_host_irqs[0]; struct irq_chip *chip = irq_desc_get_chip(desc); dev_dbg(pp->dev, ": Handling legacy irq %d\n", irq); @@ -153,28 +153,28 @@ static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) * ack operation. */ chained_irq_enter(chip, desc); - ks_dw_pcie_handle_legacy_irq(ks_pcie, irq_offset); + ks_dw_pcie_handle_legacy_irq(keystone, irq_offset); chained_irq_exit(chip, desc); } -static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, +static int ks_pcie_get_irq_controller_info(struct keystone_pcie *keystone, char *controller, int *num_irqs) { int temp, max_host_irqs, legacy = 1, *host_irqs; - struct device *dev = ks_pcie->pp.dev; + struct device *dev = keystone->pp.dev; struct device_node *np_pcie = dev->of_node, **np_temp; if (!strcmp(controller, "msi-interrupt-controller")) legacy = 0; if (legacy) { - np_temp = &ks_pcie->legacy_intc_np; + np_temp = &keystone->legacy_intc_np; max_host_irqs = MAX_LEGACY_HOST_IRQS; - host_irqs = &ks_pcie->legacy_host_irqs[0]; + host_irqs = &keystone->legacy_host_irqs[0]; } else { - np_temp = &ks_pcie->msi_intc_np; + np_temp = &keystone->msi_intc_np; max_host_irqs = MAX_MSI_HOST_IRQS; - host_irqs = &ks_pcie->msi_host_irqs[0]; + host_irqs = &keystone->msi_host_irqs[0]; } /* interrupt controller is in a child node */ @@ -212,29 +212,29 @@ static int ks_pcie_get_irq_controller_info(struct keystone_pcie *ks_pcie, return -EINVAL; } -static void ks_pcie_setup_interrupts(struct keystone_pcie *ks_pcie) +static void ks_pcie_setup_interrupts(struct keystone_pcie *keystone) { int i; /* Legacy IRQ */ - for (i = 0; i < ks_pcie->num_legacy_host_irqs; i++) { - irq_set_chained_handler_and_data(ks_pcie->legacy_host_irqs[i], + for (i = 0; i < keystone->num_legacy_host_irqs; i++) { + irq_set_chained_handler_and_data(keystone->legacy_host_irqs[i], ks_pcie_legacy_irq_handler, - ks_pcie); + keystone); } - ks_dw_pcie_enable_legacy_irqs(ks_pcie); + ks_dw_pcie_enable_legacy_irqs(keystone); /* MSI IRQ */ if (IS_ENABLED(CONFIG_PCI_MSI)) { - for (i = 0; i < ks_pcie->num_msi_host_irqs; i++) { - irq_set_chained_handler_and_data(ks_pcie->msi_host_irqs[i], + for (i = 0; i < keystone->num_msi_host_irqs; i++) { + irq_set_chained_handler_and_data(keystone->msi_host_irqs[i], ks_pcie_msi_irq_handler, - ks_pcie); + keystone); } } - if (ks_pcie->error_irq > 0) - ks_dw_pcie_enable_error_irq(ks_pcie->va_app_base); + if (keystone->error_irq > 0) + ks_dw_pcie_enable_error_irq(keystone->va_app_base); } /* @@ -259,17 +259,17 @@ static int keystone_pcie_fault(unsigned long addr, unsigned int fsr, static void __init ks_pcie_host_init(struct pcie_port *pp) { - struct keystone_pcie *ks_pcie = to_keystone_pcie(pp); + struct keystone_pcie *keystone = to_keystone_pcie(pp); u32 val; - ks_pcie_establish_link(ks_pcie); - ks_dw_pcie_setup_rc_app_regs(ks_pcie); - ks_pcie_setup_interrupts(ks_pcie); + ks_pcie_establish_link(keystone); + ks_dw_pcie_setup_rc_app_regs(keystone); + ks_pcie_setup_interrupts(keystone); writew(PCI_IO_RANGE_TYPE_32 | (PCI_IO_RANGE_TYPE_32 << 8), pp->dbi_base + PCI_IO_BASE); /* update the Vendor ID */ - writew(ks_pcie->device_id, pp->dbi_base + PCI_DEVICE_ID); + writew(keystone->device_id, pp->dbi_base + PCI_DEVICE_ID); /* update the DEV_STAT_CTRL to publish right mrrs */ val = readl(pp->dbi_base + PCIE_CAP_BASE + PCI_EXP_DEVCTL); @@ -300,28 +300,28 @@ static struct pcie_host_ops keystone_pcie_host_ops = { static irqreturn_t pcie_err_irq_handler(int irq, void *priv) { - struct keystone_pcie *ks_pcie = priv; + struct keystone_pcie *keystone = priv; - return ks_dw_pcie_handle_error_irq(ks_pcie->pp.dev, - ks_pcie->va_app_base); + return ks_dw_pcie_handle_error_irq(keystone->pp.dev, + keystone->va_app_base); } -static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, +static int __init ks_add_pcie_port(struct keystone_pcie *keystone, struct platform_device *pdev) { - struct pcie_port *pp = &ks_pcie->pp; + struct pcie_port *pp = &keystone->pp; int ret; - ret = ks_pcie_get_irq_controller_info(ks_pcie, + ret = ks_pcie_get_irq_controller_info(keystone, "legacy-interrupt-controller", - &ks_pcie->num_legacy_host_irqs); + &keystone->num_legacy_host_irqs); if (ret) return ret; if (IS_ENABLED(CONFIG_PCI_MSI)) { - ret = ks_pcie_get_irq_controller_info(ks_pcie, + ret = ks_pcie_get_irq_controller_info(keystone, "msi-interrupt-controller", - &ks_pcie->num_msi_host_irqs); + &keystone->num_msi_host_irqs); if (ret) return ret; } @@ -330,22 +330,22 @@ static int __init ks_add_pcie_port(struct keystone_pcie *ks_pcie, * Index 0 is the platform interrupt for error interrupt * from RC. This is optional. */ - ks_pcie->error_irq = irq_of_parse_and_map(ks_pcie->np, 0); - if (ks_pcie->error_irq <= 0) + keystone->error_irq = irq_of_parse_and_map(keystone->np, 0); + if (keystone->error_irq <= 0) dev_info(&pdev->dev, "no error IRQ defined\n"); else { - ret = request_irq(ks_pcie->error_irq, pcie_err_irq_handler, - IRQF_SHARED, "pcie-error-irq", ks_pcie); + ret = request_irq(keystone->error_irq, pcie_err_irq_handler, + IRQF_SHARED, "pcie-error-irq", keystone); if (ret < 0) { dev_err(&pdev->dev, "failed to request error IRQ %d\n", - ks_pcie->error_irq); + keystone->error_irq); return ret; } } pp->root_bus_nr = -1; pp->ops = &keystone_pcie_host_ops; - ret = ks_dw_pcie_host_init(ks_pcie, ks_pcie->msi_intc_np); + ret = ks_dw_pcie_host_init(keystone, keystone->msi_intc_np); if (ret) { dev_err(&pdev->dev, "failed to initialize host\n"); return ret; @@ -364,9 +364,9 @@ static const struct of_device_id ks_pcie_of_match[] = { static int __exit ks_pcie_remove(struct platform_device *pdev) { - struct keystone_pcie *ks_pcie = platform_get_drvdata(pdev); + struct keystone_pcie *keystone = platform_get_drvdata(pdev); - clk_disable_unprepare(ks_pcie->clk); + clk_disable_unprepare(keystone->clk); return 0; } @@ -374,19 +374,18 @@ static int __exit ks_pcie_remove(struct platform_device *pdev) static int __init ks_pcie_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; - struct keystone_pcie *ks_pcie; + struct keystone_pcie *keystone; struct pcie_port *pp; struct resource *res; void __iomem *reg_p; struct phy *phy; int ret; - ks_pcie = devm_kzalloc(&pdev->dev, sizeof(*ks_pcie), - GFP_KERNEL); - if (!ks_pcie) + keystone = devm_kzalloc(&pdev->dev, sizeof(*keystone), GFP_KERNEL); + if (!keystone) return -ENOMEM; - pp = &ks_pcie->pp; + pp = &keystone->pp; /* initialize SerDes Phy if present */ phy = devm_phy_get(dev, "pcie-phy"); @@ -404,29 +403,29 @@ static int __init ks_pcie_probe(struct platform_device *pdev) reg_p = devm_ioremap_resource(dev, res); if (IS_ERR(reg_p)) return PTR_ERR(reg_p); - ks_pcie->device_id = readl(reg_p) >> 16; + keystone->device_id = readl(reg_p) >> 16; devm_iounmap(dev, reg_p); devm_release_mem_region(dev, res->start, resource_size(res)); pp->dev = dev; - ks_pcie->np = dev->of_node; - platform_set_drvdata(pdev, ks_pcie); - ks_pcie->clk = devm_clk_get(dev, "pcie"); - if (IS_ERR(ks_pcie->clk)) { + keystone->np = dev->of_node; + platform_set_drvdata(pdev, keystone); + keystone->clk = devm_clk_get(dev, "pcie"); + if (IS_ERR(keystone->clk)) { dev_err(dev, "Failed to get pcie rc clock\n"); - return PTR_ERR(ks_pcie->clk); + return PTR_ERR(keystone->clk); } - ret = clk_prepare_enable(ks_pcie->clk); + ret = clk_prepare_enable(keystone->clk); if (ret) return ret; - ret = ks_add_pcie_port(ks_pcie, pdev); + ret = ks_add_pcie_port(keystone, pdev); if (ret < 0) goto fail_clk; return 0; fail_clk: - clk_disable_unprepare(ks_pcie->clk); + clk_disable_unprepare(keystone->clk); return ret; } diff --git a/drivers/pci/host/pci-keystone.h b/drivers/pci/host/pci-keystone.h index a5b0cb2..379213c 100644 --- a/drivers/pci/host/pci-keystone.h +++ b/drivers/pci/host/pci-keystone.h @@ -39,24 +39,24 @@ struct keystone_pcie { }; /* Keystone DW specific MSI controller APIs/definitions */ -void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *ks_pcie, int offset); +void ks_dw_pcie_handle_msi_irq(struct keystone_pcie *keystone, int offset); phys_addr_t ks_dw_pcie_get_msi_addr(struct pcie_port *pp); /* Keystone specific PCI controller APIs */ -void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *ks_pcie); -void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, int offset); +void ks_dw_pcie_enable_legacy_irqs(struct keystone_pcie *keystone); +void ks_dw_pcie_handle_legacy_irq(struct keystone_pcie *keystone, int offset); void ks_dw_pcie_enable_error_irq(void __iomem *reg_base); irqreturn_t ks_dw_pcie_handle_error_irq(struct device *dev, void __iomem *reg_base); -int ks_dw_pcie_host_init(struct keystone_pcie *ks_pcie, +int ks_dw_pcie_host_init(struct keystone_pcie *keystone, struct device_node *msi_intc_np); int ks_dw_pcie_wr_other_conf(struct pcie_port *pp, struct pci_bus *bus, unsigned int devfn, int where, int size, u32 val); int ks_dw_pcie_rd_other_conf(struct pcie_port *pp, struct pci_bus *bus, unsigned int devfn, int where, int size, u32 *val); -void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *ks_pcie); +void ks_dw_pcie_setup_rc_app_regs(struct keystone_pcie *keystone); int ks_dw_pcie_link_up(struct pcie_port *pp); -void ks_dw_pcie_initiate_link_train(struct keystone_pcie *ks_pcie); +void ks_dw_pcie_initiate_link_train(struct keystone_pcie *keystone); void ks_dw_pcie_msi_set_irq(struct pcie_port *pp, int irq); void ks_dw_pcie_msi_clear_irq(struct pcie_port *pp, int irq); void ks_dw_pcie_v3_65_scan_bus(struct pcie_port *pp);
Use a device-specific name, "keystone", for struct keystone_pcie pointers to hint that this is device-specific information. No functional change intended. Signed-off-by: Bjorn Helgaas <bhelgaas@google.com> --- drivers/pci/host/pci-keystone-dw.c | 122 ++++++++++++++++++----------------- drivers/pci/host/pci-keystone.c | 125 ++++++++++++++++++------------------ drivers/pci/host/pci-keystone.h | 12 ++- 3 files changed, 129 insertions(+), 130 deletions(-) -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html