From: Bjorn Helgaas <bjorn.helgaas@xxxxxxxxx> Date: Sun, 29 Mar 2015 08:30:40 -0500 > Help me understand the sparc64 situation: are you saying that BAR > addresses, i.e., MMIO transactions from a CPU or a peer-to-peer DMA can be > 64 bits, but a DMA to main memory can only be 32 bits? > > I assume this would work if we made dma_addr_t 64 bits on sparc64. What > would be the cost of doing that? The cost is 4 extra bytes in every datastructure, kernel wide, that stores DMA addresses. This choice was very intentional, and well thought out. Don't use DMA addresses for PCI addresses. They are absolutely not the same, especially when an IOMMU is always present because in that case all DMA addresses are virtual and exist in a different realm and set of constraints/restrictions. -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html