public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH v3] Fix dma_mapping_error for 32bit x86
@ 2008-11-29 12:46 Thomas Bogendoerfer
  2008-11-29 15:13 ` FUJITA Tomonori
  2008-12-01 11:34 ` Joerg Roedel
  0 siblings, 2 replies; 11+ messages in thread
From: Thomas Bogendoerfer @ 2008-11-29 12:46 UTC (permalink / raw)
  To: linux-kernel

Devices like b44 ethernet can't dma from addresses above 1GB. The driver
handles this cases by falling back to GFP_DMA allocation. But for detecting
the problem it needs to get an indication from dma_mapping_error.
The bug is triggered by using a VMSPLIT option of 2G/2G.

Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
---


diff -ru orig/linux-2.6.27.4/include/asm-x86/dma-mapping.h linux-2.6.27.4/include/asm-x86/dma-mapping.h
--- orig/linux-2.6.27.4/include/asm-x86/dma-mapping.h	2008-10-26 00:05:07.000000000 +0200
+++ linux-2.6.27.4/include/asm-x86/dma-mapping.h	2008-10-26 11:06:14.000000000 +0100
@@ -74,15 +74,13 @@
 /* Make sure we keep the same behaviour */
 static inline int dma_mapping_error(struct device *dev, dma_addr_t dma_addr)
 {
-#ifdef CONFIG_X86_32
-	return 0;
-#else
+#ifdef CONFIG_X86_64
 	struct dma_mapping_ops *ops = get_dma_ops(dev);
 	if (ops->mapping_error)
 		return ops->mapping_error(dev, dma_addr);
 
-	return (dma_addr == bad_dma_address);
 #endif
+	return (dma_addr == bad_dma_address);
 }
 
 #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f)

^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2008-12-01 19:37 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-11-29 12:46 [PATCH v3] Fix dma_mapping_error for 32bit x86 Thomas Bogendoerfer
2008-11-29 15:13 ` FUJITA Tomonori
2008-12-01 11:34 ` Joerg Roedel
2008-12-01 12:01   ` FUJITA Tomonori
2008-12-01 12:55     ` Ingo Molnar
2008-12-01 14:10       ` FUJITA Tomonori
2008-12-01 14:35         ` Ingo Molnar
2008-12-01 17:17           ` FUJITA Tomonori
2008-12-01 19:36             ` Ingo Molnar
2008-12-01 12:58     ` Joerg Roedel
2008-12-01 14:10       ` FUJITA Tomonori

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox