Commit c05df636 authored by Franky Lin's avatar Franky Lin Committed by Greg Kroah-Hartman

staging: brcm80211: Remove siutils dependence from dhd_sdio.c

Remove siutils related functions and resources from dhd_sdio.c
Signed-off-by: default avatarFranky Lin <frankyl@broadcom.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent cee3cf4b
...@@ -30,5 +30,6 @@ ...@@ -30,5 +30,6 @@
#define BCM4329_CORE_SOCRAM_BASE 0x18003000 #define BCM4329_CORE_SOCRAM_BASE 0x18003000
/* ARM Cortex M3 core, ID 0x82a */ /* ARM Cortex M3 core, ID 0x82a */
#define BCM4329_CORE_ARM_BASE 0x18002000 #define BCM4329_CORE_ARM_BASE 0x18002000
#define BCM4329_RAMSIZE 0x48000
#endif /* _bcmchip_h_ */ #endif /* _bcmchip_h_ */
...@@ -180,6 +180,7 @@ struct chip_info { ...@@ -180,6 +180,7 @@ struct chip_info {
u32 ramcorebase; u32 ramcorebase;
u32 armcorebase; u32 armcorebase;
u32 pmurev; u32 pmurev;
u32 ramsize;
}; };
/* Private data for SDIO bus interaction */ /* Private data for SDIO bus interaction */
...@@ -187,7 +188,6 @@ typedef struct dhd_bus { ...@@ -187,7 +188,6 @@ typedef struct dhd_bus {
dhd_pub_t *dhd; dhd_pub_t *dhd;
bcmsdh_info_t *sdh; /* Handle for BCMSDH calls */ bcmsdh_info_t *sdh; /* Handle for BCMSDH calls */
si_t *sih; /* Handle for SI calls */
struct chip_info *ci; /* Chip info struct */ struct chip_info *ci; /* Chip info struct */
char *vars; /* Variables (from CIS and/or other) */ char *vars; /* Variables (from CIS and/or other) */
uint varsz; /* Size of variables buffer */ uint varsz; /* Size of variables buffer */
...@@ -535,8 +535,8 @@ static int dhdsdio_htclk(dhd_bus_t *bus, bool on, bool pendok) ...@@ -535,8 +535,8 @@ static int dhdsdio_htclk(dhd_bus_t *bus, bool on, bool pendok)
clkreq = clkreq =
bus->alp_only ? SBSDIO_ALP_AVAIL_REQ : SBSDIO_HT_AVAIL_REQ; bus->alp_only ? SBSDIO_ALP_AVAIL_REQ : SBSDIO_HT_AVAIL_REQ;
if ((bus->sih->chip == BCM4329_CHIP_ID) if ((bus->ci->chip == BCM4329_CHIP_ID)
&& (bus->sih->chiprev == 0)) && (bus->ci->chiprev == 0))
clkreq |= SBSDIO_FORCE_ALP; clkreq |= SBSDIO_FORCE_ALP;
bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR, bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR,
...@@ -547,8 +547,8 @@ static int dhdsdio_htclk(dhd_bus_t *bus, bool on, bool pendok) ...@@ -547,8 +547,8 @@ static int dhdsdio_htclk(dhd_bus_t *bus, bool on, bool pendok)
return BCME_ERROR; return BCME_ERROR;
} }
if (pendok && ((bus->sih->buscoretype == PCMCIA_CORE_ID) if (pendok && ((bus->ci->buscoretype == PCMCIA_CORE_ID)
&& (bus->sih->buscorerev == 9))) { && (bus->ci->buscorerev == 9))) {
u32 dummy, retries; u32 dummy, retries;
R_SDREG(dummy, &bus->regs->clockctlstatus, retries); R_SDREG(dummy, &bus->regs->clockctlstatus, retries);
} }
...@@ -842,8 +842,8 @@ int dhdsdio_bussleep(dhd_bus_t *bus, bool sleep) ...@@ -842,8 +842,8 @@ int dhdsdio_bussleep(dhd_bus_t *bus, bool sleep)
SBSDIO_FORCE_HW_CLKREQ_OFF, NULL); SBSDIO_FORCE_HW_CLKREQ_OFF, NULL);
/* Isolate the bus */ /* Isolate the bus */
if (bus->sih->chip != BCM4329_CHIP_ID if (bus->ci->chip != BCM4329_CHIP_ID
&& bus->sih->chip != BCM4319_CHIP_ID) { && bus->ci->chip != BCM4319_CHIP_ID) {
bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_DEVICE_CTL, bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_DEVICE_CTL,
SBSDIO_DEVCTL_PADS_ISO, NULL); SBSDIO_DEVCTL_PADS_ISO, NULL);
} }
...@@ -859,8 +859,8 @@ int dhdsdio_bussleep(dhd_bus_t *bus, bool sleep) ...@@ -859,8 +859,8 @@ int dhdsdio_bussleep(dhd_bus_t *bus, bool sleep)
/* Force pad isolation off if possible /* Force pad isolation off if possible
(in case power never toggled) */ (in case power never toggled) */
if ((bus->sih->buscoretype == PCMCIA_CORE_ID) if ((bus->ci->buscoretype == PCMCIA_CORE_ID)
&& (bus->sih->buscorerev >= 10)) && (bus->ci->buscorerev >= 10))
bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_DEVICE_CTL, 0, bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_DEVICE_CTL, 0,
NULL); NULL);
...@@ -2920,14 +2920,11 @@ int dhd_bus_init(dhd_pub_t *dhdp, bool enforce_mutex) ...@@ -2920,14 +2920,11 @@ int dhd_bus_init(dhd_pub_t *dhdp, bool enforce_mutex)
/* If F2 successfully enabled, set core and enable interrupts */ /* If F2 successfully enabled, set core and enable interrupts */
if (ready == enable) { if (ready == enable) {
/* Make sure we're talking to the core. */
bus->regs = si_setcore(bus->sih, PCMCIA_CORE_ID, 0);
if (!(bus->regs))
bus->regs = si_setcore(bus->sih, SDIOD_CORE_ID, 0);
/* Set up the interrupt mask and enable interrupts */ /* Set up the interrupt mask and enable interrupts */
bus->hostintmask = HOSTINTMASK; bus->hostintmask = HOSTINTMASK;
W_SDREG(bus->hostintmask, &bus->regs->hostintmask, retries); W_SDREG(bus->hostintmask,
(unsigned int *)CORE_BUS_REG(bus->ci->buscorebase,
hostintmask), retries);
bcmsdh_cfg_write(bus->sdh, SDIO_FUNC_1, SBSDIO_WATERMARK, bcmsdh_cfg_write(bus->sdh, SDIO_FUNC_1, SBSDIO_WATERMARK,
(u8) watermark, &err); (u8) watermark, &err);
...@@ -5187,7 +5184,10 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid) ...@@ -5187,7 +5184,10 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid)
#endif /* DHD_DEBUG */ #endif /* DHD_DEBUG */
/* Force PLL off until si_attach() programs PLL control regs */ /*
* Force PLL off until dhdsdio_chip_attach()
* programs PLL control regs
*/
bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR, bcmsdh_cfg_write(sdh, SDIO_FUNC_1, SBSDIO_FUNC1_CHIPCLKCSR,
DHD_INIT_CLKCTL1, &err); DHD_INIT_CLKCTL1, &err);
...@@ -5253,23 +5253,16 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid) ...@@ -5253,23 +5253,16 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid)
} }
#endif /* DHD_DEBUG */ #endif /* DHD_DEBUG */
/* si_attach() will provide an SI handle and scan the backplane */
bus->sih = si_attach((uint) devid, regsva, DHD_BUS, sdh,
&bus->vars, &bus->varsz);
if (!(bus->sih)) {
DHD_ERROR(("%s: si_attach failed!\n", __func__));
goto fail;
}
if (dhdsdio_chip_attach(bus, regsva)) { if (dhdsdio_chip_attach(bus, regsva)) {
DHD_ERROR(("%s: dhdsdio_chip_attach failed!\n", __func__)); DHD_ERROR(("%s: dhdsdio_chip_attach failed!\n", __func__));
goto fail; goto fail;
} }
bcmsdh_chipinfo(sdh, bus->sih->chip, bus->sih->chiprev); bcmsdh_chipinfo(sdh, bus->ci->chip, bus->ci->chiprev);
if (!dhdsdio_chipmatch((u16) bus->sih->chip)) { if (!dhdsdio_chipmatch((u16) bus->ci->chip)) {
DHD_ERROR(("%s: unsupported chip: 0x%04x\n", DHD_ERROR(("%s: unsupported chip: 0x%04x\n",
__func__, bus->sih->chip)); __func__, bus->ci->chip));
goto fail; goto fail;
} }
...@@ -5277,14 +5270,9 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid) ...@@ -5277,14 +5270,9 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid)
/* Get info on the ARM and SOCRAM cores... */ /* Get info on the ARM and SOCRAM cores... */
if (!DHD_NOPMU(bus)) { if (!DHD_NOPMU(bus)) {
if ((si_setcore(bus->sih, ARM7S_CORE_ID, 0)) || bus->armrev = SBCOREREV(bcmsdh_reg_read(bus->sdh,
(si_setcore(bus->sih, ARMCM3_CORE_ID, 0))) { CORE_SB(bus->ci->armcorebase, sbidhigh), 4));
bus->armrev = si_corerev(bus->sih); bus->orig_ramsize = bus->ci->ramsize;
} else {
DHD_ERROR(("%s: failed to find ARM core!\n", __func__));
goto fail;
}
bus->orig_ramsize = si_socram_size(bus->sih);
if (!(bus->orig_ramsize)) { if (!(bus->orig_ramsize)) {
DHD_ERROR(("%s: failed to find SOCRAM memory!\n", DHD_ERROR(("%s: failed to find SOCRAM memory!\n",
__func__)); __func__));
...@@ -5298,17 +5286,7 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid) ...@@ -5298,17 +5286,7 @@ dhdsdio_probe_attach(struct dhd_bus *bus, void *sdh, void *regsva, u16 devid)
bus->ramsize, bus->orig_ramsize)); bus->ramsize, bus->orig_ramsize));
} }
/* ...but normally deal with the SDPCMDEV core */ bus->regs = (void *)bus->ci->buscorebase;
bus->regs = si_setcore(bus->sih, PCMCIA_CORE_ID, 0);
if (!bus->regs) {
bus->regs = si_setcore(bus->sih, SDIOD_CORE_ID, 0);
if (!bus->regs) {
DHD_ERROR(("%s: failed to find SDIODEV core!\n",
__func__));
goto fail;
}
}
bus->sdpcmrev = si_corerev(bus->sih);
/* Set core control so an SDIO reset does a backplane reset */ /* Set core control so an SDIO reset does a backplane reset */
OR_REG(&bus->regs->corecontrol, CC_BPRESEN); OR_REG(&bus->regs->corecontrol, CC_BPRESEN);
...@@ -5522,13 +5500,9 @@ static void dhdsdio_release_dongle(dhd_bus_t *bus) ...@@ -5522,13 +5500,9 @@ static void dhdsdio_release_dongle(dhd_bus_t *bus)
if (bus->dhd && bus->dhd->dongle_reset) if (bus->dhd && bus->dhd->dongle_reset)
return; return;
if (bus->sih) { if (bus->ci) {
dhdsdio_clkctl(bus, CLK_AVAIL, false); dhdsdio_clkctl(bus, CLK_AVAIL, false);
#if !defined(BCMLXSDMMC)
si_watchdog(bus->sih, 4);
#endif /* !defined(BCMLXSDMMC) */
dhdsdio_clkctl(bus, CLK_NONE, false); dhdsdio_clkctl(bus, CLK_NONE, false);
si_detach(bus->sih);
dhdsdio_chip_detach(bus); dhdsdio_chip_detach(bus);
if (bus->vars && bus->varsz) if (bus->vars && bus->varsz)
kfree(bus->vars); kfree(bus->vars);
...@@ -5955,8 +5929,8 @@ dhd_bcmsdh_send_buf(dhd_bus_t *bus, u32 addr, uint fn, uint flags, ...@@ -5955,8 +5929,8 @@ dhd_bcmsdh_send_buf(dhd_bus_t *bus, u32 addr, uint fn, uint flags,
uint dhd_bus_chip(struct dhd_bus *bus) uint dhd_bus_chip(struct dhd_bus *bus)
{ {
ASSERT(bus->sih != NULL); ASSERT(bus->ci != NULL);
return bus->sih->chip; return bus->ci->chip;
} }
void *dhd_bus_pub(struct dhd_bus *bus) void *dhd_bus_pub(struct dhd_bus *bus)
...@@ -6071,6 +6045,7 @@ dhdsdio_chip_recognition(bcmsdh_info_t *sdh, struct chip_info *ci, void *regs) ...@@ -6071,6 +6045,7 @@ dhdsdio_chip_recognition(bcmsdh_info_t *sdh, struct chip_info *ci, void *regs)
ci->buscorebase = BCM4329_CORE_BUS_BASE; ci->buscorebase = BCM4329_CORE_BUS_BASE;
ci->ramcorebase = BCM4329_CORE_SOCRAM_BASE; ci->ramcorebase = BCM4329_CORE_SOCRAM_BASE;
ci->armcorebase = BCM4329_CORE_ARM_BASE; ci->armcorebase = BCM4329_CORE_ARM_BASE;
ci->ramsize = BCM4329_RAMSIZE;
break; break;
default: default:
DHD_ERROR(("%s: chipid 0x%x is not supported\n", DHD_ERROR(("%s: chipid 0x%x is not supported\n",
......
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