--- trunk.orig/package/broadcom-wl/patches/006-generic-dma-api.patch    
1970-01-01 03:00:00.000000000 +0300
+++ trunk/package/broadcom-wl/patches/006-generic-dma-api.patch 2011-05-16 
23:43:35.000000000 +0300
@@ -0,0 +1,82 @@
+From: George Kashperko <geo...@znau.edu.ua>
+
+broadcom-wl driver bound to ssb device with ssb driver probe
+have osh handle struct pdev pointer value initialized with
+ssb_device pointer. Later on pdev is used with legacy pci
+dma api as pci_dev thus causing oops sometimes.
+
+The patch replaces legacy pci dma api and pass relevant
+device struct pointer to avoid crashes.
+Signed-off-by: George Kashperko <geo...@znau.edu.ua>
+---
+ driver/linux_osl.c |   29 +++++++++++++++++++++++++----
+ 1 file changed, 25 insertions(+), 4 deletions(-)
+--- broadcom-wl-5.10.56.27.3.orig/driver/linux_osl.c   2011-05-16 
22:49:08.000000000 +0300
++++ broadcom-wl-5.10.56.27.3/driver/linux_osl.c        2011-05-16 
23:05:39.000000000 +0300
+@@ -25,6 +25,9 @@
+ #include <asm/paccess.h>
+ #endif /* mips */
+ #include <pcicfg.h>
++#ifdef CONFIG_SSB
++#include <linux/ssb/ssb.h>
++#endif
+ 
+ #define PCI_CFG_RETRY                 10
+ 
+@@ -364,12 +367,30 @@ osl_dma_consistent_align(void)
+       return (PAGE_SIZE);
+ }
+ 
++static struct device *
++osl_get_dev(osl_t *osh)
++{
++#ifdef CONFIG_SSB
++      if (osh->bustype == SI_BUS) {
++              /* This can be SiliconBackplane emulated as pci with Broadcom or
++               * ssb device. Less harmful is to check for pci_bus_type and if
++               * no match then assume we got ssb */
++              if (((struct pci_dev *)osh->pdev)->dev.bus == &pci_bus_type)
++                      goto pci;
++              return ((struct ssb_device *)osh->pdev)->dev;
++      }
++#endif
++    pci:
++      return &((struct pci_dev *)osh->pdev)->dev;
++}
++
+ void*
+ osl_dma_alloc_consistent(osl_t *osh, uint size, ulong *pap)
+ {
+       ASSERT((osh && (osh->magic == OS_HANDLE_MAGIC)));
+ 
+-      return (pci_alloc_consistent(osh->pdev, size, (dma_addr_t*)pap));
++      return (dma_alloc_coherent(osl_get_dev(osh), size,
++                                 (dma_addr_t*)pap, GFP_ATOMIC));
+ }
+ 
+ void
+@@ -377,7 +398,7 @@ osl_dma_free_consistent(osl_t *osh, void
+ {
+       ASSERT((osh && (osh->magic == OS_HANDLE_MAGIC)));
+ 
+-      pci_free_consistent(osh->pdev, size, va, (dma_addr_t)pa);
++      dma_free_coherent(osl_get_dev(osh), size, va, (dma_addr_t)pa);
+ }
+ 
+ uint BCMFASTPATH
+@@ -386,13 +407,13 @@ osl_dma_map(osl_t *osh, void *va, uint s
+       ASSERT((osh && (osh->magic == OS_HANDLE_MAGIC)));
+ 
+       if (direction == DMA_TX)
+-              return (pci_map_single(osh->pdev, va, size, PCI_DMA_TODEVICE));
++              return (dma_map_single(osl_get_dev(osh), va, size, 
PCI_DMA_TODEVICE));
+       else {
+ #ifdef mips
+               dma_cache_inv((uint)va, size);
+               return (virt_to_phys(va));
+ #else /* mips */
+-              return (pci_map_single(osh->pdev, va, size, 
PCI_DMA_FROMDEVICE));
++              return (dma_map_single(osl_get_dev(osh), va, size, 
PCI_DMA_FROMDEVICE));
+ #endif /* mips */
+       }
+ }



_______________________________________________
openwrt-devel mailing list
openwrt-devel@lists.openwrt.org
https://lists.openwrt.org/mailman/listinfo/openwrt-devel

Reply via email to