aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorFUJITA Tomonori <tomof@acm.org>2008-02-05 01:27:55 -0500
committerLinus Torvalds <torvalds@woody.linux-foundation.org>2008-02-05 12:44:10 -0500
commit4d57cdfacaa1c207bf4c071f89835e0368766a50 (patch)
treeb0b617efcd2e228573e42e7efbea4a95955ddf70 /drivers
parent6b7b651055221127304a4e373ee9b762398d54d7 (diff)
iommu sg merging: PCI: add device_dma_parameters support
This adds struct device_dma_parameters in struct pci_dev and properly sets up a pointer in struct device. The default max_segment_size is set to 64K, same to the block layer's default value. Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> Mostly-acked-by: Jeff Garzik <jeff@garzik.org> Cc: James Bottomley <James.Bottomley@steeleye.com> Acked-by: Jens Axboe <jens.axboe@oracle.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/pci/pci.c8
-rw-r--r--drivers/pci/probe.c3
2 files changed, 11 insertions, 0 deletions
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c
index 04aac7782468..be97090ddf32 100644
--- a/drivers/pci/pci.c
+++ b/drivers/pci/pci.c
@@ -1451,6 +1451,14 @@ pci_set_consistent_dma_mask(struct pci_dev *dev, u64 mask)
1451} 1451}
1452#endif 1452#endif
1453 1453
1454#ifndef HAVE_ARCH_PCI_SET_DMA_MAX_SEGMENT_SIZE
1455int pci_set_dma_max_seg_size(struct pci_dev *dev, unsigned int size)
1456{
1457 return dma_set_max_seg_size(&dev->dev, size);
1458}
1459EXPORT_SYMBOL(pci_set_dma_max_seg_size);
1460#endif
1461
1454/** 1462/**
1455 * pcix_get_max_mmrbc - get PCI-X maximum designed memory read byte count 1463 * pcix_get_max_mmrbc - get PCI-X maximum designed memory read byte count
1456 * @dev: PCI device to query 1464 * @dev: PCI device to query
diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index 7f5dab34d315..f47d596d5ebc 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -933,8 +933,11 @@ void pci_device_add(struct pci_dev *dev, struct pci_bus *bus)
933 933
934 set_dev_node(&dev->dev, pcibus_to_node(bus)); 934 set_dev_node(&dev->dev, pcibus_to_node(bus));
935 dev->dev.dma_mask = &dev->dma_mask; 935 dev->dev.dma_mask = &dev->dma_mask;
936 dev->dev.dma_parms = &dev->dma_parms;
936 dev->dev.coherent_dma_mask = 0xffffffffull; 937 dev->dev.coherent_dma_mask = 0xffffffffull;
937 938
939 pci_set_dma_max_seg_size(dev, 65536);
940
938 /* Fix up broken headers */ 941 /* Fix up broken headers */
939 pci_fixup_device(pci_fixup_header, dev); 942 pci_fixup_device(pci_fixup_header, dev);
940 943