提交 6a9a25ee 编写于 作者: R Roland Vossen 提交者: Greg Kroah-Hartman

staging: brcm80211: replaced #ifdef __mips__ sections by W_REG_FLUSH

Code cleanup. A read-after-write construct is present in the code to ensure
write order for certain Broadcom chips. Those chips are: bcm4706, bcm4716,
bcm4717, bcm4718. All these chips contain a MIPS processor. This patch gets
rid of several #ifdef __mips__ sections by defining a new macro in a header
file. This patch does not introduce behavioral changes and is purely meant
for code cleanup. The __mips__ define will be made more specific in a future
patch.
Signed-off-by: NRoland Vossen <rvossen@broadcom.com>
Reviewed-by: NArend van Spriel <arend@broadcom.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 0a0ad7d2
...@@ -247,16 +247,10 @@ u16 read_radio_reg(phy_info_t *pi, u16 addr) ...@@ -247,16 +247,10 @@ u16 read_radio_reg(phy_info_t *pi, u16 addr)
if ((D11REV_GE(pi->sh->corerev, 24)) || if ((D11REV_GE(pi->sh->corerev, 24)) ||
(D11REV_IS(pi->sh->corerev, 22) (D11REV_IS(pi->sh->corerev, 22)
&& (pi->pubpi.phy_type != PHY_TYPE_SSN))) { && (pi->pubpi.phy_type != PHY_TYPE_SSN))) {
W_REG(&pi->regs->radioregaddr, addr); W_REG_FLUSH(&pi->regs->radioregaddr, addr);
#ifdef __mips__
(void)R_REG(&pi->regs->radioregaddr);
#endif
data = R_REG(&pi->regs->radioregdata); data = R_REG(&pi->regs->radioregdata);
} else { } else {
W_REG(&pi->regs->phy4waddr, addr); W_REG_FLUSH(&pi->regs->phy4waddr, addr);
#ifdef __mips__
(void)R_REG(&pi->regs->phy4waddr);
#endif
#ifdef __ARM_ARCH_4T__ #ifdef __ARM_ARCH_4T__
__asm__(" .align 4 "); __asm__(" .align 4 ");
...@@ -281,16 +275,10 @@ void write_radio_reg(phy_info_t *pi, u16 addr, u16 val) ...@@ -281,16 +275,10 @@ void write_radio_reg(phy_info_t *pi, u16 addr, u16 val)
(D11REV_IS(pi->sh->corerev, 22) (D11REV_IS(pi->sh->corerev, 22)
&& (pi->pubpi.phy_type != PHY_TYPE_SSN))) { && (pi->pubpi.phy_type != PHY_TYPE_SSN))) {
W_REG(&pi->regs->radioregaddr, addr); W_REG_FLUSH(&pi->regs->radioregaddr, addr);
#ifdef __mips__
(void)R_REG(&pi->regs->radioregaddr);
#endif
W_REG(&pi->regs->radioregdata, val); W_REG(&pi->regs->radioregdata, val);
} else { } else {
W_REG(&pi->regs->phy4waddr, addr); W_REG_FLUSH(&pi->regs->phy4waddr, addr);
#ifdef __mips__
(void)R_REG(&pi->regs->phy4waddr);
#endif
W_REG(&pi->regs->phy4wdatalo, val); W_REG(&pi->regs->phy4wdatalo, val);
} }
...@@ -312,29 +300,17 @@ static u32 read_radio_id(phy_info_t *pi) ...@@ -312,29 +300,17 @@ static u32 read_radio_id(phy_info_t *pi)
if (D11REV_GE(pi->sh->corerev, 24)) { if (D11REV_GE(pi->sh->corerev, 24)) {
u32 b0, b1, b2; u32 b0, b1, b2;
W_REG(&pi->regs->radioregaddr, 0); W_REG_FLUSH(&pi->regs->radioregaddr, 0);
#ifdef __mips__
(void)R_REG(&pi->regs->radioregaddr);
#endif
b0 = (u32) R_REG(&pi->regs->radioregdata); b0 = (u32) R_REG(&pi->regs->radioregdata);
W_REG(&pi->regs->radioregaddr, 1); W_REG_FLUSH(&pi->regs->radioregaddr, 1);
#ifdef __mips__
(void)R_REG(&pi->regs->radioregaddr);
#endif
b1 = (u32) R_REG(&pi->regs->radioregdata); b1 = (u32) R_REG(&pi->regs->radioregdata);
W_REG(&pi->regs->radioregaddr, 2); W_REG_FLUSH(&pi->regs->radioregaddr, 2);
#ifdef __mips__
(void)R_REG(&pi->regs->radioregaddr);
#endif
b2 = (u32) R_REG(&pi->regs->radioregdata); b2 = (u32) R_REG(&pi->regs->radioregdata);
id = ((b0 & 0xf) << 28) | (((b2 << 8) | b1) << 12) | ((b0 >> 4) id = ((b0 & 0xf) << 28) | (((b2 << 8) | b1) << 12) | ((b0 >> 4)
& 0xf); & 0xf);
} else { } else {
W_REG(&pi->regs->phy4waddr, RADIO_IDCODE); W_REG_FLUSH(&pi->regs->phy4waddr, RADIO_IDCODE);
#ifdef __mips__
(void)R_REG(&pi->regs->phy4waddr);
#endif
id = (u32) R_REG(&pi->regs->phy4wdatalo); id = (u32) R_REG(&pi->regs->phy4wdatalo);
id |= (u32) R_REG(&pi->regs->phy4wdatahi) << 16; id |= (u32) R_REG(&pi->regs->phy4wdatahi) << 16;
} }
...@@ -397,10 +373,7 @@ u16 read_phy_reg(phy_info_t *pi, u16 addr) ...@@ -397,10 +373,7 @@ u16 read_phy_reg(phy_info_t *pi, u16 addr)
regs = pi->regs; regs = pi->regs;
W_REG(&regs->phyregaddr, addr); W_REG_FLUSH(&regs->phyregaddr, addr);
#ifdef __mips__
(void)R_REG(&regs->phyregaddr);
#endif
pi->phy_wreg = 0; pi->phy_wreg = 0;
return R_REG(&regs->phyregdata); return R_REG(&regs->phyregdata);
...@@ -413,8 +386,7 @@ void write_phy_reg(phy_info_t *pi, u16 addr, u16 val) ...@@ -413,8 +386,7 @@ void write_phy_reg(phy_info_t *pi, u16 addr, u16 val)
regs = pi->regs; regs = pi->regs;
#ifdef __mips__ #ifdef __mips__
W_REG(&regs->phyregaddr, addr); W_REG_FLUSH(&regs->phyregaddr, addr);
(void)R_REG(&regs->phyregaddr);
W_REG(&regs->phyregdata, val); W_REG(&regs->phyregdata, val);
if (addr == 0x72) if (addr == 0x72)
(void)R_REG(&regs->phyregdata); (void)R_REG(&regs->phyregdata);
...@@ -436,10 +408,7 @@ void and_phy_reg(phy_info_t *pi, u16 addr, u16 val) ...@@ -436,10 +408,7 @@ void and_phy_reg(phy_info_t *pi, u16 addr, u16 val)
regs = pi->regs; regs = pi->regs;
W_REG(&regs->phyregaddr, addr); W_REG_FLUSH(&regs->phyregaddr, addr);
#ifdef __mips__
(void)R_REG(&regs->phyregaddr);
#endif
W_REG(&regs->phyregdata, (R_REG(&regs->phyregdata) & val)); W_REG(&regs->phyregdata, (R_REG(&regs->phyregdata) & val));
pi->phy_wreg = 0; pi->phy_wreg = 0;
...@@ -451,10 +420,7 @@ void or_phy_reg(phy_info_t *pi, u16 addr, u16 val) ...@@ -451,10 +420,7 @@ void or_phy_reg(phy_info_t *pi, u16 addr, u16 val)
regs = pi->regs; regs = pi->regs;
W_REG(&regs->phyregaddr, addr); W_REG_FLUSH(&regs->phyregaddr, addr);
#ifdef __mips__
(void)R_REG(&regs->phyregaddr);
#endif
W_REG(&regs->phyregdata, (R_REG(&regs->phyregdata) | val)); W_REG(&regs->phyregdata, (R_REG(&regs->phyregdata) | val));
pi->phy_wreg = 0; pi->phy_wreg = 0;
...@@ -466,10 +432,7 @@ void mod_phy_reg(phy_info_t *pi, u16 addr, u16 mask, u16 val) ...@@ -466,10 +432,7 @@ void mod_phy_reg(phy_info_t *pi, u16 addr, u16 mask, u16 val)
regs = pi->regs; regs = pi->regs;
W_REG(&regs->phyregaddr, addr); W_REG_FLUSH(&regs->phyregaddr, addr);
#ifdef __mips__
(void)R_REG(&regs->phyregaddr);
#endif
W_REG(&regs->phyregdata, W_REG(&regs->phyregdata,
((R_REG(&regs->phyregdata) & ~mask) | (val & mask))); ((R_REG(&regs->phyregdata) & ~mask) | (val & mask)));
......
...@@ -366,6 +366,17 @@ extern void bcm_prpkt(const char *msg, struct sk_buff *p0); ...@@ -366,6 +366,17 @@ extern void bcm_prpkt(const char *msg, struct sk_buff *p0);
} while (0) } while (0)
#endif /* __BIG_ENDIAN */ #endif /* __BIG_ENDIAN */
#ifdef __mips__
/*
* bcm4716 (which includes 4717 & 4718), plus 4706 on PCIe can reorder
* transactions. As a fix, a read after write is performed on certain places
* in the code. Older chips and the newer 5357 family don't require this fix.
*/
#define W_REG_FLUSH(r, v) ({ W_REG((r), (v)); (void)R_REG(r); })
#else
#define W_REG_FLUSH(r, v) W_REG((r), (v))
#endif /* __mips__ */
#define AND_REG(r, v) W_REG((r), R_REG(r) & (v)) #define AND_REG(r, v) W_REG((r), R_REG(r) & (v))
#define OR_REG(r, v) W_REG((r), R_REG(r) | (v)) #define OR_REG(r, v) W_REG((r), R_REG(r) | (v))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册