[PATCH] bcm43xx: Set both, the DMAmask and the coherent DMAmask.
authorMichael Buesch <mbuesch@freenet.de>
Sat, 11 Mar 2006 12:15:02 +0000 (13:15 +0100)
committerJohn W. Linville <linville@tuxdriver.com>
Mon, 27 Mar 2006 16:19:34 +0000 (11:19 -0500)
This has a potential to fix the >1G bug. But I can not test that, yet.

Signed-off-by: Michael Buesch <mbuesch@freenet.de>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/bcm43xx/bcm43xx_main.c

index 1fe2fa9856e3c4f0761f7637288e00d935147694..6da0beb0a9339daf4cab269bbbd8337367c3bc8c 100644 (file)
@@ -3717,6 +3717,8 @@ static int bcm43xx_init_private(struct bcm43xx_private *bcm,
                                struct net_device *net_dev,
                                struct pci_dev *pci_dev)
 {
+       int err;
+
        bcm->ieee = netdev_priv(net_dev);
        bcm->softmac = ieee80211_priv(net_dev);
        bcm->softmac->set_channel = bcm43xx_ieee80211_set_chan;
@@ -3735,8 +3737,7 @@ static int bcm43xx_init_private(struct bcm43xx_private *bcm,
        bcm->irq_savedstate = BCM43xx_IRQ_INITIAL;
        bcm->pci_dev = pci_dev;
        bcm->net_dev = net_dev;
-       if (modparam_bad_frames_preempt)
-               bcm->bad_frames_preempt = 1;
+       bcm->bad_frames_preempt = modparam_bad_frames_preempt;
        spin_lock_init(&bcm->lock);
        tasklet_init(&bcm->isr_tasklet,
                     (void (*)(unsigned long))bcm43xx_interrupt_tasklet,
@@ -3745,7 +3746,9 @@ static int bcm43xx_init_private(struct bcm43xx_private *bcm,
        if (modparam_pio) {
                bcm->__using_pio = 1;
        } else {
-               if (pci_set_dma_mask(pci_dev, DMA_30BIT_MASK)) {
+               err = pci_set_dma_mask(pci_dev, DMA_30BIT_MASK);
+               err |= pci_set_consistent_dma_mask(pci_dev, DMA_30BIT_MASK);
+               if (err) {
 #ifdef CONFIG_BCM43XX_PIO
                        printk(KERN_WARNING PFX "DMA not supported. Falling back to PIO.\n");
                        bcm->__using_pio = 1;