summaryrefslogtreecommitdiff
path: root/sys/dev/pci
diff options
context:
space:
mode:
authorMartin Pieuchot <mpi@cvs.openbsd.org>2012-12-22 19:17:37 +0000
committerMartin Pieuchot <mpi@cvs.openbsd.org>2012-12-22 19:17:37 +0000
commit4af5c6be548fdfa84e9a78ac3d20bf7d3a8897bc (patch)
tree4dd82e77a48ad261d8c1b3b7e4b522c746c5a7a6 /sys/dev/pci
parent0d80214797ba3d4e55b573007090af10935dbc44 (diff)
Add support for U3 brigdes present in macppc G5 machines. Many thanks
to Chris Jackman for sending me a PowerMac G5!
Diffstat (limited to 'sys/dev/pci')
-rw-r--r--sys/dev/pci/agp_apple.c59
-rw-r--r--sys/dev/pci/agpreg.h3
2 files changed, 39 insertions, 23 deletions
diff --git a/sys/dev/pci/agp_apple.c b/sys/dev/pci/agp_apple.c
index 10fed199f48..07662c72c86 100644
--- a/sys/dev/pci/agp_apple.c
+++ b/sys/dev/pci/agp_apple.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: agp_apple.c,v 1.1 2012/12/04 10:42:04 mpi Exp $ */
+/* $OpenBSD: agp_apple.c,v 1.2 2012/12/22 19:17:36 mpi Exp $ */
/*
* Copyright (c) 2012 Martin Pieuchot <mpi@openbsd.org>
@@ -42,6 +42,8 @@ struct agp_apple_softc {
pcitag_t asc_tag;
bus_addr_t asc_apaddr;
bus_size_t asc_apsize;
+ int asc_flags;
+#define AGP_APPLE_ISU3 (1 << 0)
};
int agp_apple_match(struct device *, void *, void *);
@@ -81,21 +83,10 @@ agp_apple_match(struct device *parent, void *match, void *aux)
case PCI_PRODUCT_APPLE_UNINORTH2_AGP:
case PCI_PRODUCT_APPLE_UNINORTH_AGP3:
case PCI_PRODUCT_APPLE_INTREPID2_AGP:
- return (1);
-#if 0
- /*
- * XXX Do not attach U3 bridges to this driver yet.
- *
- * Even though they share the same register layout they
- * use a big-endian GART and need a different set of
- * commands for flushing their TLB. They should also
- * support an aperture of 512M.
- */
case PCI_PRODUCT_APPLE_U3_AGP:
case PCI_PRODUCT_APPLE_U3L_AGP:
case PCI_PRODUCT_APPLE_K2_AGP:
return (1);
-#endif
}
return (0);
@@ -112,6 +103,16 @@ agp_apple_attach(struct device *parent, struct device *self, void *aux)
asc->asc_tag = pa->pa_tag;
asc->asc_pc = pa->pa_pc;
+ switch (PCI_PRODUCT(pa->pa_id)) {
+ case PCI_PRODUCT_APPLE_U3_AGP:
+ case PCI_PRODUCT_APPLE_U3L_AGP:
+ case PCI_PRODUCT_APPLE_K2_AGP:
+ asc->asc_flags |= AGP_APPLE_ISU3;
+ break;
+ default:
+ break;
+ }
+
/*
* XXX It looks like UniNorth GART only accepts an aperture
* base address of 0x00 certainly because it does not perform
@@ -123,7 +124,7 @@ agp_apple_attach(struct device *parent, struct device *self, void *aux)
/*
* There's no way to read the aperture size but all UniNorth
- * chips seem to support an aperture of 256M.
+ * chips seem to support an aperture of 256M (and 512M for U3).
*/
asc->asc_apsize = 256 * M;
for (;;) {
@@ -174,11 +175,17 @@ void
agp_apple_bind_page(void *v, bus_addr_t off, paddr_t pa, int flags)
{
struct agp_apple_softc *asc = v;
+ uint32_t entry;
if (off >= (asc->gatt->ag_entries << AGP_PAGE_SHIFT))
return;
- asc->gatt->ag_virtual[off >> AGP_PAGE_SHIFT] = htole32(pa | 0x01);
+ if (asc->asc_flags & AGP_APPLE_ISU3)
+ entry = (pa >> PAGE_SHIFT | 0x80000000);
+ else
+ entry = htole32(pa | 0x01);
+
+ asc->gatt->ag_virtual[off >> AGP_PAGE_SHIFT] = entry;
flushd(&asc->gatt->ag_virtual[off >> AGP_PAGE_SHIFT]);
}
@@ -203,12 +210,20 @@ agp_apple_flush_tlb(void *v)
{
struct agp_apple_softc *asc = v;
- pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
- AGP_APPLE_GART_ENABLE | AGP_APPLE_GART_INVALIDATE);
- pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
- AGP_APPLE_GART_ENABLE);
- pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
- AGP_APPLE_GART_ENABLE | AGP_APPLE_GART_2XRESET);
- pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
- AGP_APPLE_GART_ENABLE);
+ if (asc->asc_flags & AGP_APPLE_ISU3) {
+ pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
+ AGP_APPLE_GART_ENABLE | AGP_APPLE_GART_PERFRD |
+ AGP_APPLE_GART_INVALIDATE);
+ pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
+ AGP_APPLE_GART_ENABLE | AGP_APPLE_GART_PERFRD);
+ } else {
+ pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
+ AGP_APPLE_GART_ENABLE | AGP_APPLE_GART_INVALIDATE);
+ pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
+ AGP_APPLE_GART_ENABLE);
+ pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
+ AGP_APPLE_GART_ENABLE | AGP_APPLE_GART_2XRESET);
+ pci_conf_write(asc->asc_pc, asc->asc_tag, AGP_APPLE_GARTCTRL,
+ AGP_APPLE_GART_ENABLE);
+ }
}
diff --git a/sys/dev/pci/agpreg.h b/sys/dev/pci/agpreg.h
index 67f959e849e..f8269c9292a 100644
--- a/sys/dev/pci/agpreg.h
+++ b/sys/dev/pci/agpreg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: agpreg.h,v 1.16 2012/12/04 10:42:04 mpi Exp $ */
+/* $OpenBSD: agpreg.h,v 1.17 2012/12/22 19:17:36 mpi Exp $ */
/* $NetBSD: agpreg.h,v 1.1 2001/09/10 10:01:02 fvdl Exp $ */
/*-
@@ -120,6 +120,7 @@
#define AGP_APPLE_GART_INVALIDATE 0x00001
#define AGP_APPLE_GART_ENABLE 0x00100
#define AGP_APPLE_GART_2XRESET 0x10000
+#define AGP_APPLE_GART_PERFRD 0x80000
/*
* Config offsets for Ali AGP chipsets.