summaryrefslogtreecommitdiffstats
path: root/sys/sparc64/pci/psychoreg.h
diff options
context:
space:
mode:
authormarius <marius@FreeBSD.org>2007-08-05 11:56:44 +0000
committermarius <marius@FreeBSD.org>2007-08-05 11:56:44 +0000
commit5a1a2bd9cf95421a0c3026645d8824333a77a4cf (patch)
treec917da70660ade216479598d5e93f30e756eb31e /sys/sparc64/pci/psychoreg.h
parent73b31fd6b229633176825dd2f203d59947b34938 (diff)
downloadFreeBSD-src-5a1a2bd9cf95421a0c3026645d8824333a77a4cf.zip
FreeBSD-src-5a1a2bd9cf95421a0c3026645d8824333a77a4cf.tar.gz
- Divorce the IOTSBs, which so far where handled via a global list
instead of per IOMMU, so we no longer need to program all of them identically in systems having multiple IOMMUs. This continues the rototilling of the nexus(4) done about 5 months ago, which amongst others changed nexus(4) and the drivers for host-to-foo bridges to provide bus_get_dma_tag methods, allowing to handle DMA tags in a hierarchical way and to link them with devices. This still doesn't move the silicon bug workarounds for Sabre (and in the uncommitted schizo(4) for Tomatillo) bridges into special bus_dma_tag_create() and bus_dmamap_sync() methods though, as w/o fully newbus'ified bus_dma_tag_create() and bus_dma_tag_destroy() this still requires too much hackery, i.e. per-child parent DMA tags in the parent driver. - Let the host-to-foo drivers supply the maximum physical address of the IOMMU accompanying the bridges. Previously iommu(4) hard- coded an upper limit of 16GB, which actually only applies to the IOMMUs of the Hummingbird and Sabre bridges. The Psycho variants as well as the U2S in fact can can translate to up to 2TB, i.e. translate to 41-bit physical addresses. According to the recently available Tomatillo documentation these bridges even translate to 43-bit physical addresses and hints at the Schizo bridges doing 43 bits as well. This fixes the issue the FreeBSD 6.0 todo list item "Max RAM on sparc64" was refering to and pretty much obsoletes the lack of support for bounce buffers on sparc64. Thanks to Nathan Whitehorn for pointing me at the Tomatillo manual. Approved by: re (kensmith)
Diffstat (limited to 'sys/sparc64/pci/psychoreg.h')
-rw-r--r--sys/sparc64/pci/psychoreg.h4
1 files changed, 4 insertions, 0 deletions
diff --git a/sys/sparc64/pci/psychoreg.h b/sys/sparc64/pci/psychoreg.h
index 1bf300f..b15e3d9 100644
--- a/sys/sparc64/pci/psychoreg.h
+++ b/sys/sparc64/pci/psychoreg.h
@@ -299,4 +299,8 @@
#define PCSR_SECBUS 0x40 /* Secondary bus number register */
#define PCSR_SUBBUS 0x41 /* Subordinate bus number register */
+/* Width of the physical addresses the IOMMU translates to */
+#define PSYCHO_IOMMU_BITS 41
+#define SABRE_IOMMU_BITS 34
+
#endif /* !_SPARC64_PCI_PSYCHOREG_H_ */
OpenPOWER on IntegriCloud