]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
brcm80211: smac: use bcma core access function in srom.c
authorArend van Spriel <arend@broadcom.com>
Mon, 12 Dec 2011 23:15:01 +0000 (15:15 -0800)
committerJohn W. Linville <linville@tuxdriver.com>
Tue, 13 Dec 2011 20:48:01 +0000 (15:48 -0500)
The code in srom.c now uses the core access function provided by
BCMA so no need to pass __iomem pointer any longer.

Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com>
Reviewed-by: Alwin Beukers <alwin@broadcom.com>
Signed-off-by: Arend van Spriel <arend@broadcom.com>
Signed-off-by: Franky Lin <frankyl@broadcom.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/brcm80211/brcmsmac/aiutils.c
drivers/net/wireless/brcm80211/brcmsmac/srom.c
drivers/net/wireless/brcm80211/brcmsmac/srom.h

index a54cf32d1eb53a9d323508a21d694f80ec860004..bb12ebc20377bec27e5fe82ae05401274dcd0378 100644 (file)
@@ -725,7 +725,7 @@ static struct si_info *ai_doattach(struct si_info *sii,
                goto exit;
 
        /* Init nvram from sprom/otp if they exist */
-       if (srom_var_init(&sii->pub, cc))
+       if (srom_var_init(&sii->pub))
                goto exit;
 
        ai_nvram_process(sii);
index 95eb620fc7f07da395aca5a9c8916ec0613b4ea1..61092156755e0a77984736df7a1ac524bb074ef5 100644 (file)
@@ -586,17 +586,6 @@ static const struct brcms_sromvar perpath_pci_sromvars[] = {
  * shared between devices. */
 static u8 brcms_srom_crc8_table[CRC8_TABLE_SIZE];
 
-static u8 __iomem *
-srom_window_address(struct si_pub *sih, u8 __iomem *curmap)
-{
-       if (ai_get_ccrev(sih) < 32)
-               return curmap + PCI_BAR0_SPROM_OFFSET;
-       if (ai_get_cccaps(sih) & CC_CAP_SROM)
-               return curmap + PCI_16KB0_CCREGS_OFFSET + CC_SROM_OTP;
-
-       return NULL;
-}
-
 static uint mask_shift(u16 mask)
 {
        uint i;
@@ -779,17 +768,27 @@ _initvars_srom_pci(u8 sromrev, u16 *srom, struct list_head *var_list)
  * Return 0 on success, nonzero on error.
  */
 static int
-sprom_read_pci(struct si_pub *sih, u8 __iomem *sprom, uint wordoff,
-              u16 *buf, uint nwords, bool check_crc)
+sprom_read_pci(struct si_pub *sih, u16 *buf, uint nwords, bool check_crc)
 {
        int err = 0;
        uint i;
        u8 *bbuf = (u8 *)buf; /* byte buffer */
        uint nbytes = nwords << 1;
+       struct bcma_device *core;
+       uint sprom_offset;
+
+       /* determine core to read */
+       if (ai_get_ccrev(sih) < 32) {
+               core = ai_findcore(sih, BCMA_CORE_80211, 0);
+               sprom_offset = PCI_BAR0_SPROM_OFFSET;
+       } else {
+               core = ai_findcore(sih, BCMA_CORE_CHIPCOMMON, 0);
+               sprom_offset = CHIPCREGOFFS(sromotp);
+       }
 
        /* read the sprom in bytes */
        for (i = 0; i < nbytes; i++)
-               bbuf[i] = readb(sprom+i);
+               bbuf[i] = bcma_read8(core, sprom_offset+i);
 
        if (buf[0] == 0xffff)
                /*
@@ -851,10 +850,9 @@ static int otp_read_pci(struct si_pub *sih, u16 *buf, uint nwords)
  * Initialize nonvolatile variable table from sprom.
  * Return 0 on success, nonzero on error.
  */
-static int initvars_srom_pci(struct si_pub *sih, void __iomem *curmap)
+int srom_var_init(struct si_pub *sih)
 {
        u16 *srom;
-       u8 __iomem *sromwindow;
        u8 sromrev = 0;
        u32 sr;
        int err = 0;
@@ -866,12 +864,9 @@ static int initvars_srom_pci(struct si_pub *sih, void __iomem *curmap)
        if (!srom)
                return -ENOMEM;
 
-       sromwindow = srom_window_address(sih, curmap);
-
        crc8_populate_lsb(brcms_srom_crc8_table, SROM_CRC8_POLY);
        if (ai_is_sprom_available(sih)) {
-               err = sprom_read_pci(sih, sromwindow, 0, srom,
-                                    SROM4_WORDS, true);
+               err = sprom_read_pci(sih, srom, SROM4_WORDS, true);
 
                if (err == 0)
                        /* srom read and passed crc */
@@ -921,21 +916,6 @@ void srom_free_vars(struct si_pub *sih)
                kfree(entry);
        }
 }
-/*
- * Initialize local vars from the right source for this platform.
- * Return 0 on success, nonzero on error.
- */
-int srom_var_init(struct si_pub *sih, void __iomem *curmap)
-{
-       uint len;
-
-       len = 0;
-
-       if (curmap != NULL)
-               return initvars_srom_pci(sih, curmap);
-
-       return -EINVAL;
-}
 
 /*
  * Search the name=value vars for a specific one and return its value.
index c81df9798e50ac606dc4c9e15122f8ba58d28354..f2a58f262c990ce299d376300aaeaf22d12bae18 100644 (file)
@@ -20,7 +20,7 @@
 #include "types.h"
 
 /* Prototypes */
-extern int srom_var_init(struct si_pub *sih, void __iomem *curmap);
+extern int srom_var_init(struct si_pub *sih);
 extern void srom_free_vars(struct si_pub *sih);
 
 extern int srom_read(struct si_pub *sih, uint bus, void *curmap,