x86: Kill bad_dma_address variable
authorFUJITA Tomonori <[email protected]>
Sun, 15 Nov 2009 12:19:53 +0000 (21:19 +0900)
committerIngo Molnar <[email protected]>
Tue, 17 Nov 2009 06:53:21 +0000 (07:53 +0100)
commit8fd524b355daef0945692227e726fb444cebcd4f
treed9c067e6e2693d46b70010a4ed2910205a59c92d
parent42109197eb7c01080eea6d9cd48ca23cbc3c566c
x86: Kill bad_dma_address variable

This kills bad_dma_address variable, the old mechanism to enable
IOMMU drivers to make dma_mapping_error() work in IOMMU's
specific way.

bad_dma_address variable was introduced to enable IOMMU drivers
to make dma_mapping_error() work in IOMMU's specific way.
However, it can't handle systems that use both swiotlb and HW
IOMMU. SO we introduced dma_map_ops->mapping_error to solve that
case.

Intel VT-d, GART, and swiotlb already use
dma_map_ops->mapping_error. Calgary, AMD IOMMU, and nommu use
zero for an error dma address. This adds DMA_ERROR_CODE and
converts them to use it (as SPARC and POWER does).

Signed-off-by: FUJITA Tomonori <[email protected]>
Acked-by: Jesse Barnes <[email protected]>
Cc: [email protected]
Cc: [email protected]
LKML-Reference: <1258287594[email protected]>
Signed-off-by: Ingo Molnar <[email protected]>
arch/x86/include/asm/dma-mapping.h
arch/x86/kernel/amd_iommu.c
arch/x86/kernel/pci-calgary_64.c
arch/x86/kernel/pci-dma.c
arch/x86/kernel/pci-nommu.c