aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/x86/kernel/pci-dma.c18
-rw-r--r--arch/x86/kernel/pci-dma_32.c13
-rw-r--r--arch/x86/kernel/pci-dma_64.c15
-rw-r--r--include/asm-x86/dma-mapping.h2
4 files changed, 19 insertions, 29 deletions
diff --git a/arch/x86/kernel/pci-dma.c b/arch/x86/kernel/pci-dma.c
index 91443361cb67..48cccbe51aa5 100644
--- a/arch/x86/kernel/pci-dma.c
+++ b/arch/x86/kernel/pci-dma.c
@@ -1,12 +1,16 @@
1#include <linux/dma-mapping.h> 1#include <linux/dma-mapping.h>
2#include <linux/dmar.h> 2#include <linux/dmar.h>
3#include <linux/bootmem.h> 3#include <linux/bootmem.h>
4#include <linux/pci.h>
4 5
5#include <asm/proto.h> 6#include <asm/proto.h>
6#include <asm/dma.h> 7#include <asm/dma.h>
7#include <asm/gart.h> 8#include <asm/gart.h>
8#include <asm/calgary.h> 9#include <asm/calgary.h>
9 10
11int forbid_dac __read_mostly;
12EXPORT_SYMBOL(forbid_dac);
13
10const struct dma_mapping_ops *dma_ops; 14const struct dma_mapping_ops *dma_ops;
11EXPORT_SYMBOL(dma_ops); 15EXPORT_SYMBOL(dma_ops);
12 16
@@ -121,3 +125,17 @@ void pci_iommu_shutdown(void)
121} 125}
122/* Must execute after PCI subsystem */ 126/* Must execute after PCI subsystem */
123fs_initcall(pci_iommu_init); 127fs_initcall(pci_iommu_init);
128
129#ifdef CONFIG_PCI
130/* Many VIA bridges seem to corrupt data for DAC. Disable it here */
131
132static __devinit void via_no_dac(struct pci_dev *dev)
133{
134 if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI && forbid_dac == 0) {
135 printk(KERN_INFO "PCI: VIA PCI bridge detected."
136 "Disabling DAC.\n");
137 forbid_dac = 1;
138 }
139}
140DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_VIA, PCI_ANY_ID, via_no_dac);
141#endif
diff --git a/arch/x86/kernel/pci-dma_32.c b/arch/x86/kernel/pci-dma_32.c
index 9e8297657c32..6543bb30b65d 100644
--- a/arch/x86/kernel/pci-dma_32.c
+++ b/arch/x86/kernel/pci-dma_32.c
@@ -157,9 +157,6 @@ EXPORT_SYMBOL(dma_mark_declared_memory_occupied);
157#ifdef CONFIG_PCI 157#ifdef CONFIG_PCI
158/* Many VIA bridges seem to corrupt data for DAC. Disable it here */ 158/* Many VIA bridges seem to corrupt data for DAC. Disable it here */
159 159
160int forbid_dac;
161EXPORT_SYMBOL(forbid_dac);
162
163int 160int
164dma_supported(struct device *dev, u64 mask) 161dma_supported(struct device *dev, u64 mask)
165{ 162{
@@ -182,16 +179,6 @@ dma_supported(struct device *dev, u64 mask)
182} 179}
183EXPORT_SYMBOL(dma_supported); 180EXPORT_SYMBOL(dma_supported);
184 181
185
186static __devinit void via_no_dac(struct pci_dev *dev)
187{
188 if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI && forbid_dac == 0) {
189 printk(KERN_INFO "PCI: VIA PCI bridge detected. Disabling DAC.\n");
190 forbid_dac = 1;
191 }
192}
193DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_VIA, PCI_ANY_ID, via_no_dac);
194
195static int check_iommu(char *s) 182static int check_iommu(char *s)
196{ 183{
197 if (!strcmp(s, "usedac")) { 184 if (!strcmp(s, "usedac")) {
diff --git a/arch/x86/kernel/pci-dma_64.c b/arch/x86/kernel/pci-dma_64.c
index 6b204cc42890..7820675a688a 100644
--- a/arch/x86/kernel/pci-dma_64.c
+++ b/arch/x86/kernel/pci-dma_64.c
@@ -161,8 +161,6 @@ void dma_free_coherent(struct device *dev, size_t size,
161} 161}
162EXPORT_SYMBOL(dma_free_coherent); 162EXPORT_SYMBOL(dma_free_coherent);
163 163
164static int forbid_dac __read_mostly;
165
166int dma_supported(struct device *dev, u64 mask) 164int dma_supported(struct device *dev, u64 mask)
167{ 165{
168#ifdef CONFIG_PCI 166#ifdef CONFIG_PCI
@@ -270,16 +268,3 @@ static __init int iommu_setup(char *p)
270 return 0; 268 return 0;
271} 269}
272early_param("iommu", iommu_setup); 270early_param("iommu", iommu_setup);
273
274#ifdef CONFIG_PCI
275/* Many VIA bridges seem to corrupt data for DAC. Disable it here */
276
277static __devinit void via_no_dac(struct pci_dev *dev)
278{
279 if ((dev->class >> 8) == PCI_CLASS_BRIDGE_PCI && forbid_dac == 0) {
280 printk(KERN_INFO "PCI: VIA PCI bridge detected. Disabling DAC.\n");
281 forbid_dac = 1;
282 }
283}
284DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_VIA, PCI_ANY_ID, via_no_dac);
285#endif
diff --git a/include/asm-x86/dma-mapping.h b/include/asm-x86/dma-mapping.h
index 914846d0beaa..d82517de1e7c 100644
--- a/include/asm-x86/dma-mapping.h
+++ b/include/asm-x86/dma-mapping.h
@@ -14,6 +14,7 @@ extern dma_addr_t bad_dma_address;
14extern int iommu_merge; 14extern int iommu_merge;
15extern struct device fallback_dev; 15extern struct device fallback_dev;
16extern int panic_on_overflow; 16extern int panic_on_overflow;
17extern int forbid_dac;
17 18
18struct dma_mapping_ops { 19struct dma_mapping_ops {
19 int (*mapping_error)(dma_addr_t dma_addr); 20 int (*mapping_error)(dma_addr_t dma_addr);
@@ -223,6 +224,5 @@ dma_release_declared_memory(struct device *dev);
223extern void * 224extern void *
224dma_mark_declared_memory_occupied(struct device *dev, 225dma_mark_declared_memory_occupied(struct device *dev,
225 dma_addr_t device_addr, size_t size); 226 dma_addr_t device_addr, size_t size);
226extern int forbid_dac;
227#endif /* CONFIG_X86_32 */ 227#endif /* CONFIG_X86_32 */
228#endif 228#endif