Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/pci - Don't try to sizing a BAR not if a device is h...
details: https://anonhg.NetBSD.org/src/rev/640c346c4323
branches: trunk
changeset: 352120:640c346c4323
user: msaitoh <msaitoh%NetBSD.org@localhost>
date: Fri Mar 17 08:51:44 2017 +0000
description:
- Don't try to sizing a BAR not if a device is host bridge but a device's
PCI_COMMAND_MEM_ENABLE is set.
- Fix 17 years old bug that all effective BARs are marked "not sized" on
pcictl pciN dump.
- Print BAR's window size on pcictl pciN dump.
- remove extra "(?)"
diffstat:
sys/dev/pci/pci_subr.c | 125 ++++++++++++++++++------------------------------
1 files changed, 46 insertions(+), 79 deletions(-)
diffs (261 lines):
diff -r 31cabd286f51 -r 640c346c4323 sys/dev/pci/pci_subr.c
--- a/sys/dev/pci/pci_subr.c Fri Mar 17 06:52:59 2017 +0000
+++ b/sys/dev/pci/pci_subr.c Fri Mar 17 08:51:44 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pci_subr.c,v 1.166 2017/03/14 08:27:13 msaitoh Exp $ */
+/* $NetBSD: pci_subr.c,v 1.167 2017/03/17 08:51:44 msaitoh Exp $ */
/*
* Copyright (c) 1997 Zubin D. Dittia. All rights reserved.
@@ -40,7 +40,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pci_subr.c,v 1.166 2017/03/14 08:27:13 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pci_subr.c,v 1.167 2017/03/17 08:51:44 msaitoh Exp $");
#ifdef _KERNEL_OPT
#include "opt_pci.h"
@@ -884,21 +884,18 @@
#ifdef _KERNEL
pci_chipset_tag_t pc, pcitag_t tag,
#endif
- const pcireg_t *regs, int reg, const char *name
-#ifdef _KERNEL
- , int sizebar
-#endif
- )
+ const pcireg_t *regs, int reg, const char *name)
{
int width;
pcireg_t rval, rval64h;
-#ifdef _KERNEL
- int s;
- pcireg_t mask, mask64h;
-#endif
+ bool ioen, memen;
+ pcireg_t mask, mask64h = 0;
+
+ rval = regs[o2i(PCI_COMMAND_STATUS_REG)];
+ ioen = rval & PCI_COMMAND_IO_ENABLE;
+ memen = rval & PCI_COMMAND_MEM_ENABLE;
width = 4;
-
/*
* Section 6.2.5.1, `Address Maps', tells us that:
*
@@ -919,8 +916,9 @@
rval64h = 0;
#ifdef _KERNEL
- /* XXX don't size unknown memory type? */
- if (rval != 0 && sizebar) {
+ if (rval != 0 && memen) {
+ int s;
+
/*
* The following sequence seems to make some devices
* (e.g. host bus bridges, which don't normally
@@ -939,19 +937,23 @@
pci_conf_write(pc, tag, reg + 4, 0xffffffff);
mask64h = pci_conf_read(pc, tag, reg + 4);
pci_conf_write(pc, tag, reg + 4, rval64h);
- } else
- mask64h = 0;
+ }
splx(s);
} else
- mask = mask64h = 0;
#endif /* _KERNEL */
+ {
+ mask = regs[o2i(reg)];
+ if (PCI_MAPREG_TYPE(rval) == PCI_MAPREG_TYPE_MEM &&
+ PCI_MAPREG_MEM_TYPE(rval) == PCI_MAPREG_MEM_TYPE_64BIT)
+ mask64h = regs[o2i(reg + 4)];
+ }
printf(" Base address register at 0x%02x", reg);
if (name)
printf(" (%s)", name);
printf("\n ");
if (rval == 0) {
- printf("not implemented(?)\n");
+ printf("not implemented\n");
return width;
}
printf("type: ");
@@ -979,47 +981,34 @@
printf("%s %sprefetchable memory\n", type, prefetch);
switch (PCI_MAPREG_MEM_TYPE(rval)) {
case PCI_MAPREG_MEM_TYPE_64BIT:
- printf(" base: 0x%016llx, ",
+ printf(" base: 0x%016llx\n",
PCI_MAPREG_MEM64_ADDR(
((((long long) rval64h) << 32) | rval)));
-#ifdef _KERNEL
- if (sizebar)
- printf("size: 0x%016llx",
- PCI_MAPREG_MEM64_SIZE(
- ((((long long) mask64h) << 32) | mask)));
- else
-#endif /* _KERNEL */
- printf("not sized");
+ printf(" size: 0x%016llx",
+ PCI_MAPREG_MEM64_SIZE(
+ ((((long long) mask64h) << 32) | mask)));
+ if (!memen)
+ printf(", disabled");
printf("\n");
break;
case PCI_MAPREG_MEM_TYPE_32BIT:
case PCI_MAPREG_MEM_TYPE_32BIT_1M:
default:
- printf(" base: 0x%08x, ",
- PCI_MAPREG_MEM_ADDR(rval));
-#ifdef _KERNEL
- if (sizebar)
- printf("size: 0x%08x",
- PCI_MAPREG_MEM_SIZE(mask));
- else
-#endif /* _KERNEL */
- printf("not sized");
+ printf(" base: 0x%08x\n",
+ PCI_MAPREG_MEM_ADDR(rval)),
+ printf(" size: 0x%08x",
+ PCI_MAPREG_MEM_SIZE(mask));
+ if (!memen)
+ printf(", disabled");
printf("\n");
break;
}
} else {
-#ifdef _KERNEL
- if (sizebar)
- printf("%d-bit ", mask & ~0x0000ffff ? 32 : 16);
-#endif /* _KERNEL */
- printf("i/o\n");
- printf(" base: 0x%08x, ", PCI_MAPREG_IO_ADDR(rval));
-#ifdef _KERNEL
- if (sizebar)
- printf("size: 0x%08x", PCI_MAPREG_IO_SIZE(mask));
- else
-#endif /* _KERNEL */
- printf("not sized");
+ printf("%d-bit I/O\n", mask & ~0x0000ffff ? 32 : 16);
+ printf(" base: 0x%08x\n", PCI_MAPREG_IO_ADDR(rval));
+ printf(" size: 0x%08x", PCI_MAPREG_IO_SIZE(mask));
+ if (!ioen)
+ printf(", disabled");
printf("\n");
}
@@ -3866,18 +3855,14 @@
#ifdef _KERNEL
pci_chipset_tag_t pc, pcitag_t tag,
#endif
- const pcireg_t *regs
-#ifdef _KERNEL
- , int sizebars
-#endif
- )
+ const pcireg_t *regs)
{
int off, width;
pcireg_t rval;
for (off = PCI_MAPREG_START; off < PCI_MAPREG_END; off += width) {
#ifdef _KERNEL
- width = pci_conf_print_bar(pc, tag, regs, off, NULL, sizebars);
+ width = pci_conf_print_bar(pc, tag, regs, off, NULL);
#else
width = pci_conf_print_bar(regs, off, NULL);
#endif
@@ -3933,11 +3918,7 @@
#ifdef _KERNEL
pci_chipset_tag_t pc, pcitag_t tag,
#endif
- const pcireg_t *regs
-#ifdef _KERNEL
- , int sizebars
-#endif
- )
+ const pcireg_t *regs)
{
int off, width;
pcireg_t rval;
@@ -3954,7 +3935,7 @@
for (off = 0x10; off < 0x18; off += width) {
#ifdef _KERNEL
- width = pci_conf_print_bar(pc, tag, regs, off, NULL, sizebars);
+ width = pci_conf_print_bar(pc, tag, regs, off, NULL);
#else
width = pci_conf_print_bar(regs, off, NULL);
#endif
@@ -4109,11 +4090,7 @@
#ifdef _KERNEL
pci_chipset_tag_t pc, pcitag_t tag,
#endif
- const pcireg_t *regs
-#ifdef _KERNEL
- , int sizebars
-#endif
- )
+ const pcireg_t *regs)
{
pcireg_t rval;
@@ -4128,7 +4105,7 @@
#ifdef _KERNEL
pci_conf_print_bar(pc, tag, regs, 0x10,
- "CardBus socket/ExCA registers", sizebars);
+ "CardBus socket/ExCA registers");
#else
pci_conf_print_bar(regs, 0x10, "CardBus socket/ExCA registers");
#endif
@@ -4212,8 +4189,7 @@
printf(" Subsystem ID: 0x%04x\n", PCI_PRODUCT(rval));
#ifdef _KERNEL
- pci_conf_print_bar(pc, tag, regs, 0x44, "legacy-mode registers",
- sizebars);
+ pci_conf_print_bar(pc, tag, regs, 0x44, "legacy-mode registers");
#else
pci_conf_print_bar(regs, 0x44, "legacy-mode registers");
#endif
@@ -4233,9 +4209,7 @@
int off, capoff, endoff, hdrtype;
const char *type_name;
#ifdef _KERNEL
- void (*type_printfn)(pci_chipset_tag_t, pcitag_t, const pcireg_t *,
- int);
- int sizebars;
+ void (*type_printfn)(pci_chipset_tag_t, pcitag_t, const pcireg_t *);
#else
void (*type_printfn)(const pcireg_t *);
#endif
@@ -4252,13 +4226,6 @@
#endif
}
-#ifdef _KERNEL
- sizebars = 1;
- if (PCI_CLASS(regs[o2i(PCI_CLASS_REG)]) == PCI_CLASS_BRIDGE &&
- PCI_SUBCLASS(regs[o2i(PCI_CLASS_REG)]) == PCI_SUBCLASS_BRIDGE_HOST)
- sizebars = 0;
-#endif
-
/* common header */
printf(" Common header:\n");
pci_conf_print_regs(regs, 0, 16);
@@ -4310,7 +4277,7 @@
printf("\n");
if (type_printfn) {
#ifdef _KERNEL
- (*type_printfn)(pc, tag, regs, sizebars);
+ (*type_printfn)(pc, tag, regs);
#else
(*type_printfn)(regs);
#endif
Home |
Main Index |
Thread Index |
Old Index