summaryrefslogtreecommitdiff
path: root/sys/arch/amd64/pci/pci_machdep.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/amd64/pci/pci_machdep.c')
-rw-r--r--sys/arch/amd64/pci/pci_machdep.c230
1 files changed, 19 insertions, 211 deletions
diff --git a/sys/arch/amd64/pci/pci_machdep.c b/sys/arch/amd64/pci/pci_machdep.c
index 29d371f7067..19137f17676 100644
--- a/sys/arch/amd64/pci/pci_machdep.c
+++ b/sys/arch/amd64/pci/pci_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pci_machdep.c,v 1.27 2009/04/21 17:05:29 oga Exp $ */
+/* $OpenBSD: pci_machdep.c,v 1.28 2009/04/21 19:18:09 kettenis Exp $ */
/* $NetBSD: pci_machdep.c,v 1.3 2003/05/07 21:33:58 fvdl Exp $ */
/*-
@@ -63,14 +63,6 @@
/*
* Machine-specific functions for PCI autoconfiguration.
- *
- * On PCs, there are two methods of generating PCI configuration cycles.
- * We try to detect the appropriate mechanism for this machine and set
- * up a few function pointers to access the correct method directly.
- *
- * The configuration method can be hard-coded in the config file by
- * using `options PCI_CONF_MODE=N', where `N' is the configuration mode
- * as defined section 3.6.4.1, `Generating Configuration Cycles'.
*/
#include <sys/types.h>
@@ -104,8 +96,6 @@
#include <machine/mpbiosvar.h>
#endif
-int pci_mode = -1;
-
struct mutex pci_conf_lock = MUTEX_INITIALIZER(IPL_HIGH);
#define PCI_CONF_LOCK() \
@@ -122,30 +112,6 @@ do { \
#define PCI_MODE1_ADDRESS_REG 0x0cf8
#define PCI_MODE1_DATA_REG 0x0cfc
-#define PCI_MODE2_ENABLE_REG 0x0cf8
-#define PCI_MODE2_FORWARD_REG 0x0cfa
-
-#define _m1tag(b, d, f) \
- (PCI_MODE1_ENABLE | ((b) << 16) | ((d) << 11) | ((f) << 8))
-#define _qe(bus, dev, fcn, vend, prod) \
- {_m1tag(bus, dev, fcn), PCI_ID_CODE(vend, prod)}
-struct {
- u_int32_t tag;
- pcireg_t id;
-} pcim1_quirk_tbl[] = {
- _qe(0, 0, 0, PCI_VENDOR_COMPAQ, PCI_PRODUCT_COMPAQ_TRIFLEX1),
- /* XXX Triflex2 not tested */
- _qe(0, 0, 0, PCI_VENDOR_COMPAQ, PCI_PRODUCT_COMPAQ_TRIFLEX2),
- _qe(0, 0, 0, PCI_VENDOR_COMPAQ, PCI_PRODUCT_COMPAQ_TRIFLEX4),
- /* Triton needed for Connectix Virtual PC */
- _qe(0, 0, 0, PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82437FX),
- /* Connectix Virtual PC 5 has a 440BX */
- _qe(0, 0, 0, PCI_VENDOR_INTEL, PCI_PRODUCT_INTEL_82443BX_NOAGP),
- {0, 0xffffffff} /* patchable */
-};
-#undef _m1tag
-#undef _qe
-
/*
* PCI doesn't have any special needs; just use the generic versions
* of these functions.
@@ -173,82 +139,37 @@ void
pci_attach_hook(struct device *parent, struct device *self,
struct pcibus_attach_args *pba)
{
- if (pba->pba_bus == 0) {
- printf(": configuration mode %d", pci_mode);
#ifndef SMALL_KERNEL
+ if (pba->pba_bus == 0)
amdgart_probe(pba);
#endif /* !SMALL_KERNEL */
- }
}
int
pci_bus_maxdevs(pci_chipset_tag_t pc, int busno)
{
-
- /*
- * Bus number is irrelevant. If Configuration Mechanism 2 is in
- * use, can only have devices 0-15 on any bus. If Configuration
- * Mechanism 1 is in use, can have devices 0-32 (i.e. the `normal'
- * range).
- */
- if (pci_mode == 2)
- return (16);
- else
- return (32);
+ return (32);
}
pcitag_t
pci_make_tag(pci_chipset_tag_t pc, int bus, int device, int function)
{
- pcitag_t tag;
-
- switch (pci_mode) {
- case 1:
- if (bus >= 256 || device >= 32 || function >= 8)
- panic("pci_make_tag: bad request");
-
- tag.mode1 = PCI_MODE1_ENABLE |
- (bus << 16) | (device << 11) | (function << 8);
- break;
- case 2:
- if (bus >= 256 || device >= 16 || function >= 8)
- panic("pci_make_tag: bad request");
-
- tag.mode2.port = 0xc000 | (device << 8);
- tag.mode2.enable = 0xf0 | (function << 1);
- tag.mode2.forward = bus;
- break;
- default:
- panic("pci_make_tag: mode not configured");
- }
+ if (bus >= 256 || device >= 32 || function >= 8)
+ panic("pci_make_tag: bad request");
- return tag;
+ return (PCI_MODE1_ENABLE |
+ (bus << 16) | (device << 11) | (function << 8));
}
void
pci_decompose_tag(pci_chipset_tag_t pc, pcitag_t tag, int *bp, int *dp, int *fp)
{
-
- switch (pci_mode) {
- case 1:
- if (bp != NULL)
- *bp = (tag.mode1 >> 16) & 0xff;
- if (dp != NULL)
- *dp = (tag.mode1 >> 11) & 0x1f;
- if (fp != NULL)
- *fp = (tag.mode1 >> 8) & 0x7;
- break;
- case 2:
- if (bp != NULL)
- *bp = tag.mode2.forward & 0xff;
- if (dp != NULL)
- *dp = (tag.mode2.port >> 8) & 0xf;
- if (fp != NULL)
- *fp = (tag.mode2.enable >> 1) & 0x7;
- break;
- default:
- panic("pci_decompose_tag: mode not configured");
- }
+ if (bp != NULL)
+ *bp = (tag >> 16) & 0xff;
+ if (dp != NULL)
+ *dp = (tag >> 11) & 0x1f;
+ if (fp != NULL)
+ *fp = (tag >> 8) & 0x7;
}
pcireg_t
@@ -257,21 +178,9 @@ pci_conf_read(pci_chipset_tag_t pc, pcitag_t tag, int reg)
pcireg_t data;
PCI_CONF_LOCK();
- switch (pci_mode) {
- case 1:
- outl(PCI_MODE1_ADDRESS_REG, tag.mode1 | reg);
- data = inl(PCI_MODE1_DATA_REG);
- outl(PCI_MODE1_ADDRESS_REG, 0);
- break;
- case 2:
- outb(PCI_MODE2_ENABLE_REG, tag.mode2.enable);
- outb(PCI_MODE2_FORWARD_REG, tag.mode2.forward);
- data = inl(tag.mode2.port | reg);
- outb(PCI_MODE2_ENABLE_REG, 0);
- break;
- default:
- panic("pci_conf_read: mode not configured");
- }
+ outl(PCI_MODE1_ADDRESS_REG, tag | reg);
+ data = inl(PCI_MODE1_DATA_REG);
+ outl(PCI_MODE1_ADDRESS_REG, 0);
PCI_CONF_UNLOCK();
return data;
@@ -280,112 +189,11 @@ pci_conf_read(pci_chipset_tag_t pc, pcitag_t tag, int reg)
void
pci_conf_write(pci_chipset_tag_t pc, pcitag_t tag, int reg, pcireg_t data)
{
-
PCI_CONF_LOCK();
- switch (pci_mode) {
- case 1:
- outl(PCI_MODE1_ADDRESS_REG, tag.mode1 | reg);
- outl(PCI_MODE1_DATA_REG, data);
- outl(PCI_MODE1_ADDRESS_REG, 0);
- break;
- case 2:
- outb(PCI_MODE2_ENABLE_REG, tag.mode2.enable);
- outb(PCI_MODE2_FORWARD_REG, tag.mode2.forward);
- outl(tag.mode2.port | reg, data);
- outb(PCI_MODE2_ENABLE_REG, 0);
- break;
- default:
- panic("pci_conf_write: mode not configured");
- }
- PCI_CONF_UNLOCK();
-}
-
-int
-pci_mode_detect(void)
-{
-
-#ifdef PCI_CONF_MODE
-#if (PCI_CONF_MODE == 1) || (PCI_CONF_MODE == 2)
- return (pci_mode = PCI_CONF_MODE);
-#else
-#error Invalid PCI configuration mode.
-#endif
-#else
- u_int32_t sav, val;
- int i;
- pcireg_t idreg;
-
- if (pci_mode != -1)
- return pci_mode;
-
- /*
- * We try to divine which configuration mode the host bridge wants.
- */
-
- sav = inl(PCI_MODE1_ADDRESS_REG);
-
- pci_mode = 1; /* assume this for now */
- /*
- * catch some known buggy implementations of mode 1
- */
- for (i = 0; i < sizeof(pcim1_quirk_tbl) / sizeof(pcim1_quirk_tbl[0]);
- i++) {
- pcitag_t t;
-
- if (!pcim1_quirk_tbl[i].tag)
- break;
- t.mode1 = pcim1_quirk_tbl[i].tag;
- idreg = pci_conf_read(0, t, PCI_ID_REG); /* needs "pci_mode" */
- if (idreg == pcim1_quirk_tbl[i].id) {
-#ifdef DEBUG
- printf("known mode 1 PCI chipset (%08x)\n",
- idreg);
-#endif
- return (pci_mode);
- }
- }
-
- /*
- * Strong check for standard compliant mode 1:
- * 1. bit 31 ("enable") can be set
- * 2. byte/word access does not affect register
- */
- outl(PCI_MODE1_ADDRESS_REG, PCI_MODE1_ENABLE);
- outb(PCI_MODE1_ADDRESS_REG + 3, 0);
- outw(PCI_MODE1_ADDRESS_REG + 2, 0);
- val = inl(PCI_MODE1_ADDRESS_REG);
- if ((val & 0x80fffffc) != PCI_MODE1_ENABLE) {
-#ifdef DEBUG
- printf("pci_mode_detect: mode 1 enable failed (%x)\n",
- val);
-#endif
- goto not1;
- }
+ outl(PCI_MODE1_ADDRESS_REG, tag | reg);
+ outl(PCI_MODE1_DATA_REG, data);
outl(PCI_MODE1_ADDRESS_REG, 0);
- val = inl(PCI_MODE1_ADDRESS_REG);
- if ((val & 0x80fffffc) != 0)
- goto not1;
- return (pci_mode);
-not1:
- outl(PCI_MODE1_ADDRESS_REG, sav);
-
- /*
- * This mode 2 check is quite weak (and known to give false
- * positives on some Compaq machines).
- * However, this doesn't matter, because this is the
- * last test, and simply no PCI devices will be found if
- * this happens.
- */
- outb(PCI_MODE2_ENABLE_REG, 0);
- outb(PCI_MODE2_FORWARD_REG, 0);
- if (inb(PCI_MODE2_ENABLE_REG) != 0 ||
- inb(PCI_MODE2_FORWARD_REG) != 0)
- goto not2;
- return (pci_mode = 2);
-not2:
-
- return (pci_mode = 0);
-#endif
+ PCI_CONF_UNLOCK();
}
int