IOMMUs merges scatter/gather segments without considering a low level driver's restrictions. The problem is that IOMMUs can't access to the limitations because they are in request_queue. This patchset introduces a new structure, device_dma_parameters, including dma information. A pointer to device_dma_parameters is added to struct device. The bus specific structures (like pci_dev) includes device_dma_parameters. Low level drivers can use dma_set_max_seg_size to tell IOMMUs about the restrictions. We can move more dma stuff in struct device (like dma_mask) to struct device_dma_parameters later (needs some cleanups before that). This includes patches for all the IOMMUs that could merge sg (x86_64, ppc, IA64, alpha, sparc64, and parisc) though only the ppc patch was tested. The patches for other IOMMUs are only compile tested. Thanks to everyone for the comments on the previous submission to linux-scsi. This is against 2.6.24-rc1. The same patchset is also available: git://git.kernel.org/pub/scm/linux/kernel/git/tomo/linux-2.6-misc.git iommu-sg-fixes - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
- Follow-Ups:
- Re: [PATCH -mm 0/11] fix iommu sg merging problem
- From: Jens Axboe <[email protected]>
- Re: [PATCH -mm 0/11] fix iommu sg merging problem
- From: Jeff Garzik <[email protected]>
- [PATCH -mm 02/11] PCI: add device_dma_parameters support
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 01/11] add device_dma_parameters structure
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 03/11] x86: make pci-gart iommu respect the segment size limits
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 04/11] ppc: make iommu respect the segment size limits
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 06/11] alpha: make pci_iommu respect the segment size limits
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 11/11] aacraid: use pci_set_dma_max_seg_size
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 08/11] parisc: make iommu respect the segment size limits
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 10/11] sata_inic162x: use pci_set_dma_max_seg_size
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 09/11] call blk_queue_segment_boundary in __scsi_alloc_queue
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 07/11] sparc64: make iommu respect the segment size limits
- From: FUJITA Tomonori <[email protected]>
- [PATCH -mm 05/11] IA64: make sba_iommu respect the segment size limits
- From: FUJITA Tomonori <[email protected]>
- Re: [PATCH -mm 0/11] fix iommu sg merging problem
- Prev by Date: [PATCH -mm 08/11] parisc: make iommu respect the segment size limits
- Next by Date: [PATCH 1/4] x86 gart: rename iommu.h to gart.h
- Previous by thread: [PATCH] hptiop: fix type mismatch warning
- Next by thread: [PATCH -mm 05/11] IA64: make sba_iommu respect the segment size limits
- Index(es):