311-v4.16-0004-brcmfmac-Clean-up-brcmf_sdiod_set_sbaddr_window.patch 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. From b9b0d290bc0c90a5a262bc89c9d995988ea98669 Mon Sep 17 00:00:00 2001
  2. From: Ian Molton <[email protected]>
  3. Date: Mon, 13 Nov 2017 21:35:41 +0100
  4. Subject: [PATCH] brcmfmac: Clean up brcmf_sdiod_set_sbaddr_window()
  5. This function sets the address of the IO window used for
  6. SDIO accesses onto the backplane of the chip.
  7. It currently uses 3 separate masks despite the full mask being
  8. defined in the code already. Remove the separate masks and clean up.
  9. Signed-off-by: Ian Molton <[email protected]>
  10. Signed-off-by: Arend van Spriel <[email protected]>
  11. Signed-off-by: Kalle Valo <[email protected]>
  12. ---
  13. .../net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c | 17 +++++------------
  14. drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.h | 3 ---
  15. 2 files changed, 5 insertions(+), 15 deletions(-)
  16. --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c
  17. +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/bcmsdh.c
  18. @@ -410,23 +410,16 @@ static int
  19. brcmf_sdiod_set_sbaddr_window(struct brcmf_sdio_dev *sdiodev, u32 address)
  20. {
  21. int err = 0, i;
  22. - u8 addr[3];
  23. + u32 addr;
  24. if (sdiodev->state == BRCMF_SDIOD_NOMEDIUM)
  25. return -ENOMEDIUM;
  26. - addr[0] = (address >> 8) & SBSDIO_SBADDRLOW_MASK;
  27. - addr[1] = (address >> 16) & SBSDIO_SBADDRMID_MASK;
  28. - addr[2] = (address >> 24) & SBSDIO_SBADDRHIGH_MASK;
  29. + addr = (address & SBSDIO_SBWINDOW_MASK) >> 8;
  30. - for (i = 0; i < 3; i++) {
  31. - brcmf_sdiod_regwb(sdiodev, SBSDIO_FUNC1_SBADDRLOW + i, addr[i],
  32. - &err);
  33. - if (err) {
  34. - brcmf_err("failed at addr: 0x%0x\n",
  35. - SBSDIO_FUNC1_SBADDRLOW + i);
  36. - }
  37. - }
  38. + for (i = 0 ; i < 3 && !err ; i++, addr >>= 8)
  39. + brcmf_sdiod_regwb(sdiodev, SBSDIO_FUNC1_SBADDRLOW + i,
  40. + addr & 0xff, &err);
  41. return err;
  42. }
  43. --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.h
  44. +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/sdio.h
  45. @@ -133,9 +133,6 @@
  46. /* valid bits in SBSDIO_FUNC1_SBADDRxxx regs */
  47. -#define SBSDIO_SBADDRLOW_MASK 0x80 /* Valid bits in SBADDRLOW */
  48. -#define SBSDIO_SBADDRMID_MASK 0xff /* Valid bits in SBADDRMID */
  49. -#define SBSDIO_SBADDRHIGH_MASK 0xffU /* Valid bits in SBADDRHIGH */
  50. /* Address bits from SBADDR regs */
  51. #define SBSDIO_SBWINDOW_MASK 0xffff8000