Commit 6cbab0d9 authored by Rafał Miłecki's avatar Rafał Miłecki Committed by John W. Linville

b43: use switches for SSB specific code

Signed-off-by: default avatarRafał Miłecki <zajec5@gmail.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 75396ae6
...@@ -726,7 +726,6 @@ enum { ...@@ -726,7 +726,6 @@ enum {
/* Data structure for one wireless device (802.11 core) */ /* Data structure for one wireless device (802.11 core) */
struct b43_wldev { struct b43_wldev {
struct ssb_device *sdev; /* TODO: remove when b43_bus_dev is ready */
struct b43_bus_dev *dev; struct b43_bus_dev *dev;
struct b43_wl *wl; struct b43_wl *wl;
......
...@@ -2,7 +2,9 @@ ...@@ -2,7 +2,9 @@
#define B43_BUS_H_ #define B43_BUS_H_
enum b43_bus_type { enum b43_bus_type {
#ifdef CONFIG_B43_BCMA
B43_BUS_BCMA, B43_BUS_BCMA,
#endif
B43_BUS_SSB, B43_BUS_SSB,
}; };
......
...@@ -1055,7 +1055,14 @@ int b43_dma_init(struct b43_wldev *dev) ...@@ -1055,7 +1055,14 @@ int b43_dma_init(struct b43_wldev *dev)
err = b43_dma_set_mask(dev, dmamask); err = b43_dma_set_mask(dev, dmamask);
if (err) if (err)
return err; return err;
dma->translation = ssb_dma_translation(dev->sdev);
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
dma->translation = ssb_dma_translation(dev->dev->sdev);
break;
#endif
}
err = -ENOMEM; err = -ENOMEM;
/* setup TX DMA channels. */ /* setup TX DMA channels. */
......
...@@ -1187,7 +1187,13 @@ void b43_wireless_core_reset(struct b43_wldev *dev, bool gmode) ...@@ -1187,7 +1187,13 @@ void b43_wireless_core_reset(struct b43_wldev *dev, bool gmode)
{ {
u32 macctl; u32 macctl;
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
b43_ssb_wireless_core_reset(dev, gmode); b43_ssb_wireless_core_reset(dev, gmode);
break;
#endif
}
/* Turn Analog ON, but only if we already know the PHY-type. /* Turn Analog ON, but only if we already know the PHY-type.
* This protects against very early setup where we don't know the * This protects against very early setup where we don't know the
...@@ -2624,11 +2630,17 @@ static int b43_gpio_init(struct b43_wldev *dev) ...@@ -2624,11 +2630,17 @@ static int b43_gpio_init(struct b43_wldev *dev)
if (dev->dev->core_rev >= 2) if (dev->dev->core_rev >= 2)
mask |= 0x0010; /* FIXME: This is redundant. */ mask |= 0x0010; /* FIXME: This is redundant. */
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
gpiodev = b43_ssb_gpio_dev(dev); gpiodev = b43_ssb_gpio_dev(dev);
if (gpiodev) if (gpiodev)
ssb_write32(gpiodev, B43_GPIO_CONTROL, ssb_write32(gpiodev, B43_GPIO_CONTROL,
(ssb_read32(gpiodev, B43_GPIO_CONTROL) (ssb_read32(gpiodev, B43_GPIO_CONTROL)
& mask) | set); & mask) | set);
break;
#endif
}
return 0; return 0;
} }
...@@ -2638,9 +2650,15 @@ static void b43_gpio_cleanup(struct b43_wldev *dev) ...@@ -2638,9 +2650,15 @@ static void b43_gpio_cleanup(struct b43_wldev *dev)
{ {
struct ssb_device *gpiodev; struct ssb_device *gpiodev;
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
gpiodev = b43_ssb_gpio_dev(dev); gpiodev = b43_ssb_gpio_dev(dev);
if (gpiodev) if (gpiodev)
ssb_write32(gpiodev, B43_GPIO_CONTROL, 0); ssb_write32(gpiodev, B43_GPIO_CONTROL, 0);
break;
#endif
}
} }
/* http://bcm-specs.sipsolutions.net/EnableMac */ /* http://bcm-specs.sipsolutions.net/EnableMac */
...@@ -2712,12 +2730,20 @@ void b43_mac_suspend(struct b43_wldev *dev) ...@@ -2712,12 +2730,20 @@ void b43_mac_suspend(struct b43_wldev *dev)
/* http://bcm-v4.sipsolutions.net/802.11/PHY/N/MacPhyClkSet */ /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/MacPhyClkSet */
void b43_mac_phy_clock_set(struct b43_wldev *dev, bool on) void b43_mac_phy_clock_set(struct b43_wldev *dev, bool on)
{ {
u32 tmslow = ssb_read32(dev->sdev, SSB_TMSLOW); u32 tmp;
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
tmp = ssb_read32(dev->dev->sdev, SSB_TMSLOW);
if (on) if (on)
tmslow |= B43_TMSLOW_MACPHYCLKEN; tmp |= B43_TMSLOW_MACPHYCLKEN;
else else
tmslow &= ~B43_TMSLOW_MACPHYCLKEN; tmp &= ~B43_TMSLOW_MACPHYCLKEN;
ssb_write32(dev->sdev, SSB_TMSLOW, tmslow); ssb_write32(dev->dev->sdev, SSB_TMSLOW, tmp);
break;
#endif
}
} }
static void b43_adjust_opmode(struct b43_wldev *dev) static void b43_adjust_opmode(struct b43_wldev *dev)
...@@ -2956,8 +2982,14 @@ static int b43_chip_init(struct b43_wldev *dev) ...@@ -2956,8 +2982,14 @@ static int b43_chip_init(struct b43_wldev *dev)
b43_mac_phy_clock_set(dev, true); b43_mac_phy_clock_set(dev, true);
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
b43_write16(dev, B43_MMIO_POWERUP_DELAY, b43_write16(dev, B43_MMIO_POWERUP_DELAY,
dev->sdev->bus->chipco.fast_pwrup_delay); dev->dev->sdev->bus->chipco.fast_pwrup_delay);
break;
#endif
}
err = 0; err = 0;
b43dbg(dev->wl, "Chip initialized\n"); b43dbg(dev->wl, "Chip initialized\n");
...@@ -3473,21 +3505,27 @@ static void b43_op_set_tsf(struct ieee80211_hw *hw, u64 tsf) ...@@ -3473,21 +3505,27 @@ static void b43_op_set_tsf(struct ieee80211_hw *hw, u64 tsf)
static void b43_put_phy_into_reset(struct b43_wldev *dev) static void b43_put_phy_into_reset(struct b43_wldev *dev)
{ {
struct ssb_device *sdev = dev->sdev; u32 tmp;
u32 tmslow;
tmslow = ssb_read32(sdev, SSB_TMSLOW); switch (dev->dev->bus_type) {
tmslow &= ~B43_TMSLOW_GMODE; #ifdef CONFIG_B43_SSB
tmslow |= B43_TMSLOW_PHYRESET; case B43_BUS_SSB:
tmslow |= SSB_TMSLOW_FGC; tmp = ssb_read32(dev->dev->sdev, SSB_TMSLOW);
ssb_write32(sdev, SSB_TMSLOW, tmslow); tmp &= ~B43_TMSLOW_GMODE;
tmp |= B43_TMSLOW_PHYRESET;
tmp |= SSB_TMSLOW_FGC;
ssb_write32(dev->dev->sdev, SSB_TMSLOW, tmp);
msleep(1); msleep(1);
tmslow = ssb_read32(sdev, SSB_TMSLOW); tmp = ssb_read32(dev->dev->sdev, SSB_TMSLOW);
tmslow &= ~SSB_TMSLOW_FGC; tmp &= ~SSB_TMSLOW_FGC;
tmslow |= B43_TMSLOW_PHYRESET; tmp |= B43_TMSLOW_PHYRESET;
ssb_write32(sdev, SSB_TMSLOW, tmslow); ssb_write32(dev->dev->sdev, SSB_TMSLOW, tmp);
msleep(1); msleep(1);
break;
#endif
}
} }
static const char *band_to_string(enum ieee80211_band band) static const char *band_to_string(enum ieee80211_band band)
...@@ -4347,7 +4385,6 @@ static void b43_wireless_core_exit(struct b43_wldev *dev) ...@@ -4347,7 +4385,6 @@ static void b43_wireless_core_exit(struct b43_wldev *dev)
/* Initialize a wireless core */ /* Initialize a wireless core */
static int b43_wireless_core_init(struct b43_wldev *dev) static int b43_wireless_core_init(struct b43_wldev *dev)
{ {
struct ssb_bus *bus = dev->sdev->bus;
struct ssb_sprom *sprom = dev->dev->bus_sprom; struct ssb_sprom *sprom = dev->dev->bus_sprom;
struct b43_phy *phy = &dev->phy; struct b43_phy *phy = &dev->phy;
int err; int err;
...@@ -4366,7 +4403,14 @@ static int b43_wireless_core_init(struct b43_wldev *dev) ...@@ -4366,7 +4403,14 @@ static int b43_wireless_core_init(struct b43_wldev *dev)
phy->ops->prepare_structs(dev); phy->ops->prepare_structs(dev);
/* Enable IRQ routing to this device. */ /* Enable IRQ routing to this device. */
ssb_pcicore_dev_irqvecs_enable(&bus->pcicore, dev->sdev); switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
ssb_pcicore_dev_irqvecs_enable(&dev->dev->sdev->bus->pcicore,
dev->dev->sdev);
break;
#endif
}
b43_imcfglo_timeouts_workaround(dev); b43_imcfglo_timeouts_workaround(dev);
b43_bluetooth_coext_disable(dev); b43_bluetooth_coext_disable(dev);
...@@ -4397,8 +4441,9 @@ static int b43_wireless_core_init(struct b43_wldev *dev) ...@@ -4397,8 +4441,9 @@ static int b43_wireless_core_init(struct b43_wldev *dev)
if (sprom->boardflags_lo & B43_BFL_XTAL_NOSLOW) if (sprom->boardflags_lo & B43_BFL_XTAL_NOSLOW)
hf |= B43_HF_DSCRQ; /* Disable slowclock requests from ucode. */ hf |= B43_HF_DSCRQ; /* Disable slowclock requests from ucode. */
#ifdef CONFIG_SSB_DRIVER_PCICORE #ifdef CONFIG_SSB_DRIVER_PCICORE
if ((bus->bustype == SSB_BUSTYPE_PCI) && if (dev->dev->bus_type == B43_BUS_SSB &&
(bus->pcicore.dev->id.revision <= 10)) dev->dev->sdev->bus->bustype == SSB_BUSTYPE_PCI &&
dev->dev->sdev->bus->pcicore.dev->id.revision <= 10)
hf |= B43_HF_PCISCW; /* PCI slow clock workaround. */ hf |= B43_HF_PCISCW; /* PCI slow clock workaround. */
#endif #endif
hf &= ~B43_HF_SKCFPUP; hf &= ~B43_HF_SKCFPUP;
...@@ -4764,8 +4809,7 @@ static void b43_wireless_core_detach(struct b43_wldev *dev) ...@@ -4764,8 +4809,7 @@ static void b43_wireless_core_detach(struct b43_wldev *dev)
static int b43_wireless_core_attach(struct b43_wldev *dev) static int b43_wireless_core_attach(struct b43_wldev *dev)
{ {
struct b43_wl *wl = dev->wl; struct b43_wl *wl = dev->wl;
struct ssb_bus *bus = dev->sdev->bus; struct pci_dev *pdev = NULL;
struct pci_dev *pdev = (bus->bustype == SSB_BUSTYPE_PCI) ? bus->host_pci : NULL;
int err; int err;
bool have_2ghz_phy = 0, have_5ghz_phy = 0; bool have_2ghz_phy = 0, have_5ghz_phy = 0;
...@@ -4776,20 +4820,31 @@ static int b43_wireless_core_attach(struct b43_wldev *dev) ...@@ -4776,20 +4820,31 @@ static int b43_wireless_core_attach(struct b43_wldev *dev)
* that in core_init(), too. * that in core_init(), too.
*/ */
#ifdef CONFIG_B43_SSB
if (dev->dev->bus_type == B43_BUS_SSB &&
dev->dev->sdev->bus->bustype == SSB_BUSTYPE_PCI)
pdev = dev->dev->sdev->bus->host_pci;
#endif
err = b43_bus_powerup(dev, 0); err = b43_bus_powerup(dev, 0);
if (err) { if (err) {
b43err(wl, "Bus powerup failed\n"); b43err(wl, "Bus powerup failed\n");
goto out; goto out;
} }
/* Get the PHY type. */ /* Get the PHY type. */
switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
if (dev->dev->core_rev >= 5) { if (dev->dev->core_rev >= 5) {
u32 tmshigh; u32 tmshigh = ssb_read32(dev->dev->sdev, SSB_TMSHIGH);
tmshigh = ssb_read32(dev->sdev, SSB_TMSHIGH);
have_2ghz_phy = !!(tmshigh & B43_TMSHIGH_HAVE_2GHZ_PHY); have_2ghz_phy = !!(tmshigh & B43_TMSHIGH_HAVE_2GHZ_PHY);
have_5ghz_phy = !!(tmshigh & B43_TMSHIGH_HAVE_5GHZ_PHY); have_5ghz_phy = !!(tmshigh & B43_TMSHIGH_HAVE_5GHZ_PHY);
} else } else
B43_WARN_ON(1); B43_WARN_ON(1);
break;
#endif
}
dev->phy.gmode = have_2ghz_phy; dev->phy.gmode = have_2ghz_phy;
dev->phy.radio_on = 1; dev->phy.radio_on = 1;
...@@ -4898,7 +4953,6 @@ static int b43_one_core_attach(struct b43_bus_dev *dev, struct b43_wl *wl) ...@@ -4898,7 +4953,6 @@ static int b43_one_core_attach(struct b43_bus_dev *dev, struct b43_wl *wl)
wldev->use_pio = b43_modparam_pio; wldev->use_pio = b43_modparam_pio;
wldev->dev = dev; wldev->dev = dev;
wldev->sdev = dev->sdev; /* TODO: Remove when not needed */
wldev->wl = wl; wldev->wl = wl;
b43_set_status(wldev, B43_STAT_UNINIT); b43_set_status(wldev, B43_STAT_UNINIT);
wldev->bad_frames_preempt = modparam_bad_frames_preempt; wldev->bad_frames_preempt = modparam_bad_frames_preempt;
......
...@@ -603,17 +603,23 @@ static void b43_nphy_tx_lp_fbw(struct b43_wldev *dev) ...@@ -603,17 +603,23 @@ static void b43_nphy_tx_lp_fbw(struct b43_wldev *dev)
/* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */ /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */
static void b43_nphy_bmac_clock_fgc(struct b43_wldev *dev, bool force) static void b43_nphy_bmac_clock_fgc(struct b43_wldev *dev, bool force)
{ {
u32 tmslow; u32 tmp;
if (dev->phy.type != B43_PHYTYPE_N) if (dev->phy.type != B43_PHYTYPE_N)
return; return;
tmslow = ssb_read32(dev->sdev, SSB_TMSLOW); switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
tmp = ssb_read32(dev->dev->sdev, SSB_TMSLOW);
if (force) if (force)
tmslow |= SSB_TMSLOW_FGC; tmp |= SSB_TMSLOW_FGC;
else else
tmslow &= ~SSB_TMSLOW_FGC; tmp &= ~SSB_TMSLOW_FGC;
ssb_write32(dev->sdev, SSB_TMSLOW, tmslow); ssb_write32(dev->dev->sdev, SSB_TMSLOW, tmp);
break;
#endif
}
} }
/* http://bcm-v4.sipsolutions.net/802.11/PHY/N/CCA */ /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/CCA */
...@@ -958,8 +964,15 @@ static void b43_nphy_superswitch_init(struct b43_wldev *dev, bool init) ...@@ -958,8 +964,15 @@ static void b43_nphy_superswitch_init(struct b43_wldev *dev, bool init)
b43_phy_write(dev, B43_NPHY_GPIO_LOOEN, 0); b43_phy_write(dev, B43_NPHY_GPIO_LOOEN, 0);
b43_phy_write(dev, B43_NPHY_GPIO_HIOEN, 0); b43_phy_write(dev, B43_NPHY_GPIO_HIOEN, 0);
ssb_chipco_gpio_control(&dev->sdev->bus->chipco, 0xFC00, switch (dev->dev->bus_type) {
0xFC00); #ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
ssb_chipco_gpio_control(&dev->dev->sdev->bus->chipco,
0xFC00, 0xFC00);
break;
#endif
}
b43_write32(dev, B43_MMIO_MACCTL, b43_write32(dev, B43_MMIO_MACCTL,
b43_read32(dev, B43_MMIO_MACCTL) & b43_read32(dev, B43_MMIO_MACCTL) &
~B43_MACCTL_GPOUTSMSK); ~B43_MACCTL_GPOUTSMSK);
...@@ -3600,7 +3613,14 @@ int b43_phy_initn(struct b43_wldev *dev) ...@@ -3600,7 +3613,14 @@ int b43_phy_initn(struct b43_wldev *dev)
if ((dev->phy.rev >= 3) && if ((dev->phy.rev >= 3) &&
(sprom->boardflags_lo & B43_BFL_EXTLNA) && (sprom->boardflags_lo & B43_BFL_EXTLNA) &&
(b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ)) { (b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ)) {
chipco_set32(&dev->sdev->bus->chipco, SSB_CHIPCO_CHIPCTL, 0x40); switch (dev->dev->bus_type) {
#ifdef CONFIG_B43_SSB
case B43_BUS_SSB:
chipco_set32(&dev->dev->sdev->bus->chipco,
SSB_CHIPCO_CHIPCTL, 0x40);
break;
#endif
}
} }
nphy->deaf_count = 0; nphy->deaf_count = 0;
b43_nphy_tables_init(dev); b43_nphy_tables_init(dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment