x86/PCI: MMCONFIG: add PCI_MMCFG_BUS_OFFSET() to factor common expression
authorBjorn Helgaas <bjorn.helgaas@hp.com>
Sat, 14 Nov 2009 00:34:08 +0000 (17:34 -0700)
committerJesse Barnes <jbarnes@virtuousgeek.org>
Tue, 24 Nov 2009 23:29:11 +0000 (15:29 -0800)
This factors out the common "bus << 20" expression used when computing the
MMCONFIG address.

Reviewed-by: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Bjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
arch/x86/include/asm/pci_x86.h
arch/x86/pci/mmconfig-shared.c
arch/x86/pci/mmconfig_32.c
arch/x86/pci/mmconfig_64.c

index b399988eee3a3105e60be5fe760089d6cf57d3f0..7d94a235ec82d37a8eaaa61c726740038162ddfd 100644 (file)
@@ -124,6 +124,8 @@ extern void __init pci_mmcfg_arch_free(void);
 extern struct acpi_mcfg_allocation *pci_mmcfg_config;
 extern int pci_mmcfg_config_num;
 
+#define PCI_MMCFG_BUS_OFFSET(bus)      ((bus) << 20)
+
 /*
  * AMD Fam10h CPUs are buggy, and cannot access MMIO config space
  * on their northbrige except through the * %eax register. As such, you MUST
index 067a2cfed15c09d60063b1cdbd10d0039f723968..4820f0e8c594eb2c0900c2d165883cf5e3d58c66 100644 (file)
@@ -355,8 +355,9 @@ static void __init pci_mmcfg_insert_resources(void)
                snprintf(names, PCI_MMCFG_RESOURCE_NAME_LEN,
                         "PCI MMCONFIG %u [%02x-%02x]", cfg->pci_segment,
                         cfg->start_bus_number, cfg->end_bus_number);
-               res->start = cfg->address + (cfg->start_bus_number << 20);
-               res->end = res->start + (num_buses << 20) - 1;
+               res->start = cfg->address +
+                       PCI_MMCFG_BUS_OFFSET(cfg->start_bus_number);
+               res->end = res->start + PCI_MMCFG_BUS_OFFSET(num_buses) - 1;
                res->flags = IORESOURCE_MEM | IORESOURCE_BUSY;
                insert_resource(&iomem_resource, res);
                names += PCI_MMCFG_RESOURCE_NAME_LEN;
@@ -478,15 +479,14 @@ static void __init pci_mmcfg_reject_broken(int early)
                return;
 
        for (i = 0; i < pci_mmcfg_config_num; i++) {
-               int valid = 0;
+               int num_buses, valid = 0;
                u64 addr, size;
 
                cfg = &pci_mmcfg_config[i];
-               addr = cfg->start_bus_number;
-               addr <<= 20;
-               addr += cfg->address;
-               size = cfg->end_bus_number + 1 - cfg->start_bus_number;
-               size <<= 20;
+               addr = cfg->address +
+                       PCI_MMCFG_BUS_OFFSET(cfg->start_bus_number);
+               num_buses = cfg->end_bus_number - cfg->start_bus_number + 1;
+               size = PCI_MMCFG_BUS_OFFSET(num_buses);
                printk(KERN_NOTICE "PCI: MCFG configuration %d: base %lx "
                       "segment %hu buses %u - %u\n",
                       i, (unsigned long)cfg->address, cfg->pci_segment,
index f10a7e94a84c51d9b87a041a19b3c7b89b283d8b..8c19df89ad750768637a457f2262fcc2159be0e8 100644 (file)
@@ -47,7 +47,7 @@ static u32 get_base_addr(unsigned int seg, int bus, unsigned devfn)
  */
 static void pci_exp_set_dev_base(unsigned int base, int bus, int devfn)
 {
-       u32 dev_base = base | (bus << 20) | (devfn << 12);
+       u32 dev_base = base | PCI_MMCFG_BUS_OFFSET(bus) | (devfn << 12);
        int cpu = smp_processor_id();
        if (dev_base != mmcfg_last_accessed_device ||
            cpu != mmcfg_last_accessed_cpu) {
index 94349f8b2f964b969f7cc576ad92a50cfac75049..8588711924ccb3a06be2649bb50628c58d5300ac 100644 (file)
@@ -43,7 +43,7 @@ static char __iomem *pci_dev_base(unsigned int seg, unsigned int bus, unsigned i
        addr = get_virt(seg, bus);
        if (!addr)
                return NULL;
-       return addr + ((bus << 20) | (devfn << 12));
+       return addr + (PCI_MMCFG_BUS_OFFSET(bus) | (devfn << 12));
 }
 
 static int pci_mmcfg_read(unsigned int seg, unsigned int bus,
@@ -113,17 +113,16 @@ static void __iomem * __init mcfg_ioremap(struct acpi_mcfg_allocation *cfg)
 {
        void __iomem *addr;
        u64 start, size;
+       int num_buses;
 
-       start = cfg->start_bus_number;
-       start <<= 20;
-       start += cfg->address;
-       size = cfg->end_bus_number + 1 - cfg->start_bus_number;
-       size <<= 20;
+       start = cfg->address + PCI_MMCFG_BUS_OFFSET(cfg->start_bus_number);
+       num_buses = cfg->end_bus_number - cfg->start_bus_number + 1;
+       size = PCI_MMCFG_BUS_OFFSET(num_buses);
        addr = ioremap_nocache(start, size);
        if (addr) {
                printk(KERN_INFO "PCI: Using MMCONFIG at %Lx - %Lx\n",
                       start, start + size - 1);
-               addr -= cfg->start_bus_number << 20;
+               addr -= PCI_MMCFG_BUS_OFFSET(cfg->start_bus_number);
        }
        return addr;
 }
@@ -162,7 +161,7 @@ void __init pci_mmcfg_arch_free(void)
 
        for (i = 0; i < pci_mmcfg_config_num; ++i) {
                if (pci_mmcfg_virt[i].virt) {
-                       iounmap(pci_mmcfg_virt[i].virt + (pci_mmcfg_virt[i].cfg->start_bus_number << 20));
+                       iounmap(pci_mmcfg_virt[i].virt + PCI_MMCFG_BUS_OFFSET(pci_mmcfg_virt[i].cfg->start_bus_number));
                        pci_mmcfg_virt[i].virt = NULL;
                        pci_mmcfg_virt[i].cfg = NULL;
                }