staging: brcm80211: replaced macro W_SDREG by function w_sdreg()
Code cleanup. Leads to more readable code and better type checking. Signed-off-by: Roland Vossen <rvossen@broadcom.com> Reviewed-by: Arend van Spriel <arend@broadcom.com> Reviewed-by: Franky Lin <frankyl@broadcom.com> Signed-off-by: Arend van Spriel <arend@broadcom.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
parent
e347d383da
commit
95f58e6e20
|
@ -847,20 +847,20 @@ r_sdreg32(struct brcmf_bus *bus, u32 *regvar, u32 reg_offset, u32 *retryvar)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#define W_SDREG(regval, regaddr, retryvar, typ) \
|
static void
|
||||||
do { \
|
w_sdreg32(struct brcmf_bus *bus, u32 regval, u32 reg_offset, u32 *retryvar)
|
||||||
retryvar = 0; \
|
{
|
||||||
do { \
|
*retryvar = 0;
|
||||||
W_REG((u32)(regaddr), regval, typ); \
|
do {
|
||||||
} while (brcmf_sdcard_regfail(bus->card) && \
|
W_REG(bus->ci->buscorebase + reg_offset, regval, u32);
|
||||||
(++retryvar <= retry_limit)); \
|
} while (brcmf_sdcard_regfail(bus->card) &&
|
||||||
if (retryvar) { \
|
(++(*retryvar) <= retry_limit));
|
||||||
bus->regfails += (retryvar-1); \
|
if (*retryvar) {
|
||||||
if (retryvar > retry_limit) \
|
bus->regfails += (*retryvar-1);
|
||||||
DHD_ERROR(("%s: FAILED REGISTER WRITE, LINE %d\n", \
|
if (*retryvar > retry_limit)
|
||||||
__func__, __LINE__)); \
|
DHD_ERROR(("FAILED REGISTER WRITE %Xh\n", reg_offset));
|
||||||
} \
|
}
|
||||||
} while (0)
|
}
|
||||||
|
|
||||||
#define DHD_BUS SDIO_BUS
|
#define DHD_BUS SDIO_BUS
|
||||||
|
|
||||||
|
@ -1173,7 +1173,6 @@ static int brcmf_sdbrcm_clkctl(struct brcmf_bus *bus, uint target, bool pendok)
|
||||||
int brcmf_sdbrcm_bussleep(struct brcmf_bus *bus, bool sleep)
|
int brcmf_sdbrcm_bussleep(struct brcmf_bus *bus, bool sleep)
|
||||||
{
|
{
|
||||||
struct brcmf_sdio_card *card = bus->card;
|
struct brcmf_sdio_card *card = bus->card;
|
||||||
struct sdpcmd_regs *regs = bus->regs;
|
|
||||||
uint retries = 0;
|
uint retries = 0;
|
||||||
|
|
||||||
DHD_INFO(("brcmf_sdbrcm_bussleep: request %s (currently %s)\n",
|
DHD_INFO(("brcmf_sdbrcm_bussleep: request %s (currently %s)\n",
|
||||||
|
@ -1197,7 +1196,8 @@ int brcmf_sdbrcm_bussleep(struct brcmf_bus *bus, bool sleep)
|
||||||
brcmf_sdbrcm_clkctl(bus, CLK_AVAIL, false);
|
brcmf_sdbrcm_clkctl(bus, CLK_AVAIL, false);
|
||||||
|
|
||||||
/* Tell device to start using OOB wakeup */
|
/* Tell device to start using OOB wakeup */
|
||||||
W_SDREG(SMB_USE_OOB, ®s->tosbmailbox, retries, u32);
|
w_sdreg32(bus, SMB_USE_OOB,
|
||||||
|
offsetof(struct sdpcmd_regs, tosbmailbox), &retries);
|
||||||
if (retries > retry_limit)
|
if (retries > retry_limit)
|
||||||
DHD_ERROR(("CANNOT SIGNAL CHIP, WILL NOT WAKE UP!!\n"));
|
DHD_ERROR(("CANNOT SIGNAL CHIP, WILL NOT WAKE UP!!\n"));
|
||||||
|
|
||||||
|
@ -1236,9 +1236,12 @@ int brcmf_sdbrcm_bussleep(struct brcmf_bus *bus, bool sleep)
|
||||||
brcmf_sdbrcm_clkctl(bus, CLK_AVAIL, false);
|
brcmf_sdbrcm_clkctl(bus, CLK_AVAIL, false);
|
||||||
|
|
||||||
/* Send misc interrupt to indicate OOB not needed */
|
/* Send misc interrupt to indicate OOB not needed */
|
||||||
W_SDREG(0, ®s->tosbmailboxdata, retries, u32);
|
w_sdreg32(bus, 0, offsetof(struct sdpcmd_regs, tosbmailboxdata),
|
||||||
|
&retries);
|
||||||
if (retries <= retry_limit)
|
if (retries <= retry_limit)
|
||||||
W_SDREG(SMB_DEV_INT, ®s->tosbmailbox, retries, u32);
|
w_sdreg32(bus, SMB_DEV_INT,
|
||||||
|
offsetof(struct sdpcmd_regs, tosbmailbox),
|
||||||
|
&retries);
|
||||||
|
|
||||||
if (retries > retry_limit)
|
if (retries > retry_limit)
|
||||||
DHD_ERROR(("CANNOT SIGNAL CHIP TO CLEAR OOB!!\n"));
|
DHD_ERROR(("CANNOT SIGNAL CHIP TO CLEAR OOB!!\n"));
|
||||||
|
@ -3036,7 +3039,8 @@ static int brcmf_sdbrcm_download_state(struct brcmf_bus *bus, bool enter)
|
||||||
bcmerror = 0;
|
bcmerror = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
W_SDREG(0xFFFFFFFF, &bus->regs->intstatus, retries, u32);
|
w_sdreg32(bus, 0xFFFFFFFF,
|
||||||
|
offsetof(struct sdpcmd_regs, intstatus), &retries);
|
||||||
|
|
||||||
brcmf_sdbrcm_chip_resetcore(bus->card, bus->ci->armcorebase);
|
brcmf_sdbrcm_chip_resetcore(bus->card, bus->ci->armcorebase);
|
||||||
|
|
||||||
|
@ -3169,7 +3173,7 @@ void brcmf_sdbrcm_bus_stop(struct brcmf_bus *bus, bool enforce_mutex)
|
||||||
tasklet_kill(&bus->tasklet);
|
tasklet_kill(&bus->tasklet);
|
||||||
|
|
||||||
/* Disable and clear interrupts at the chip level also */
|
/* Disable and clear interrupts at the chip level also */
|
||||||
W_SDREG(0, &bus->regs->hostintmask, retries, u32);
|
w_sdreg32(bus, 0, offsetof(struct sdpcmd_regs, hostintmask), &retries);
|
||||||
local_hostintmask = bus->hostintmask;
|
local_hostintmask = bus->hostintmask;
|
||||||
bus->hostintmask = 0;
|
bus->hostintmask = 0;
|
||||||
|
|
||||||
|
@ -3196,7 +3200,8 @@ void brcmf_sdbrcm_bus_stop(struct brcmf_bus *bus, bool enforce_mutex)
|
||||||
SDIO_FUNC_ENABLE_1, NULL);
|
SDIO_FUNC_ENABLE_1, NULL);
|
||||||
|
|
||||||
/* Clear any pending interrupts now that F2 is disabled */
|
/* Clear any pending interrupts now that F2 is disabled */
|
||||||
W_SDREG(local_hostintmask, &bus->regs->intstatus, retries, u32);
|
w_sdreg32(bus, local_hostintmask,
|
||||||
|
offsetof(struct sdpcmd_regs, intstatus), &retries);
|
||||||
|
|
||||||
/* Turn off the backplane clock (only) */
|
/* Turn off the backplane clock (only) */
|
||||||
brcmf_sdbrcm_clkctl(bus, CLK_SDONLY, false);
|
brcmf_sdbrcm_clkctl(bus, CLK_SDONLY, false);
|
||||||
|
@ -3274,8 +3279,8 @@ int brcmf_sdbrcm_bus_init(struct brcmf_pub *drvr, bool enforce_mutex)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Enable function 2 (frame transfers) */
|
/* Enable function 2 (frame transfers) */
|
||||||
W_SDREG((SDPCM_PROT_VERSION << SMB_DATA_VERSION_SHIFT),
|
w_sdreg32(bus, SDPCM_PROT_VERSION << SMB_DATA_VERSION_SHIFT,
|
||||||
&bus->regs->tosbmailboxdata, retries, u32);
|
offsetof(struct sdpcmd_regs, tosbmailboxdata), &retries);
|
||||||
enable = (SDIO_FUNC_ENABLE_1 | SDIO_FUNC_ENABLE_2);
|
enable = (SDIO_FUNC_ENABLE_1 | SDIO_FUNC_ENABLE_2);
|
||||||
|
|
||||||
brcmf_sdcard_cfg_write(bus->card, SDIO_FUNC_0, SDIO_CCCR_IOEx, enable,
|
brcmf_sdcard_cfg_write(bus->card, SDIO_FUNC_0, SDIO_CCCR_IOEx, enable,
|
||||||
|
@ -3296,9 +3301,8 @@ int brcmf_sdbrcm_bus_init(struct brcmf_pub *drvr, bool enforce_mutex)
|
||||||
if (ready == enable) {
|
if (ready == enable) {
|
||||||
/* 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,
|
w_sdreg32(bus, bus->hostintmask,
|
||||||
(unsigned int *)CORE_BUS_REG(bus->ci->buscorebase,
|
offsetof(struct sdpcmd_regs, hostintmask), &retries);
|
||||||
hostintmask), retries, u32);
|
|
||||||
|
|
||||||
brcmf_sdcard_cfg_write(bus->card, SDIO_FUNC_1, SBSDIO_WATERMARK,
|
brcmf_sdcard_cfg_write(bus->card, SDIO_FUNC_1, SBSDIO_WATERMARK,
|
||||||
(u8) watermark, &err);
|
(u8) watermark, &err);
|
||||||
|
@ -3356,7 +3360,6 @@ exit:
|
||||||
static void brcmf_sdbrcm_rxfail(struct brcmf_bus *bus, bool abort, bool rtx)
|
static void brcmf_sdbrcm_rxfail(struct brcmf_bus *bus, bool abort, bool rtx)
|
||||||
{
|
{
|
||||||
struct brcmf_sdio_card *card = bus->card;
|
struct brcmf_sdio_card *card = bus->card;
|
||||||
struct sdpcmd_regs *regs = bus->regs;
|
|
||||||
uint retries = 0;
|
uint retries = 0;
|
||||||
u16 lastrbc;
|
u16 lastrbc;
|
||||||
u8 hi, lo;
|
u8 hi, lo;
|
||||||
|
@ -3402,7 +3405,9 @@ static void brcmf_sdbrcm_rxfail(struct brcmf_bus *bus, bool abort, bool rtx)
|
||||||
|
|
||||||
if (rtx) {
|
if (rtx) {
|
||||||
bus->rxrtx++;
|
bus->rxrtx++;
|
||||||
W_SDREG(SMB_NAK, ®s->tosbmailbox, retries, u32);
|
w_sdreg32(bus, SMB_NAK,
|
||||||
|
offsetof(struct sdpcmd_regs, tosbmailbox), &retries);
|
||||||
|
|
||||||
bus->f1regdata++;
|
bus->f1regdata++;
|
||||||
if (retries <= retry_limit)
|
if (retries <= retry_limit)
|
||||||
bus->rxskip = true;
|
bus->rxskip = true;
|
||||||
|
@ -4523,7 +4528,6 @@ deliver:
|
||||||
|
|
||||||
static u32 brcmf_sdbrcm_hostmail(struct brcmf_bus *bus)
|
static u32 brcmf_sdbrcm_hostmail(struct brcmf_bus *bus)
|
||||||
{
|
{
|
||||||
struct sdpcmd_regs *regs = bus->regs;
|
|
||||||
u32 intstatus = 0;
|
u32 intstatus = 0;
|
||||||
u32 hmb_data;
|
u32 hmb_data;
|
||||||
u8 fcbits;
|
u8 fcbits;
|
||||||
|
@ -4536,7 +4540,8 @@ static u32 brcmf_sdbrcm_hostmail(struct brcmf_bus *bus)
|
||||||
offsetof(struct sdpcmd_regs, tohostmailboxdata), &retries);
|
offsetof(struct sdpcmd_regs, tohostmailboxdata), &retries);
|
||||||
|
|
||||||
if (retries <= retry_limit)
|
if (retries <= retry_limit)
|
||||||
W_SDREG(SMB_INT_ACK, ®s->tosbmailbox, retries, u32);
|
w_sdreg32(bus, SMB_INT_ACK,
|
||||||
|
offsetof(struct sdpcmd_regs, tosbmailbox), &retries);
|
||||||
bus->f1regdata += 2;
|
bus->f1regdata += 2;
|
||||||
|
|
||||||
/* Dongle recomposed rx frames, accept them again */
|
/* Dongle recomposed rx frames, accept them again */
|
||||||
|
@ -4600,7 +4605,6 @@ static u32 brcmf_sdbrcm_hostmail(struct brcmf_bus *bus)
|
||||||
static bool brcmf_sdbrcm_dpc(struct brcmf_bus *bus)
|
static bool brcmf_sdbrcm_dpc(struct brcmf_bus *bus)
|
||||||
{
|
{
|
||||||
struct brcmf_sdio_card *card = bus->card;
|
struct brcmf_sdio_card *card = bus->card;
|
||||||
struct sdpcmd_regs *regs = bus->regs;
|
|
||||||
u32 intstatus, newstatus = 0;
|
u32 intstatus, newstatus = 0;
|
||||||
uint retries = 0;
|
uint retries = 0;
|
||||||
uint rxlimit = brcmf_rxbound; /* Rx frames to read before resched */
|
uint rxlimit = brcmf_rxbound; /* Rx frames to read before resched */
|
||||||
|
@ -4686,7 +4690,9 @@ static bool brcmf_sdbrcm_dpc(struct brcmf_bus *bus)
|
||||||
newstatus &= bus->hostintmask;
|
newstatus &= bus->hostintmask;
|
||||||
bus->fcstate = !!(newstatus & I_HMB_FC_STATE);
|
bus->fcstate = !!(newstatus & I_HMB_FC_STATE);
|
||||||
if (newstatus) {
|
if (newstatus) {
|
||||||
W_SDREG(newstatus, ®s->intstatus, retries, u32);
|
w_sdreg32(bus, newstatus,
|
||||||
|
offsetof(struct sdpcmd_regs, intstatus),
|
||||||
|
&retries);
|
||||||
bus->f1regdata++;
|
bus->f1regdata++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4701,7 +4707,9 @@ static bool brcmf_sdbrcm_dpc(struct brcmf_bus *bus)
|
||||||
*/
|
*/
|
||||||
if (intstatus & I_HMB_FC_CHANGE) {
|
if (intstatus & I_HMB_FC_CHANGE) {
|
||||||
intstatus &= ~I_HMB_FC_CHANGE;
|
intstatus &= ~I_HMB_FC_CHANGE;
|
||||||
W_SDREG(I_HMB_FC_CHANGE, ®s->intstatus, retries, u32);
|
w_sdreg32(bus, I_HMB_FC_CHANGE,
|
||||||
|
offsetof(struct sdpcmd_regs, intstatus), &retries);
|
||||||
|
|
||||||
r_sdreg32(bus, &newstatus,
|
r_sdreg32(bus, &newstatus,
|
||||||
offsetof(struct sdpcmd_regs, intstatus), &retries);
|
offsetof(struct sdpcmd_regs, intstatus), &retries);
|
||||||
bus->f1regdata += 2;
|
bus->f1regdata += 2;
|
||||||
|
|
Loading…
Reference in New Issue