Commit 564af7a5 authored by Bjorn Helgaas's avatar Bjorn Helgaas

Merge branch 'pci/enumeration-logging'

- Log device type (Root Port, Switch Port, etc) during enumeration (Bjorn
  Helgaas)

- Log resource names (BAR 0, VF BAR 0, bridge window, etc) consistently
  instead of a mix of names and "reg 0x10" (Puranjay Mohan, Bjorn Helgaas)

- Log bridges before devices below the bridges (Bjorn Helgaas)

* pci/enumeration-logging:
  PCI: Log bridge info when first enumerating bridge
  PCI: Log bridge windows conditionally
  PCI: Supply bridge device, not secondary bus, to read window details
  PCI: Move pci_read_bridge_windows() below individual window accessors
  PCI: Use resource names in PCI log messages
  PCI: Update BAR # and window messages
  PCI: Log device type during enumeration
parents 78e5ad79 95140c2f
...@@ -745,6 +745,7 @@ static int sriov_init(struct pci_dev *dev, int pos) ...@@ -745,6 +745,7 @@ static int sriov_init(struct pci_dev *dev, int pos)
u16 ctrl, total; u16 ctrl, total;
struct pci_sriov *iov; struct pci_sriov *iov;
struct resource *res; struct resource *res;
const char *res_name;
struct pci_dev *pdev; struct pci_dev *pdev;
pci_read_config_word(dev, pos + PCI_SRIOV_CTRL, &ctrl); pci_read_config_word(dev, pos + PCI_SRIOV_CTRL, &ctrl);
...@@ -785,6 +786,8 @@ static int sriov_init(struct pci_dev *dev, int pos) ...@@ -785,6 +786,8 @@ static int sriov_init(struct pci_dev *dev, int pos)
nres = 0; nres = 0;
for (i = 0; i < PCI_SRIOV_NUM_BARS; i++) { for (i = 0; i < PCI_SRIOV_NUM_BARS; i++) {
res = &dev->resource[i + PCI_IOV_RESOURCES]; res = &dev->resource[i + PCI_IOV_RESOURCES];
res_name = pci_resource_name(dev, i + PCI_IOV_RESOURCES);
/* /*
* If it is already FIXED, don't change it, something * If it is already FIXED, don't change it, something
* (perhaps EA or header fixups) wants it this way. * (perhaps EA or header fixups) wants it this way.
...@@ -802,8 +805,8 @@ static int sriov_init(struct pci_dev *dev, int pos) ...@@ -802,8 +805,8 @@ static int sriov_init(struct pci_dev *dev, int pos)
} }
iov->barsz[i] = resource_size(res); iov->barsz[i] = resource_size(res);
res->end = res->start + resource_size(res) * total - 1; res->end = res->start + resource_size(res) * total - 1;
pci_info(dev, "VF(n) BAR%d space: %pR (contains BAR%d for %d VFs)\n", pci_info(dev, "%s %pR: contains BAR %d for %d VFs\n",
i, res, i, total); res_name, res, i, total);
i += bar64; i += bar64;
nres++; nres++;
} }
......
...@@ -850,6 +850,66 @@ struct resource *pci_find_resource(struct pci_dev *dev, struct resource *res) ...@@ -850,6 +850,66 @@ struct resource *pci_find_resource(struct pci_dev *dev, struct resource *res)
} }
EXPORT_SYMBOL(pci_find_resource); EXPORT_SYMBOL(pci_find_resource);
/**
* pci_resource_name - Return the name of the PCI resource
* @dev: PCI device to query
* @i: index of the resource
*
* Return the standard PCI resource (BAR) name according to their index.
*/
const char *pci_resource_name(struct pci_dev *dev, unsigned int i)
{
static const char * const bar_name[] = {
"BAR 0",
"BAR 1",
"BAR 2",
"BAR 3",
"BAR 4",
"BAR 5",
"ROM",
#ifdef CONFIG_PCI_IOV
"VF BAR 0",
"VF BAR 1",
"VF BAR 2",
"VF BAR 3",
"VF BAR 4",
"VF BAR 5",
#endif
"bridge window", /* "io" included in %pR */
"bridge window", /* "mem" included in %pR */
"bridge window", /* "mem pref" included in %pR */
};
static const char * const cardbus_name[] = {
"BAR 1",
"unknown",
"unknown",
"unknown",
"unknown",
"unknown",
#ifdef CONFIG_PCI_IOV
"unknown",
"unknown",
"unknown",
"unknown",
"unknown",
"unknown",
#endif
"CardBus bridge window 0", /* I/O */
"CardBus bridge window 1", /* I/O */
"CardBus bridge window 0", /* mem */
"CardBus bridge window 1", /* mem */
};
if (dev->hdr_type == PCI_HEADER_TYPE_CARDBUS &&
i < ARRAY_SIZE(cardbus_name))
return cardbus_name[i];
if (i < ARRAY_SIZE(bar_name))
return bar_name[i];
return "unknown";
}
/** /**
* pci_wait_for_pending - wait for @mask bit(s) to clear in status word @pos * pci_wait_for_pending - wait for @mask bit(s) to clear in status word @pos
* @dev: the PCI device to operate on * @dev: the PCI device to operate on
...@@ -3290,6 +3350,7 @@ static struct resource *pci_ea_get_resource(struct pci_dev *dev, u8 bei, ...@@ -3290,6 +3350,7 @@ static struct resource *pci_ea_get_resource(struct pci_dev *dev, u8 bei,
static int pci_ea_read(struct pci_dev *dev, int offset) static int pci_ea_read(struct pci_dev *dev, int offset)
{ {
struct resource *res; struct resource *res;
const char *res_name;
int ent_size, ent_offset = offset; int ent_size, ent_offset = offset;
resource_size_t start, end; resource_size_t start, end;
unsigned long flags; unsigned long flags;
...@@ -3319,6 +3380,7 @@ static int pci_ea_read(struct pci_dev *dev, int offset) ...@@ -3319,6 +3380,7 @@ static int pci_ea_read(struct pci_dev *dev, int offset)
goto out; goto out;
res = pci_ea_get_resource(dev, bei, prop); res = pci_ea_get_resource(dev, bei, prop);
res_name = pci_resource_name(dev, bei);
if (!res) { if (!res) {
pci_err(dev, "Unsupported EA entry BEI: %u\n", bei); pci_err(dev, "Unsupported EA entry BEI: %u\n", bei);
goto out; goto out;
...@@ -3392,16 +3454,16 @@ static int pci_ea_read(struct pci_dev *dev, int offset) ...@@ -3392,16 +3454,16 @@ static int pci_ea_read(struct pci_dev *dev, int offset)
res->flags = flags; res->flags = flags;
if (bei <= PCI_EA_BEI_BAR5) if (bei <= PCI_EA_BEI_BAR5)
pci_info(dev, "BAR %d: %pR (from Enhanced Allocation, properties %#02x)\n", pci_info(dev, "%s %pR: from Enhanced Allocation, properties %#02x\n",
bei, res, prop); res_name, res, prop);
else if (bei == PCI_EA_BEI_ROM) else if (bei == PCI_EA_BEI_ROM)
pci_info(dev, "ROM: %pR (from Enhanced Allocation, properties %#02x)\n", pci_info(dev, "%s %pR: from Enhanced Allocation, properties %#02x\n",
res, prop); res_name, res, prop);
else if (bei >= PCI_EA_BEI_VF_BAR0 && bei <= PCI_EA_BEI_VF_BAR5) else if (bei >= PCI_EA_BEI_VF_BAR0 && bei <= PCI_EA_BEI_VF_BAR5)
pci_info(dev, "VF BAR %d: %pR (from Enhanced Allocation, properties %#02x)\n", pci_info(dev, "%s %pR: from Enhanced Allocation, properties %#02x\n",
bei - PCI_EA_BEI_VF_BAR0, res, prop); res_name, res, prop);
else else
pci_info(dev, "BEI %d res: %pR (from Enhanced Allocation, properties %#02x)\n", pci_info(dev, "BEI %d %pR: from Enhanced Allocation, properties %#02x\n",
bei, res, prop); bei, res, prop);
out: out:
...@@ -6689,14 +6751,15 @@ static void pci_request_resource_alignment(struct pci_dev *dev, int bar, ...@@ -6689,14 +6751,15 @@ static void pci_request_resource_alignment(struct pci_dev *dev, int bar,
resource_size_t align, bool resize) resource_size_t align, bool resize)
{ {
struct resource *r = &dev->resource[bar]; struct resource *r = &dev->resource[bar];
const char *r_name = pci_resource_name(dev, bar);
resource_size_t size; resource_size_t size;
if (!(r->flags & IORESOURCE_MEM)) if (!(r->flags & IORESOURCE_MEM))
return; return;
if (r->flags & IORESOURCE_PCI_FIXED) { if (r->flags & IORESOURCE_PCI_FIXED) {
pci_info(dev, "BAR%d %pR: ignoring requested alignment %#llx\n", pci_info(dev, "%s %pR: ignoring requested alignment %#llx\n",
bar, r, (unsigned long long)align); r_name, r, (unsigned long long)align);
return; return;
} }
...@@ -6732,8 +6795,8 @@ static void pci_request_resource_alignment(struct pci_dev *dev, int bar, ...@@ -6732,8 +6795,8 @@ static void pci_request_resource_alignment(struct pci_dev *dev, int bar,
* devices and we use the second. * devices and we use the second.
*/ */
pci_info(dev, "BAR%d %pR: requesting alignment to %#llx\n", pci_info(dev, "%s %pR: requesting alignment to %#llx\n",
bar, r, (unsigned long long)align); r_name, r, (unsigned long long)align);
if (resize) { if (resize) {
r->start = 0; r->start = 0;
......
...@@ -255,6 +255,8 @@ void __pci_bus_assign_resources(const struct pci_bus *bus, ...@@ -255,6 +255,8 @@ void __pci_bus_assign_resources(const struct pci_bus *bus,
struct list_head *fail_head); struct list_head *fail_head);
bool pci_bus_clip_resource(struct pci_dev *dev, int idx); bool pci_bus_clip_resource(struct pci_dev *dev, int idx);
const char *pci_resource_name(struct pci_dev *dev, unsigned int i);
void pci_reassigndev_resource_alignment(struct pci_dev *dev); void pci_reassigndev_resource_alignment(struct pci_dev *dev);
void pci_disable_bridge_window(struct pci_dev *dev); void pci_disable_bridge_window(struct pci_dev *dev);
struct pci_bus *pci_bus_get(struct pci_bus *bus); struct pci_bus *pci_bus_get(struct pci_bus *bus);
......
...@@ -180,6 +180,7 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, ...@@ -180,6 +180,7 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
u64 l64, sz64, mask64; u64 l64, sz64, mask64;
u16 orig_cmd; u16 orig_cmd;
struct pci_bus_region region, inverted_region; struct pci_bus_region region, inverted_region;
const char *res_name = pci_resource_name(dev, res - dev->resource);
mask = type ? PCI_ROM_ADDRESS_MASK : ~0; mask = type ? PCI_ROM_ADDRESS_MASK : ~0;
...@@ -254,8 +255,7 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, ...@@ -254,8 +255,7 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
sz64 = pci_size(l64, sz64, mask64); sz64 = pci_size(l64, sz64, mask64);
if (!sz64) { if (!sz64) {
pci_info(dev, FW_BUG "reg 0x%x: invalid BAR (can't size)\n", pci_info(dev, FW_BUG "%s: invalid; can't size\n", res_name);
pos);
goto fail; goto fail;
} }
...@@ -265,8 +265,8 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, ...@@ -265,8 +265,8 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
res->flags |= IORESOURCE_UNSET | IORESOURCE_DISABLED; res->flags |= IORESOURCE_UNSET | IORESOURCE_DISABLED;
res->start = 0; res->start = 0;
res->end = 0; res->end = 0;
pci_err(dev, "reg 0x%x: can't handle BAR larger than 4GB (size %#010llx)\n", pci_err(dev, "%s: can't handle BAR larger than 4GB (size %#010llx)\n",
pos, (unsigned long long)sz64); res_name, (unsigned long long)sz64);
goto out; goto out;
} }
...@@ -275,8 +275,8 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, ...@@ -275,8 +275,8 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
res->start = 0; res->start = 0;
res->end = sz64 - 1; res->end = sz64 - 1;
pci_info(dev, "reg 0x%x: can't handle BAR above 4GB (bus address %#010llx)\n", pci_info(dev, "%s: can't handle BAR above 4GB (bus address %#010llx)\n",
pos, (unsigned long long)l64); res_name, (unsigned long long)l64);
goto out; goto out;
} }
} }
...@@ -302,8 +302,8 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, ...@@ -302,8 +302,8 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
res->start = 0; res->start = 0;
res->end = region.end - region.start; res->end = region.end - region.start;
pci_info(dev, "reg 0x%x: initial BAR value %#010llx invalid\n", pci_info(dev, "%s: initial BAR value %#010llx invalid\n",
pos, (unsigned long long)region.start); res_name, (unsigned long long)region.start);
} }
goto out; goto out;
...@@ -313,7 +313,7 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type, ...@@ -313,7 +313,7 @@ int __pci_read_base(struct pci_dev *dev, enum pci_bar_type type,
res->flags = 0; res->flags = 0;
out: out:
if (res->flags) if (res->flags)
pci_info(dev, "reg 0x%x: %pR\n", pos, res); pci_info(dev, "%s %pR\n", res_name, res);
return (res->flags & IORESOURCE_MEM_64) ? 1 : 0; return (res->flags & IORESOURCE_MEM_64) ? 1 : 0;
} }
...@@ -344,64 +344,12 @@ static void pci_read_bases(struct pci_dev *dev, unsigned int howmany, int rom) ...@@ -344,64 +344,12 @@ static void pci_read_bases(struct pci_dev *dev, unsigned int howmany, int rom)
} }
} }
static void pci_read_bridge_windows(struct pci_dev *bridge) static void pci_read_bridge_io(struct pci_dev *dev, struct resource *res,
bool log)
{ {
u16 io;
u32 pmem, tmp;
pci_read_config_word(bridge, PCI_IO_BASE, &io);
if (!io) {
pci_write_config_word(bridge, PCI_IO_BASE, 0xe0f0);
pci_read_config_word(bridge, PCI_IO_BASE, &io);
pci_write_config_word(bridge, PCI_IO_BASE, 0x0);
}
if (io)
bridge->io_window = 1;
/*
* DECchip 21050 pass 2 errata: the bridge may miss an address
* disconnect boundary by one PCI data phase. Workaround: do not
* use prefetching on this device.
*/
if (bridge->vendor == PCI_VENDOR_ID_DEC && bridge->device == 0x0001)
return;
pci_read_config_dword(bridge, PCI_PREF_MEMORY_BASE, &pmem);
if (!pmem) {
pci_write_config_dword(bridge, PCI_PREF_MEMORY_BASE,
0xffe0fff0);
pci_read_config_dword(bridge, PCI_PREF_MEMORY_BASE, &pmem);
pci_write_config_dword(bridge, PCI_PREF_MEMORY_BASE, 0x0);
}
if (!pmem)
return;
bridge->pref_window = 1;
if ((pmem & PCI_PREF_RANGE_TYPE_MASK) == PCI_PREF_RANGE_TYPE_64) {
/*
* Bridge claims to have a 64-bit prefetchable memory
* window; verify that the upper bits are actually
* writable.
*/
pci_read_config_dword(bridge, PCI_PREF_BASE_UPPER32, &pmem);
pci_write_config_dword(bridge, PCI_PREF_BASE_UPPER32,
0xffffffff);
pci_read_config_dword(bridge, PCI_PREF_BASE_UPPER32, &tmp);
pci_write_config_dword(bridge, PCI_PREF_BASE_UPPER32, pmem);
if (tmp)
bridge->pref_64_window = 1;
}
}
static void pci_read_bridge_io(struct pci_bus *child)
{
struct pci_dev *dev = child->self;
u8 io_base_lo, io_limit_lo; u8 io_base_lo, io_limit_lo;
unsigned long io_mask, io_granularity, base, limit; unsigned long io_mask, io_granularity, base, limit;
struct pci_bus_region region; struct pci_bus_region region;
struct resource *res;
io_mask = PCI_IO_RANGE_MASK; io_mask = PCI_IO_RANGE_MASK;
io_granularity = 0x1000; io_granularity = 0x1000;
...@@ -411,7 +359,6 @@ static void pci_read_bridge_io(struct pci_bus *child) ...@@ -411,7 +359,6 @@ static void pci_read_bridge_io(struct pci_bus *child)
io_granularity = 0x400; io_granularity = 0x400;
} }
res = child->resource[0];
pci_read_config_byte(dev, PCI_IO_BASE, &io_base_lo); pci_read_config_byte(dev, PCI_IO_BASE, &io_base_lo);
pci_read_config_byte(dev, PCI_IO_LIMIT, &io_limit_lo); pci_read_config_byte(dev, PCI_IO_LIMIT, &io_limit_lo);
base = (io_base_lo & io_mask) << 8; base = (io_base_lo & io_mask) << 8;
...@@ -431,19 +378,18 @@ static void pci_read_bridge_io(struct pci_bus *child) ...@@ -431,19 +378,18 @@ static void pci_read_bridge_io(struct pci_bus *child)
region.start = base; region.start = base;
region.end = limit + io_granularity - 1; region.end = limit + io_granularity - 1;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
if (log)
pci_info(dev, " bridge window %pR\n", res); pci_info(dev, " bridge window %pR\n", res);
} }
} }
static void pci_read_bridge_mmio(struct pci_bus *child) static void pci_read_bridge_mmio(struct pci_dev *dev, struct resource *res,
bool log)
{ {
struct pci_dev *dev = child->self;
u16 mem_base_lo, mem_limit_lo; u16 mem_base_lo, mem_limit_lo;
unsigned long base, limit; unsigned long base, limit;
struct pci_bus_region region; struct pci_bus_region region;
struct resource *res;
res = child->resource[1];
pci_read_config_word(dev, PCI_MEMORY_BASE, &mem_base_lo); pci_read_config_word(dev, PCI_MEMORY_BASE, &mem_base_lo);
pci_read_config_word(dev, PCI_MEMORY_LIMIT, &mem_limit_lo); pci_read_config_word(dev, PCI_MEMORY_LIMIT, &mem_limit_lo);
base = ((unsigned long) mem_base_lo & PCI_MEMORY_RANGE_MASK) << 16; base = ((unsigned long) mem_base_lo & PCI_MEMORY_RANGE_MASK) << 16;
...@@ -453,20 +399,19 @@ static void pci_read_bridge_mmio(struct pci_bus *child) ...@@ -453,20 +399,19 @@ static void pci_read_bridge_mmio(struct pci_bus *child)
region.start = base; region.start = base;
region.end = limit + 0xfffff; region.end = limit + 0xfffff;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
if (log)
pci_info(dev, " bridge window %pR\n", res); pci_info(dev, " bridge window %pR\n", res);
} }
} }
static void pci_read_bridge_mmio_pref(struct pci_bus *child) static void pci_read_bridge_mmio_pref(struct pci_dev *dev, struct resource *res,
bool log)
{ {
struct pci_dev *dev = child->self;
u16 mem_base_lo, mem_limit_lo; u16 mem_base_lo, mem_limit_lo;
u64 base64, limit64; u64 base64, limit64;
pci_bus_addr_t base, limit; pci_bus_addr_t base, limit;
struct pci_bus_region region; struct pci_bus_region region;
struct resource *res;
res = child->resource[2];
pci_read_config_word(dev, PCI_PREF_MEMORY_BASE, &mem_base_lo); pci_read_config_word(dev, PCI_PREF_MEMORY_BASE, &mem_base_lo);
pci_read_config_word(dev, PCI_PREF_MEMORY_LIMIT, &mem_limit_lo); pci_read_config_word(dev, PCI_PREF_MEMORY_LIMIT, &mem_limit_lo);
base64 = (mem_base_lo & PCI_PREF_RANGE_MASK) << 16; base64 = (mem_base_lo & PCI_PREF_RANGE_MASK) << 16;
...@@ -506,10 +451,77 @@ static void pci_read_bridge_mmio_pref(struct pci_bus *child) ...@@ -506,10 +451,77 @@ static void pci_read_bridge_mmio_pref(struct pci_bus *child)
region.start = base; region.start = base;
region.end = limit + 0xfffff; region.end = limit + 0xfffff;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
if (log)
pci_info(dev, " bridge window %pR\n", res); pci_info(dev, " bridge window %pR\n", res);
} }
} }
static void pci_read_bridge_windows(struct pci_dev *bridge)
{
u32 buses;
u16 io;
u32 pmem, tmp;
struct resource res;
pci_read_config_dword(bridge, PCI_PRIMARY_BUS, &buses);
res.flags = IORESOURCE_BUS;
res.start = (buses >> 8) & 0xff;
res.end = (buses >> 16) & 0xff;
pci_info(bridge, "PCI bridge to %pR%s\n", &res,
bridge->transparent ? " (subtractive decode)" : "");
pci_read_config_word(bridge, PCI_IO_BASE, &io);
if (!io) {
pci_write_config_word(bridge, PCI_IO_BASE, 0xe0f0);
pci_read_config_word(bridge, PCI_IO_BASE, &io);
pci_write_config_word(bridge, PCI_IO_BASE, 0x0);
}
if (io) {
bridge->io_window = 1;
pci_read_bridge_io(bridge, &res, true);
}
pci_read_bridge_mmio(bridge, &res, true);
/*
* DECchip 21050 pass 2 errata: the bridge may miss an address
* disconnect boundary by one PCI data phase. Workaround: do not
* use prefetching on this device.
*/
if (bridge->vendor == PCI_VENDOR_ID_DEC && bridge->device == 0x0001)
return;
pci_read_config_dword(bridge, PCI_PREF_MEMORY_BASE, &pmem);
if (!pmem) {
pci_write_config_dword(bridge, PCI_PREF_MEMORY_BASE,
0xffe0fff0);
pci_read_config_dword(bridge, PCI_PREF_MEMORY_BASE, &pmem);
pci_write_config_dword(bridge, PCI_PREF_MEMORY_BASE, 0x0);
}
if (!pmem)
return;
bridge->pref_window = 1;
if ((pmem & PCI_PREF_RANGE_TYPE_MASK) == PCI_PREF_RANGE_TYPE_64) {
/*
* Bridge claims to have a 64-bit prefetchable memory
* window; verify that the upper bits are actually
* writable.
*/
pci_read_config_dword(bridge, PCI_PREF_BASE_UPPER32, &pmem);
pci_write_config_dword(bridge, PCI_PREF_BASE_UPPER32,
0xffffffff);
pci_read_config_dword(bridge, PCI_PREF_BASE_UPPER32, &tmp);
pci_write_config_dword(bridge, PCI_PREF_BASE_UPPER32, pmem);
if (tmp)
bridge->pref_64_window = 1;
}
pci_read_bridge_mmio_pref(bridge, &res, true);
}
void pci_read_bridge_bases(struct pci_bus *child) void pci_read_bridge_bases(struct pci_bus *child)
{ {
struct pci_dev *dev = child->self; struct pci_dev *dev = child->self;
...@@ -527,9 +539,9 @@ void pci_read_bridge_bases(struct pci_bus *child) ...@@ -527,9 +539,9 @@ void pci_read_bridge_bases(struct pci_bus *child)
for (i = 0; i < PCI_BRIDGE_RESOURCE_NUM; i++) for (i = 0; i < PCI_BRIDGE_RESOURCE_NUM; i++)
child->resource[i] = &dev->resource[PCI_BRIDGE_RESOURCES+i]; child->resource[i] = &dev->resource[PCI_BRIDGE_RESOURCES+i];
pci_read_bridge_io(child); pci_read_bridge_io(child->self, child->resource[0], false);
pci_read_bridge_mmio(child); pci_read_bridge_mmio(child->self, child->resource[1], false);
pci_read_bridge_mmio_pref(child); pci_read_bridge_mmio_pref(child->self, child->resource[2], false);
if (dev->transparent) { if (dev->transparent) {
pci_bus_for_each_resource(child->parent, res) { pci_bus_for_each_resource(child->parent, res) {
...@@ -1817,6 +1829,43 @@ static void early_dump_pci_device(struct pci_dev *pdev) ...@@ -1817,6 +1829,43 @@ static void early_dump_pci_device(struct pci_dev *pdev)
value, 256, false); value, 256, false);
} }
static const char *pci_type_str(struct pci_dev *dev)
{
static const char * const str[] = {
"PCIe Endpoint",
"PCIe Legacy Endpoint",
"PCIe unknown",
"PCIe unknown",
"PCIe Root Port",
"PCIe Switch Upstream Port",
"PCIe Switch Downstream Port",
"PCIe to PCI/PCI-X bridge",
"PCI/PCI-X to PCIe bridge",
"PCIe Root Complex Integrated Endpoint",
"PCIe Root Complex Event Collector",
};
int type;
if (pci_is_pcie(dev)) {
type = pci_pcie_type(dev);
if (type < ARRAY_SIZE(str))
return str[type];
return "PCIe unknown";
}
switch (dev->hdr_type) {
case PCI_HEADER_TYPE_NORMAL:
return "conventional PCI endpoint";
case PCI_HEADER_TYPE_BRIDGE:
return "conventional PCI bridge";
case PCI_HEADER_TYPE_CARDBUS:
return "CardBus bridge";
default:
return "conventional PCI";
}
}
/** /**
* pci_setup_device - Fill in class and map information of a device * pci_setup_device - Fill in class and map information of a device
* @dev: the device structure to fill * @dev: the device structure to fill
...@@ -1887,8 +1936,9 @@ int pci_setup_device(struct pci_dev *dev) ...@@ -1887,8 +1936,9 @@ int pci_setup_device(struct pci_dev *dev)
pci_set_removable(dev); pci_set_removable(dev);
pci_info(dev, "[%04x:%04x] type %02x class %#08x\n", pci_info(dev, "[%04x:%04x] type %02x class %#08x %s\n",
dev->vendor, dev->device, dev->hdr_type, dev->class); dev->vendor, dev->device, dev->hdr_type, dev->class,
pci_type_str(dev));
/* Device class may be changed after fixup */ /* Device class may be changed after fixup */
class = dev->class >> 8; class = dev->class >> 8;
...@@ -1929,14 +1979,14 @@ int pci_setup_device(struct pci_dev *dev) ...@@ -1929,14 +1979,14 @@ int pci_setup_device(struct pci_dev *dev)
res = &dev->resource[0]; res = &dev->resource[0];
res->flags = LEGACY_IO_RESOURCE; res->flags = LEGACY_IO_RESOURCE;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
pci_info(dev, "legacy IDE quirk: reg 0x10: %pR\n", pci_info(dev, "BAR 0 %pR: legacy IDE quirk\n",
res); res);
region.start = 0x3F6; region.start = 0x3F6;
region.end = 0x3F6; region.end = 0x3F6;
res = &dev->resource[1]; res = &dev->resource[1];
res->flags = LEGACY_IO_RESOURCE; res->flags = LEGACY_IO_RESOURCE;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
pci_info(dev, "legacy IDE quirk: reg 0x14: %pR\n", pci_info(dev, "BAR 1 %pR: legacy IDE quirk\n",
res); res);
} }
if ((progif & 4) == 0) { if ((progif & 4) == 0) {
...@@ -1945,14 +1995,14 @@ int pci_setup_device(struct pci_dev *dev) ...@@ -1945,14 +1995,14 @@ int pci_setup_device(struct pci_dev *dev)
res = &dev->resource[2]; res = &dev->resource[2];
res->flags = LEGACY_IO_RESOURCE; res->flags = LEGACY_IO_RESOURCE;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
pci_info(dev, "legacy IDE quirk: reg 0x18: %pR\n", pci_info(dev, "BAR 2 %pR: legacy IDE quirk\n",
res); res);
region.start = 0x376; region.start = 0x376;
region.end = 0x376; region.end = 0x376;
res = &dev->resource[3]; res = &dev->resource[3];
res->flags = LEGACY_IO_RESOURCE; res->flags = LEGACY_IO_RESOURCE;
pcibios_bus_to_resource(dev->bus, res, &region); pcibios_bus_to_resource(dev->bus, res, &region);
pci_info(dev, "legacy IDE quirk: reg 0x1c: %pR\n", pci_info(dev, "BAR 3 %pR: legacy IDE quirk\n",
res); res);
} }
} }
......
...@@ -570,13 +570,14 @@ static void quirk_extend_bar_to_page(struct pci_dev *dev) ...@@ -570,13 +570,14 @@ static void quirk_extend_bar_to_page(struct pci_dev *dev)
for (i = 0; i < PCI_STD_NUM_BARS; i++) { for (i = 0; i < PCI_STD_NUM_BARS; i++) {
struct resource *r = &dev->resource[i]; struct resource *r = &dev->resource[i];
const char *r_name = pci_resource_name(dev, i);
if (r->flags & IORESOURCE_MEM && resource_size(r) < PAGE_SIZE) { if (r->flags & IORESOURCE_MEM && resource_size(r) < PAGE_SIZE) {
r->end = PAGE_SIZE - 1; r->end = PAGE_SIZE - 1;
r->start = 0; r->start = 0;
r->flags |= IORESOURCE_UNSET; r->flags |= IORESOURCE_UNSET;
pci_info(dev, "expanded BAR %d to page size: %pR\n", pci_info(dev, "%s %pR: expanded to page size\n",
i, r); r_name, r);
} }
} }
} }
...@@ -605,6 +606,7 @@ static void quirk_io(struct pci_dev *dev, int pos, unsigned int size, ...@@ -605,6 +606,7 @@ static void quirk_io(struct pci_dev *dev, int pos, unsigned int size,
u32 region; u32 region;
struct pci_bus_region bus_region; struct pci_bus_region bus_region;
struct resource *res = dev->resource + pos; struct resource *res = dev->resource + pos;
const char *res_name = pci_resource_name(dev, pos);
pci_read_config_dword(dev, PCI_BASE_ADDRESS_0 + (pos << 2), &region); pci_read_config_dword(dev, PCI_BASE_ADDRESS_0 + (pos << 2), &region);
...@@ -622,8 +624,7 @@ static void quirk_io(struct pci_dev *dev, int pos, unsigned int size, ...@@ -622,8 +624,7 @@ static void quirk_io(struct pci_dev *dev, int pos, unsigned int size,
bus_region.end = region + size - 1; bus_region.end = region + size - 1;
pcibios_bus_to_resource(dev->bus, res, &bus_region); pcibios_bus_to_resource(dev->bus, res, &bus_region);
pci_info(dev, FW_BUG "%s quirk: reg 0x%x: %pR\n", pci_info(dev, FW_BUG "%s %pR: %s quirk\n", res_name, res, name);
name, PCI_BASE_ADDRESS_0 + (pos << 2), res);
} }
/* /*
...@@ -670,6 +671,12 @@ static void quirk_io_region(struct pci_dev *dev, int port, ...@@ -670,6 +671,12 @@ static void quirk_io_region(struct pci_dev *dev, int port,
bus_region.end = region + size - 1; bus_region.end = region + size - 1;
pcibios_bus_to_resource(dev->bus, res, &bus_region); pcibios_bus_to_resource(dev->bus, res, &bus_region);
/*
* "res" is typically a bridge window resource that's not being
* used for a bridge window, so it's just a place to stash this
* non-standard resource. Printing "nr" or pci_resource_name() of
* it doesn't really make sense.
*/
if (!pci_claim_resource(dev, nr)) if (!pci_claim_resource(dev, nr))
pci_info(dev, "quirk: %pR claimed by %s\n", res, name); pci_info(dev, "quirk: %pR claimed by %s\n", res, name);
} }
......
...@@ -213,6 +213,7 @@ static void reassign_resources_sorted(struct list_head *realloc_head, ...@@ -213,6 +213,7 @@ static void reassign_resources_sorted(struct list_head *realloc_head,
struct list_head *head) struct list_head *head)
{ {
struct resource *res; struct resource *res;
const char *res_name;
struct pci_dev_resource *add_res, *tmp; struct pci_dev_resource *add_res, *tmp;
struct pci_dev_resource *dev_res; struct pci_dev_resource *dev_res;
resource_size_t add_size, align; resource_size_t add_size, align;
...@@ -222,6 +223,7 @@ static void reassign_resources_sorted(struct list_head *realloc_head, ...@@ -222,6 +223,7 @@ static void reassign_resources_sorted(struct list_head *realloc_head,
bool found_match = false; bool found_match = false;
res = add_res->res; res = add_res->res;
/* Skip resource that has been reset */ /* Skip resource that has been reset */
if (!res->flags) if (!res->flags)
goto out; goto out;
...@@ -237,6 +239,7 @@ static void reassign_resources_sorted(struct list_head *realloc_head, ...@@ -237,6 +239,7 @@ static void reassign_resources_sorted(struct list_head *realloc_head,
continue; continue;
idx = res - &add_res->dev->resource[0]; idx = res - &add_res->dev->resource[0];
res_name = pci_resource_name(add_res->dev, idx);
add_size = add_res->add_size; add_size = add_res->add_size;
align = add_res->min_align; align = add_res->min_align;
if (!resource_size(res)) { if (!resource_size(res)) {
...@@ -249,9 +252,9 @@ static void reassign_resources_sorted(struct list_head *realloc_head, ...@@ -249,9 +252,9 @@ static void reassign_resources_sorted(struct list_head *realloc_head,
(IORESOURCE_STARTALIGN|IORESOURCE_SIZEALIGN); (IORESOURCE_STARTALIGN|IORESOURCE_SIZEALIGN);
if (pci_reassign_resource(add_res->dev, idx, if (pci_reassign_resource(add_res->dev, idx,
add_size, align)) add_size, align))
pci_info(add_res->dev, "failed to add %llx res[%d]=%pR\n", pci_info(add_res->dev, "%s %pR: failed to add %llx\n",
(unsigned long long) add_size, idx, res_name, res,
res); (unsigned long long) add_size);
} }
out: out:
list_del(&add_res->list); list_del(&add_res->list);
...@@ -571,6 +574,7 @@ EXPORT_SYMBOL(pci_setup_cardbus); ...@@ -571,6 +574,7 @@ EXPORT_SYMBOL(pci_setup_cardbus);
static void pci_setup_bridge_io(struct pci_dev *bridge) static void pci_setup_bridge_io(struct pci_dev *bridge)
{ {
struct resource *res; struct resource *res;
const char *res_name;
struct pci_bus_region region; struct pci_bus_region region;
unsigned long io_mask; unsigned long io_mask;
u8 io_base_lo, io_limit_lo; u8 io_base_lo, io_limit_lo;
...@@ -583,6 +587,7 @@ static void pci_setup_bridge_io(struct pci_dev *bridge) ...@@ -583,6 +587,7 @@ static void pci_setup_bridge_io(struct pci_dev *bridge)
/* Set up the top and bottom of the PCI I/O segment for this bus */ /* Set up the top and bottom of the PCI I/O segment for this bus */
res = &bridge->resource[PCI_BRIDGE_IO_WINDOW]; res = &bridge->resource[PCI_BRIDGE_IO_WINDOW];
res_name = pci_resource_name(bridge, PCI_BRIDGE_IO_WINDOW);
pcibios_resource_to_bus(bridge->bus, &region, res); pcibios_resource_to_bus(bridge->bus, &region, res);
if (res->flags & IORESOURCE_IO) { if (res->flags & IORESOURCE_IO) {
pci_read_config_word(bridge, PCI_IO_BASE, &l); pci_read_config_word(bridge, PCI_IO_BASE, &l);
...@@ -591,7 +596,7 @@ static void pci_setup_bridge_io(struct pci_dev *bridge) ...@@ -591,7 +596,7 @@ static void pci_setup_bridge_io(struct pci_dev *bridge)
l = ((u16) io_limit_lo << 8) | io_base_lo; l = ((u16) io_limit_lo << 8) | io_base_lo;
/* Set up upper 16 bits of I/O base/limit */ /* Set up upper 16 bits of I/O base/limit */
io_upper16 = (region.end & 0xffff0000) | (region.start >> 16); io_upper16 = (region.end & 0xffff0000) | (region.start >> 16);
pci_info(bridge, " bridge window %pR\n", res); pci_info(bridge, " %s %pR\n", res_name, res);
} else { } else {
/* Clear upper 16 bits of I/O base/limit */ /* Clear upper 16 bits of I/O base/limit */
io_upper16 = 0; io_upper16 = 0;
...@@ -608,16 +613,18 @@ static void pci_setup_bridge_io(struct pci_dev *bridge) ...@@ -608,16 +613,18 @@ static void pci_setup_bridge_io(struct pci_dev *bridge)
static void pci_setup_bridge_mmio(struct pci_dev *bridge) static void pci_setup_bridge_mmio(struct pci_dev *bridge)
{ {
struct resource *res; struct resource *res;
const char *res_name;
struct pci_bus_region region; struct pci_bus_region region;
u32 l; u32 l;
/* Set up the top and bottom of the PCI Memory segment for this bus */ /* Set up the top and bottom of the PCI Memory segment for this bus */
res = &bridge->resource[PCI_BRIDGE_MEM_WINDOW]; res = &bridge->resource[PCI_BRIDGE_MEM_WINDOW];
res_name = pci_resource_name(bridge, PCI_BRIDGE_MEM_WINDOW);
pcibios_resource_to_bus(bridge->bus, &region, res); pcibios_resource_to_bus(bridge->bus, &region, res);
if (res->flags & IORESOURCE_MEM) { if (res->flags & IORESOURCE_MEM) {
l = (region.start >> 16) & 0xfff0; l = (region.start >> 16) & 0xfff0;
l |= region.end & 0xfff00000; l |= region.end & 0xfff00000;
pci_info(bridge, " bridge window %pR\n", res); pci_info(bridge, " %s %pR\n", res_name, res);
} else { } else {
l = 0x0000fff0; l = 0x0000fff0;
} }
...@@ -627,6 +634,7 @@ static void pci_setup_bridge_mmio(struct pci_dev *bridge) ...@@ -627,6 +634,7 @@ static void pci_setup_bridge_mmio(struct pci_dev *bridge)
static void pci_setup_bridge_mmio_pref(struct pci_dev *bridge) static void pci_setup_bridge_mmio_pref(struct pci_dev *bridge)
{ {
struct resource *res; struct resource *res;
const char *res_name;
struct pci_bus_region region; struct pci_bus_region region;
u32 l, bu, lu; u32 l, bu, lu;
...@@ -640,6 +648,7 @@ static void pci_setup_bridge_mmio_pref(struct pci_dev *bridge) ...@@ -640,6 +648,7 @@ static void pci_setup_bridge_mmio_pref(struct pci_dev *bridge)
/* Set up PREF base/limit */ /* Set up PREF base/limit */
bu = lu = 0; bu = lu = 0;
res = &bridge->resource[PCI_BRIDGE_PREF_MEM_WINDOW]; res = &bridge->resource[PCI_BRIDGE_PREF_MEM_WINDOW];
res_name = pci_resource_name(bridge, PCI_BRIDGE_PREF_MEM_WINDOW);
pcibios_resource_to_bus(bridge->bus, &region, res); pcibios_resource_to_bus(bridge->bus, &region, res);
if (res->flags & IORESOURCE_PREFETCH) { if (res->flags & IORESOURCE_PREFETCH) {
l = (region.start >> 16) & 0xfff0; l = (region.start >> 16) & 0xfff0;
...@@ -648,7 +657,7 @@ static void pci_setup_bridge_mmio_pref(struct pci_dev *bridge) ...@@ -648,7 +657,7 @@ static void pci_setup_bridge_mmio_pref(struct pci_dev *bridge)
bu = upper_32_bits(region.start); bu = upper_32_bits(region.start);
lu = upper_32_bits(region.end); lu = upper_32_bits(region.end);
} }
pci_info(bridge, " bridge window %pR\n", res); pci_info(bridge, " %s %pR\n", res_name, res);
} else { } else {
l = 0x0000fff0; l = 0x0000fff0;
} }
...@@ -1013,6 +1022,7 @@ static int pbus_size_mem(struct pci_bus *bus, unsigned long mask, ...@@ -1013,6 +1022,7 @@ static int pbus_size_mem(struct pci_bus *bus, unsigned long mask,
int i; int i;
pci_dev_for_each_resource(dev, r, i) { pci_dev_for_each_resource(dev, r, i) {
const char *r_name = pci_resource_name(dev, i);
resource_size_t r_size; resource_size_t r_size;
if (r->parent || (r->flags & IORESOURCE_PCI_FIXED) || if (r->parent || (r->flags & IORESOURCE_PCI_FIXED) ||
...@@ -1043,8 +1053,8 @@ static int pbus_size_mem(struct pci_bus *bus, unsigned long mask, ...@@ -1043,8 +1053,8 @@ static int pbus_size_mem(struct pci_bus *bus, unsigned long mask,
if (order < 0) if (order < 0)
order = 0; order = 0;
if (order >= ARRAY_SIZE(aligns)) { if (order >= ARRAY_SIZE(aligns)) {
pci_warn(dev, "disabling BAR %d: %pR (bad alignment %#llx)\n", pci_warn(dev, "%s %pR: disabling; bad alignment %#llx\n",
i, r, (unsigned long long) align); r_name, r, (unsigned long long) align);
r->flags = 0; r->flags = 0;
continue; continue;
} }
...@@ -2235,6 +2245,7 @@ int pci_reassign_bridge_resources(struct pci_dev *bridge, unsigned long type) ...@@ -2235,6 +2245,7 @@ int pci_reassign_bridge_resources(struct pci_dev *bridge, unsigned long type)
for (i = PCI_BRIDGE_RESOURCES; i < PCI_BRIDGE_RESOURCE_END; for (i = PCI_BRIDGE_RESOURCES; i < PCI_BRIDGE_RESOURCE_END;
i++) { i++) {
struct resource *res = &bridge->resource[i]; struct resource *res = &bridge->resource[i];
const char *res_name = pci_resource_name(bridge, i);
if ((res->flags ^ type) & PCI_RES_TYPE_MASK) if ((res->flags ^ type) & PCI_RES_TYPE_MASK)
continue; continue;
...@@ -2247,8 +2258,7 @@ int pci_reassign_bridge_resources(struct pci_dev *bridge, unsigned long type) ...@@ -2247,8 +2258,7 @@ int pci_reassign_bridge_resources(struct pci_dev *bridge, unsigned long type)
if (ret) if (ret)
goto cleanup; goto cleanup;
pci_info(bridge, "BAR %d: releasing %pR\n", pci_info(bridge, "%s %pR: releasing\n", res_name, res);
i, res);
if (res->parent) if (res->parent)
release_resource(res); release_resource(res);
......
...@@ -30,6 +30,7 @@ static void pci_std_update_resource(struct pci_dev *dev, int resno) ...@@ -30,6 +30,7 @@ static void pci_std_update_resource(struct pci_dev *dev, int resno)
u32 new, check, mask; u32 new, check, mask;
int reg; int reg;
struct resource *res = dev->resource + resno; struct resource *res = dev->resource + resno;
const char *res_name = pci_resource_name(dev, resno);
/* Per SR-IOV spec 3.4.1.11, VF BARs are RO zero */ /* Per SR-IOV spec 3.4.1.11, VF BARs are RO zero */
if (dev->is_virtfn) if (dev->is_virtfn)
...@@ -104,8 +105,8 @@ static void pci_std_update_resource(struct pci_dev *dev, int resno) ...@@ -104,8 +105,8 @@ static void pci_std_update_resource(struct pci_dev *dev, int resno)
pci_read_config_dword(dev, reg, &check); pci_read_config_dword(dev, reg, &check);
if ((new ^ check) & mask) { if ((new ^ check) & mask) {
pci_err(dev, "BAR %d: error updating (%#010x != %#010x)\n", pci_err(dev, "%s: error updating (%#010x != %#010x)\n",
resno, new, check); res_name, new, check);
} }
if (res->flags & IORESOURCE_MEM_64) { if (res->flags & IORESOURCE_MEM_64) {
...@@ -113,8 +114,8 @@ static void pci_std_update_resource(struct pci_dev *dev, int resno) ...@@ -113,8 +114,8 @@ static void pci_std_update_resource(struct pci_dev *dev, int resno)
pci_write_config_dword(dev, reg + 4, new); pci_write_config_dword(dev, reg + 4, new);
pci_read_config_dword(dev, reg + 4, &check); pci_read_config_dword(dev, reg + 4, &check);
if (check != new) { if (check != new) {
pci_err(dev, "BAR %d: error updating (high %#010x != %#010x)\n", pci_err(dev, "%s: error updating (high %#010x != %#010x)\n",
resno, new, check); res_name, new, check);
} }
} }
...@@ -135,11 +136,12 @@ void pci_update_resource(struct pci_dev *dev, int resno) ...@@ -135,11 +136,12 @@ void pci_update_resource(struct pci_dev *dev, int resno)
int pci_claim_resource(struct pci_dev *dev, int resource) int pci_claim_resource(struct pci_dev *dev, int resource)
{ {
struct resource *res = &dev->resource[resource]; struct resource *res = &dev->resource[resource];
const char *res_name = pci_resource_name(dev, resource);
struct resource *root, *conflict; struct resource *root, *conflict;
if (res->flags & IORESOURCE_UNSET) { if (res->flags & IORESOURCE_UNSET) {
pci_info(dev, "can't claim BAR %d %pR: no address assigned\n", pci_info(dev, "%s %pR: can't claim; no address assigned\n",
resource, res); res_name, res);
return -EINVAL; return -EINVAL;
} }
...@@ -153,16 +155,16 @@ int pci_claim_resource(struct pci_dev *dev, int resource) ...@@ -153,16 +155,16 @@ int pci_claim_resource(struct pci_dev *dev, int resource)
root = pci_find_parent_resource(dev, res); root = pci_find_parent_resource(dev, res);
if (!root) { if (!root) {
pci_info(dev, "can't claim BAR %d %pR: no compatible bridge window\n", pci_info(dev, "%s %pR: can't claim; no compatible bridge window\n",
resource, res); res_name, res);
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
return -EINVAL; return -EINVAL;
} }
conflict = request_resource_conflict(root, res); conflict = request_resource_conflict(root, res);
if (conflict) { if (conflict) {
pci_info(dev, "can't claim BAR %d %pR: address conflict with %s %pR\n", pci_info(dev, "%s %pR: can't claim; address conflict with %s %pR\n",
resource, res, conflict->name, conflict); res_name, res, conflict->name, conflict);
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
return -EBUSY; return -EBUSY;
} }
...@@ -201,6 +203,7 @@ static int pci_revert_fw_address(struct resource *res, struct pci_dev *dev, ...@@ -201,6 +203,7 @@ static int pci_revert_fw_address(struct resource *res, struct pci_dev *dev,
{ {
struct resource *root, *conflict; struct resource *root, *conflict;
resource_size_t fw_addr, start, end; resource_size_t fw_addr, start, end;
const char *res_name = pci_resource_name(dev, resno);
fw_addr = pcibios_retrieve_fw_addr(dev, resno); fw_addr = pcibios_retrieve_fw_addr(dev, resno);
if (!fw_addr) if (!fw_addr)
...@@ -231,12 +234,11 @@ static int pci_revert_fw_address(struct resource *res, struct pci_dev *dev, ...@@ -231,12 +234,11 @@ static int pci_revert_fw_address(struct resource *res, struct pci_dev *dev,
root = &iomem_resource; root = &iomem_resource;
} }
pci_info(dev, "BAR %d: trying firmware assignment %pR\n", pci_info(dev, "%s: trying firmware assignment %pR\n", res_name, res);
resno, res);
conflict = request_resource_conflict(root, res); conflict = request_resource_conflict(root, res);
if (conflict) { if (conflict) {
pci_info(dev, "BAR %d: %pR conflicts with %s %pR\n", pci_info(dev, "%s %pR: conflicts with %s %pR\n", res_name, res,
resno, res, conflict->name, conflict); conflict->name, conflict);
res->start = start; res->start = start;
res->end = end; res->end = end;
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
...@@ -325,6 +327,7 @@ static int _pci_assign_resource(struct pci_dev *dev, int resno, ...@@ -325,6 +327,7 @@ static int _pci_assign_resource(struct pci_dev *dev, int resno,
int pci_assign_resource(struct pci_dev *dev, int resno) int pci_assign_resource(struct pci_dev *dev, int resno)
{ {
struct resource *res = dev->resource + resno; struct resource *res = dev->resource + resno;
const char *res_name = pci_resource_name(dev, resno);
resource_size_t align, size; resource_size_t align, size;
int ret; int ret;
...@@ -334,8 +337,8 @@ int pci_assign_resource(struct pci_dev *dev, int resno) ...@@ -334,8 +337,8 @@ int pci_assign_resource(struct pci_dev *dev, int resno)
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
align = pci_resource_alignment(dev, res); align = pci_resource_alignment(dev, res);
if (!align) { if (!align) {
pci_info(dev, "BAR %d: can't assign %pR (bogus alignment)\n", pci_info(dev, "%s %pR: can't assign; bogus alignment\n",
resno, res); res_name, res);
return -EINVAL; return -EINVAL;
} }
...@@ -348,18 +351,18 @@ int pci_assign_resource(struct pci_dev *dev, int resno) ...@@ -348,18 +351,18 @@ int pci_assign_resource(struct pci_dev *dev, int resno)
* working, which is better than just leaving it disabled. * working, which is better than just leaving it disabled.
*/ */
if (ret < 0) { if (ret < 0) {
pci_info(dev, "BAR %d: no space for %pR\n", resno, res); pci_info(dev, "%s %pR: can't assign; no space\n", res_name, res);
ret = pci_revert_fw_address(res, dev, resno, size); ret = pci_revert_fw_address(res, dev, resno, size);
} }
if (ret < 0) { if (ret < 0) {
pci_info(dev, "BAR %d: failed to assign %pR\n", resno, res); pci_info(dev, "%s %pR: failed to assign\n", res_name, res);
return ret; return ret;
} }
res->flags &= ~IORESOURCE_UNSET; res->flags &= ~IORESOURCE_UNSET;
res->flags &= ~IORESOURCE_STARTALIGN; res->flags &= ~IORESOURCE_STARTALIGN;
pci_info(dev, "BAR %d: assigned %pR\n", resno, res); pci_info(dev, "%s %pR: assigned\n", res_name, res);
if (resno < PCI_BRIDGE_RESOURCES) if (resno < PCI_BRIDGE_RESOURCES)
pci_update_resource(dev, resno); pci_update_resource(dev, resno);
...@@ -367,10 +370,11 @@ int pci_assign_resource(struct pci_dev *dev, int resno) ...@@ -367,10 +370,11 @@ int pci_assign_resource(struct pci_dev *dev, int resno)
} }
EXPORT_SYMBOL(pci_assign_resource); EXPORT_SYMBOL(pci_assign_resource);
int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsize, int pci_reassign_resource(struct pci_dev *dev, int resno,
resource_size_t min_align) resource_size_t addsize, resource_size_t min_align)
{ {
struct resource *res = dev->resource + resno; struct resource *res = dev->resource + resno;
const char *res_name = pci_resource_name(dev, resno);
unsigned long flags; unsigned long flags;
resource_size_t new_size; resource_size_t new_size;
int ret; int ret;
...@@ -381,8 +385,8 @@ int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsiz ...@@ -381,8 +385,8 @@ int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsiz
flags = res->flags; flags = res->flags;
res->flags |= IORESOURCE_UNSET; res->flags |= IORESOURCE_UNSET;
if (!res->parent) { if (!res->parent) {
pci_info(dev, "BAR %d: can't reassign an unassigned resource %pR\n", pci_info(dev, "%s %pR: can't reassign; unassigned resource\n",
resno, res); res_name, res);
return -EINVAL; return -EINVAL;
} }
...@@ -391,15 +395,15 @@ int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsiz ...@@ -391,15 +395,15 @@ int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsiz
ret = _pci_assign_resource(dev, resno, new_size, min_align); ret = _pci_assign_resource(dev, resno, new_size, min_align);
if (ret) { if (ret) {
res->flags = flags; res->flags = flags;
pci_info(dev, "BAR %d: %pR (failed to expand by %#llx)\n", pci_info(dev, "%s %pR: failed to expand by %#llx\n",
resno, res, (unsigned long long) addsize); res_name, res, (unsigned long long) addsize);
return ret; return ret;
} }
res->flags &= ~IORESOURCE_UNSET; res->flags &= ~IORESOURCE_UNSET;
res->flags &= ~IORESOURCE_STARTALIGN; res->flags &= ~IORESOURCE_STARTALIGN;
pci_info(dev, "BAR %d: reassigned %pR (expanded by %#llx)\n", pci_info(dev, "%s %pR: reassigned; expanded by %#llx\n",
resno, res, (unsigned long long) addsize); res_name, res, (unsigned long long) addsize);
if (resno < PCI_BRIDGE_RESOURCES) if (resno < PCI_BRIDGE_RESOURCES)
pci_update_resource(dev, resno); pci_update_resource(dev, resno);
...@@ -409,8 +413,9 @@ int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsiz ...@@ -409,8 +413,9 @@ int pci_reassign_resource(struct pci_dev *dev, int resno, resource_size_t addsiz
void pci_release_resource(struct pci_dev *dev, int resno) void pci_release_resource(struct pci_dev *dev, int resno)
{ {
struct resource *res = dev->resource + resno; struct resource *res = dev->resource + resno;
const char *res_name = pci_resource_name(dev, resno);
pci_info(dev, "BAR %d: releasing %pR\n", resno, res); pci_info(dev, "%s %pR: releasing\n", res_name, res);
if (!res->parent) if (!res->parent)
return; return;
...@@ -480,6 +485,7 @@ int pci_enable_resources(struct pci_dev *dev, int mask) ...@@ -480,6 +485,7 @@ int pci_enable_resources(struct pci_dev *dev, int mask)
u16 cmd, old_cmd; u16 cmd, old_cmd;
int i; int i;
struct resource *r; struct resource *r;
const char *r_name;
pci_read_config_word(dev, PCI_COMMAND, &cmd); pci_read_config_word(dev, PCI_COMMAND, &cmd);
old_cmd = cmd; old_cmd = cmd;
...@@ -488,6 +494,8 @@ int pci_enable_resources(struct pci_dev *dev, int mask) ...@@ -488,6 +494,8 @@ int pci_enable_resources(struct pci_dev *dev, int mask)
if (!(mask & (1 << i))) if (!(mask & (1 << i)))
continue; continue;
r_name = pci_resource_name(dev, i);
if (!(r->flags & (IORESOURCE_IO | IORESOURCE_MEM))) if (!(r->flags & (IORESOURCE_IO | IORESOURCE_MEM)))
continue; continue;
if ((i == PCI_ROM_RESOURCE) && if ((i == PCI_ROM_RESOURCE) &&
...@@ -495,14 +503,14 @@ int pci_enable_resources(struct pci_dev *dev, int mask) ...@@ -495,14 +503,14 @@ int pci_enable_resources(struct pci_dev *dev, int mask)
continue; continue;
if (r->flags & IORESOURCE_UNSET) { if (r->flags & IORESOURCE_UNSET) {
pci_err(dev, "can't enable device: BAR %d %pR not assigned\n", pci_err(dev, "%s %pR: not assigned; can't enable device\n",
i, r); r_name, r);
return -EINVAL; return -EINVAL;
} }
if (!r->parent) { if (!r->parent) {
pci_err(dev, "can't enable device: BAR %d %pR not claimed\n", pci_err(dev, "%s %pR: not claimed; can't enable device\n",
i, r); r_name, r);
return -EINVAL; return -EINVAL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment