From: Greg Kroah-Hartman Date: Mon, 29 Jun 2015 22:55:15 +0000 (-0700) Subject: 4.0-stable patches X-Git-Tag: v3.10.83~25 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5dae1d08a4d81159729735f499d18d273c6c02a3;p=thirdparty%2Fkernel%2Fstable-queue.git 4.0-stable patches added patches: config-enable-need_dma_map_state-by-default-when-swiotlb-is-selected.patch --- diff --git a/queue-4.0/config-enable-need_dma_map_state-by-default-when-swiotlb-is-selected.patch b/queue-4.0/config-enable-need_dma_map_state-by-default-when-swiotlb-is-selected.patch new file mode 100644 index 00000000000..fc2f1a26b9c --- /dev/null +++ b/queue-4.0/config-enable-need_dma_map_state-by-default-when-swiotlb-is-selected.patch @@ -0,0 +1,60 @@ +From a6dfa128ce5c414ab46b1d690f7a1b8decb8526d Mon Sep 17 00:00:00 2001 +From: Konrad Rzeszutek Wilk +Date: Fri, 17 Apr 2015 15:04:48 -0400 +Subject: config: Enable NEED_DMA_MAP_STATE by default when SWIOTLB is selected + +From: Konrad Rzeszutek Wilk + +commit a6dfa128ce5c414ab46b1d690f7a1b8decb8526d upstream. + +A huge amount of NIC drivers use the DMA API, however if +compiled under 32-bit an very important part of the DMA API can +be ommitted leading to the drivers not working at all +(especially if used with 'swiotlb=force iommu=soft'). + +As Prashant Sreedharan explains it: "the driver [tg3] uses +DEFINE_DMA_UNMAP_ADDR(), dma_unmap_addr_set() to keep a copy of +the dma "mapping" and dma_unmap_addr() to get the "mapping" +value. On most of the platforms this is a no-op, but ... with +"iommu=soft and swiotlb=force" this house keeping is required, +... otherwise we pass 0 while calling pci_unmap_/pci_dma_sync_ +instead of the DMA address." + +As such enable this even when using 32-bit kernels. + +Reported-by: Ian Jackson +Signed-off-by: Konrad Rzeszutek Wilk +Acked-by: David S. Miller +Acked-by: Prashant Sreedharan +Cc: Borislav Petkov +Cc: H. Peter Anvin +Cc: Linus Torvalds +Cc: Michael Chan +Cc: Thomas Gleixner +Cc: boris.ostrovsky@oracle.com +Cc: cascardo@linux.vnet.ibm.com +Cc: david.vrabel@citrix.com +Cc: sanjeevb@broadcom.com +Cc: siva.kallam@broadcom.com +Cc: vyasevich@gmail.com +Cc: xen-devel@lists.xensource.com +Link: http://lkml.kernel.org/r/20150417190448.GA9462@l.oracle.com +Signed-off-by: Ingo Molnar +Cc: Ben Hutchings +Signed-off-by: Greg Kroah-Hartman + +--- + arch/x86/Kconfig | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +--- a/arch/x86/Kconfig ++++ b/arch/x86/Kconfig +@@ -177,7 +177,7 @@ config SBUS + + config NEED_DMA_MAP_STATE + def_bool y +- depends on X86_64 || INTEL_IOMMU || DMA_API_DEBUG ++ depends on X86_64 || INTEL_IOMMU || DMA_API_DEBUG || SWIOTLB + + config NEED_SG_DMA_LENGTH + def_bool y