Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 5b36c9b4 authored by Hauke Mehrtens's avatar Hauke Mehrtens Committed by John W. Linville
Browse files

b43: read correct register on bcma bus.



This causes an databus error on a Broadcom SoC using bcma.

Signed-off-by: default avatarHauke Mehrtens <hauke@hauke-m.de>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent a5d5a914
Loading
Loading
Loading
Loading
+17 −3
Original line number Original line Diff line number Diff line
@@ -795,9 +795,23 @@ static u64 supported_dma_mask(struct b43_wldev *dev)
	u32 tmp;
	u32 tmp;
	u16 mmio_base;
	u16 mmio_base;


	tmp = b43_read32(dev, SSB_TMSHIGH);
	switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_BCMA
	case B43_BUS_BCMA:
		tmp = bcma_aread32(dev->dev->bdev, BCMA_IOST);
		if (tmp & BCMA_IOST_DMA64)
			return DMA_BIT_MASK(64);
		break;
#endif
#ifdef CONFIG_B43_SSB
	case B43_BUS_SSB:
		tmp = ssb_read32(dev->dev->sdev, SSB_TMSHIGH);
		if (tmp & SSB_TMSHIGH_DMA64)
		if (tmp & SSB_TMSHIGH_DMA64)
			return DMA_BIT_MASK(64);
			return DMA_BIT_MASK(64);
		break;
#endif
	}

	mmio_base = b43_dmacontroller_base(0, 0);
	mmio_base = b43_dmacontroller_base(0, 0);
	b43_write32(dev, mmio_base + B43_DMA32_TXCTL, B43_DMA32_TXADDREXT_MASK);
	b43_write32(dev, mmio_base + B43_DMA32_TXCTL, B43_DMA32_TXADDREXT_MASK);
	tmp = b43_read32(dev, mmio_base + B43_DMA32_TXCTL);
	tmp = b43_read32(dev, mmio_base + B43_DMA32_TXCTL);