提交 93760716 编写于 作者: B Brett Rudley 提交者: Greg Kroah-Hartman

staging: brcm80211: nicpci.c: replace osl based PCI calls with native linux pci calls

Get rid of the private PCI access routines and replace with standard calls from linux/pci.h in nicpci.c

(The private versions are still used in siutils.c... for now)
Signed-off-by: NBrett Rudley <brudley@broadcom.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 e69284f2
...@@ -71,35 +71,6 @@ static bool pcicore_pmecap(pcicore_info_t *pi); ...@@ -71,35 +71,6 @@ static bool pcicore_pmecap(pcicore_info_t *pi);
#define PCIE_ASPM(sih) ((PCIE_PUB(sih)) && (((sih)->buscorerev >= 3) && ((sih)->buscorerev <= 5))) #define PCIE_ASPM(sih) ((PCIE_PUB(sih)) && (((sih)->buscorerev >= 3) && ((sih)->buscorerev <= 5)))
#define DWORD_ALIGN(x) (x & ~(0x03))
#define BYTE_POS(x) (x & 0x3)
#define WORD_POS(x) (x & 0x1)
#define BYTE_SHIFT(x) (8 * BYTE_POS(x))
#define WORD_SHIFT(x) (16 * WORD_POS(x))
#define BYTE_VAL(a, x) ((a >> BYTE_SHIFT(x)) & 0xFF)
#define WORD_VAL(a, x) ((a >> WORD_SHIFT(x)) & 0xFFFF)
#define read_pci_cfg_byte(a) \
(BYTE_VAL(OSL_PCI_READ_CONFIG(osh, DWORD_ALIGN(a), 4), a) & 0xff)
#define read_pci_cfg_word(a) \
(WORD_VAL(OSL_PCI_READ_CONFIG(osh, DWORD_ALIGN(a), 4), a) & 0xffff)
#define write_pci_cfg_byte(a, val) do { \
u32 tmpval; \
tmpval = (OSL_PCI_READ_CONFIG(osh, DWORD_ALIGN(a), 4) & ~0xFF << BYTE_POS(a)) | \
val << BYTE_POS(a); \
OSL_PCI_WRITE_CONFIG(osh, DWORD_ALIGN(a), 4, tmpval); \
} while (0)
#define write_pci_cfg_word(a, val) do { \
u32 tmpval; \
tmpval = (OSL_PCI_READ_CONFIG(osh, DWORD_ALIGN(a), 4) & ~0xFFFF << WORD_POS(a)) | \
val << WORD_POS(a); \
OSL_PCI_WRITE_CONFIG(osh, DWORD_ALIGN(a), 4, tmpval); \
} while (0)
/* delay needed between the mdio control/ mdiodata register data access */ /* delay needed between the mdio control/ mdiodata register data access */
#define PR28829_DELAY() udelay(10) #define PR28829_DELAY() udelay(10)
...@@ -158,29 +129,29 @@ pcicore_find_pci_capability(struct osl_info *osh, u8 req_cap_id, ...@@ -158,29 +129,29 @@ pcicore_find_pci_capability(struct osl_info *osh, u8 req_cap_id,
u8 byte_val; u8 byte_val;
/* check for Header type 0 */ /* check for Header type 0 */
byte_val = read_pci_cfg_byte(PCI_CFG_HDR); pci_read_config_byte(osh->pdev, PCI_CFG_HDR, &byte_val);
if ((byte_val & 0x7f) != PCI_HEADER_NORMAL) if ((byte_val & 0x7f) != PCI_HEADER_NORMAL)
goto end; goto end;
/* check if the capability pointer field exists */ /* check if the capability pointer field exists */
byte_val = read_pci_cfg_byte(PCI_CFG_STAT); pci_read_config_byte(osh->pdev, PCI_CFG_STAT, &byte_val);
if (!(byte_val & PCI_CAPPTR_PRESENT)) if (!(byte_val & PCI_CAPPTR_PRESENT))
goto end; goto end;
cap_ptr = read_pci_cfg_byte(PCI_CFG_CAPPTR); pci_read_config_byte(osh->pdev, PCI_CFG_CAPPTR, &cap_ptr);
/* check if the capability pointer is 0x00 */ /* check if the capability pointer is 0x00 */
if (cap_ptr == 0x00) if (cap_ptr == 0x00)
goto end; goto end;
/* loop thr'u the capability list and see if the pcie capabilty exists */ /* loop thr'u the capability list and see if the pcie capabilty exists */
cap_id = read_pci_cfg_byte(cap_ptr); pci_read_config_byte(osh->pdev, cap_ptr, &cap_id);
while (cap_id != req_cap_id) { while (cap_id != req_cap_id) {
cap_ptr = read_pci_cfg_byte((cap_ptr + 1)); pci_read_config_byte(osh->pdev, cap_ptr + 1, &cap_ptr);
if (cap_ptr == 0x00) if (cap_ptr == 0x00)
break; break;
cap_id = read_pci_cfg_byte(cap_ptr); pci_read_config_byte(osh->pdev, cap_ptr, &cap_id);
} }
if (cap_id != req_cap_id) { if (cap_id != req_cap_id) {
goto end; goto end;
...@@ -199,7 +170,7 @@ pcicore_find_pci_capability(struct osl_info *osh, u8 req_cap_id, ...@@ -199,7 +170,7 @@ pcicore_find_pci_capability(struct osl_info *osh, u8 req_cap_id,
bufsize = SZPCR - cap_data; bufsize = SZPCR - cap_data;
*buflen = bufsize; *buflen = bufsize;
while (bufsize--) { while (bufsize--) {
*buf = read_pci_cfg_byte(cap_data); pci_read_config_byte(osh->pdev, cap_data, buf);
cap_data++; cap_data++;
buf++; buf++;
} }
...@@ -374,15 +345,15 @@ u8 pcie_clkreq(void *pch, u32 mask, u32 val) ...@@ -374,15 +345,15 @@ u8 pcie_clkreq(void *pch, u32 mask, u32 val)
if (!offset) if (!offset)
return 0; return 0;
reg_val = OSL_PCI_READ_CONFIG(pi->osh, offset, sizeof(u32)); pci_read_config_dword(pi->osh->pdev, offset, &reg_val);
/* set operation */ /* set operation */
if (mask) { if (mask) {
if (val) if (val)
reg_val |= PCIE_CLKREQ_ENAB; reg_val |= PCIE_CLKREQ_ENAB;
else else
reg_val &= ~PCIE_CLKREQ_ENAB; reg_val &= ~PCIE_CLKREQ_ENAB;
OSL_PCI_WRITE_CONFIG(pi->osh, offset, sizeof(u32), reg_val); pci_write_config_dword(pi->osh->pdev, offset, reg_val);
reg_val = OSL_PCI_READ_CONFIG(pi->osh, offset, sizeof(u32)); pci_read_config_dword(pi->osh->pdev, offset, &reg_val);
} }
if (reg_val & PCIE_CLKREQ_ENAB) if (reg_val & PCIE_CLKREQ_ENAB)
return 1; return 1;
...@@ -503,12 +474,12 @@ static void pcie_war_aspm_clkreq(pcicore_info_t *pi) ...@@ -503,12 +474,12 @@ static void pcie_war_aspm_clkreq(pcicore_info_t *pi)
W_REG(pi->osh, reg16, val16); W_REG(pi->osh, reg16, val16);
w = OSL_PCI_READ_CONFIG(pi->osh, pi->pciecap_lcreg_offset, pci_read_config_dword(pi->osh->pdev, pi->pciecap_lcreg_offset,
sizeof(u32)); &w);
w &= ~PCIE_ASPM_ENAB; w &= ~PCIE_ASPM_ENAB;
w |= pi->pcie_war_aspm_ovr; w |= pi->pcie_war_aspm_ovr;
OSL_PCI_WRITE_CONFIG(pi->osh, pi->pciecap_lcreg_offset, pci_write_config_dword(pi->osh->pdev,
sizeof(u32), w); pi->pciecap_lcreg_offset, w);
} }
reg16 = &pcieregs->sprom[SRSH_CLKREQ_OFFSET_REV5]; reg16 = &pcieregs->sprom[SRSH_CLKREQ_OFFSET_REV5];
...@@ -695,11 +666,9 @@ void pcicore_sleep(void *pch) ...@@ -695,11 +666,9 @@ void pcicore_sleep(void *pch)
if (!pi || !PCIE_ASPM(pi->sih)) if (!pi || !PCIE_ASPM(pi->sih))
return; return;
w = OSL_PCI_READ_CONFIG(pi->osh, pi->pciecap_lcreg_offset, pci_read_config_dword(pi->osh->pdev, pi->pciecap_lcreg_offset, &w);
sizeof(u32));
w &= ~PCIE_CAP_LCREG_ASPML1; w &= ~PCIE_CAP_LCREG_ASPML1;
OSL_PCI_WRITE_CONFIG(pi->osh, pi->pciecap_lcreg_offset, sizeof(u32), pci_write_config_dword(pi->osh->pdev, pi->pciecap_lcreg_offset, w);
w);
pi->pcie_pr42767 = false; pi->pcie_pr42767 = false;
} }
...@@ -731,7 +700,7 @@ bool pcicore_pmecap_fast(struct osl_info *osh) ...@@ -731,7 +700,7 @@ bool pcicore_pmecap_fast(struct osl_info *osh)
if (!cap_ptr) if (!cap_ptr)
return false; return false;
pmecap = OSL_PCI_READ_CONFIG(osh, cap_ptr, sizeof(u32)); pci_read_config_dword(osh->pdev, cap_ptr, &pmecap);
return (pmecap & PME_CAP_PM_STATES) != 0; return (pmecap & PME_CAP_PM_STATES) != 0;
} }
...@@ -754,9 +723,8 @@ static bool pcicore_pmecap(pcicore_info_t *pi) ...@@ -754,9 +723,8 @@ static bool pcicore_pmecap(pcicore_info_t *pi)
pi->pmecap_offset = cap_ptr; pi->pmecap_offset = cap_ptr;
pmecap = pci_read_config_dword(pi->osh->pdev, pi->pmecap_offset,
OSL_PCI_READ_CONFIG(pi->osh, pi->pmecap_offset, &pmecap);
sizeof(u32));
/* At least one state can generate PME */ /* At least one state can generate PME */
pi->pmecap = (pmecap & PME_CAP_PM_STATES) != 0; pi->pmecap = (pmecap & PME_CAP_PM_STATES) != 0;
...@@ -775,11 +743,11 @@ void pcicore_pmeen(void *pch) ...@@ -775,11 +743,11 @@ void pcicore_pmeen(void *pch)
if (!pcicore_pmecap(pi)) if (!pcicore_pmecap(pi))
return; return;
w = OSL_PCI_READ_CONFIG(pi->osh, pi->pmecap_offset + PME_CSR_OFFSET, pci_read_config_dword(pi->osh->pdev, pi->pmecap_offset + PME_CSR_OFFSET,
sizeof(u32)); &w);
w |= (PME_CSR_PME_EN); w |= (PME_CSR_PME_EN);
OSL_PCI_WRITE_CONFIG(pi->osh, pi->pmecap_offset + PME_CSR_OFFSET, pci_write_config_dword(pi->osh->pdev,
sizeof(u32), w); pi->pmecap_offset + PME_CSR_OFFSET, w);
} }
/* /*
...@@ -793,8 +761,8 @@ bool pcicore_pmestat(void *pch) ...@@ -793,8 +761,8 @@ bool pcicore_pmestat(void *pch)
if (!pcicore_pmecap(pi)) if (!pcicore_pmecap(pi))
return false; return false;
w = OSL_PCI_READ_CONFIG(pi->osh, pi->pmecap_offset + PME_CSR_OFFSET, pci_read_config_dword(pi->osh->pdev, pi->pmecap_offset + PME_CSR_OFFSET,
sizeof(u32)); &w);
return (w & PME_CSR_PME_STAT) == PME_CSR_PME_STAT; return (w & PME_CSR_PME_STAT) == PME_CSR_PME_STAT;
} }
...@@ -809,22 +777,23 @@ void pcicore_pmeclr(void *pch) ...@@ -809,22 +777,23 @@ void pcicore_pmeclr(void *pch)
if (!pcicore_pmecap(pi)) if (!pcicore_pmecap(pi))
return; return;
w = OSL_PCI_READ_CONFIG(pi->osh, pi->pmecap_offset + PME_CSR_OFFSET, pci_read_config_dword(pi->osh->pdev, pi->pmecap_offset + PME_CSR_OFFSET,
sizeof(u32)); &w);
PCI_ERROR(("pcicore_pci_pmeclr PMECSR : 0x%x\n", w)); PCI_ERROR(("pcicore_pci_pmeclr PMECSR : 0x%x\n", w));
/* PMESTAT is cleared by writing 1 to it */ /* PMESTAT is cleared by writing 1 to it */
w &= ~(PME_CSR_PME_EN); w &= ~(PME_CSR_PME_EN);
OSL_PCI_WRITE_CONFIG(pi->osh, pi->pmecap_offset + PME_CSR_OFFSET, pci_write_config_dword(pi->osh->pdev,
sizeof(u32), w); pi->pmecap_offset + PME_CSR_OFFSET, w);
} }
u32 pcie_lcreg(void *pch, u32 mask, u32 val) u32 pcie_lcreg(void *pch, u32 mask, u32 val)
{ {
pcicore_info_t *pi = (pcicore_info_t *) pch; pcicore_info_t *pi = (pcicore_info_t *) pch;
u8 offset; u8 offset;
u32 tmpval;
offset = pi->pciecap_lcreg_offset; offset = pi->pciecap_lcreg_offset;
if (!offset) if (!offset)
...@@ -832,9 +801,10 @@ u32 pcie_lcreg(void *pch, u32 mask, u32 val) ...@@ -832,9 +801,10 @@ u32 pcie_lcreg(void *pch, u32 mask, u32 val)
/* set operation */ /* set operation */
if (mask) if (mask)
OSL_PCI_WRITE_CONFIG(pi->osh, offset, sizeof(u32), val); pci_write_config_dword(pi->osh->pdev, offset, val);
return OSL_PCI_READ_CONFIG(pi->osh, offset, sizeof(u32)); pci_read_config_dword(pi->osh->pdev, offset, &tmpval);
return tmpval;
} }
u32 u32
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册