提交 6247d2aa 编写于 作者: R Rafał Miłecki 提交者: John W. Linville

b43: update flushing many writes performed in a row

Flush radio writes as well and add some tiny optimizations (e.g.
masksetting PHY reg involves reading it, so reset the counter).
Signed-off-by: NRafał Miłecki <zajec5@gmail.com>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 07bc7884
...@@ -60,7 +60,21 @@ static inline bool b43_bus_host_is_pcmcia(struct b43_bus_dev *dev) ...@@ -60,7 +60,21 @@ static inline bool b43_bus_host_is_pcmcia(struct b43_bus_dev *dev)
#else #else
return false; return false;
#endif #endif
};
static inline bool b43_bus_host_is_pci(struct b43_bus_dev *dev)
{
#ifdef CONFIG_B43_BCMA
if (dev->bus_type == B43_BUS_BCMA)
return (dev->bdev->bus->hosttype == BCMA_HOSTTYPE_PCI);
#endif
#ifdef CONFIG_B43_SSB
if (dev->bus_type == B43_BUS_SSB)
return (dev->sdev->bus->bustype == SSB_BUSTYPE_PCI);
#endif
return false;
} }
static inline bool b43_bus_host_is_sdio(struct b43_bus_dev *dev) static inline bool b43_bus_host_is_sdio(struct b43_bus_dev *dev)
{ {
#ifdef CONFIG_B43_SSB #ifdef CONFIG_B43_SSB
......
...@@ -222,12 +222,18 @@ static inline void assert_mac_suspended(struct b43_wldev *dev) ...@@ -222,12 +222,18 @@ static inline void assert_mac_suspended(struct b43_wldev *dev)
u16 b43_radio_read(struct b43_wldev *dev, u16 reg) u16 b43_radio_read(struct b43_wldev *dev, u16 reg)
{ {
assert_mac_suspended(dev); assert_mac_suspended(dev);
dev->phy.writes_counter = 0;
return dev->phy.ops->radio_read(dev, reg); return dev->phy.ops->radio_read(dev, reg);
} }
void b43_radio_write(struct b43_wldev *dev, u16 reg, u16 value) void b43_radio_write(struct b43_wldev *dev, u16 reg, u16 value)
{ {
assert_mac_suspended(dev); assert_mac_suspended(dev);
if (b43_bus_host_is_pci(dev->dev) &&
++dev->phy.writes_counter > B43_MAX_WRITES_IN_ROW) {
b43_read32(dev, B43_MMIO_MACCTL);
dev->phy.writes_counter = 1;
}
dev->phy.ops->radio_write(dev, reg, value); dev->phy.ops->radio_write(dev, reg, value);
} }
...@@ -274,11 +280,12 @@ u16 b43_phy_read(struct b43_wldev *dev, u16 reg) ...@@ -274,11 +280,12 @@ u16 b43_phy_read(struct b43_wldev *dev, u16 reg)
void b43_phy_write(struct b43_wldev *dev, u16 reg, u16 value) void b43_phy_write(struct b43_wldev *dev, u16 reg, u16 value)
{ {
assert_mac_suspended(dev); assert_mac_suspended(dev);
dev->phy.ops->phy_write(dev, reg, value); if (b43_bus_host_is_pci(dev->dev) &&
if (++dev->phy.writes_counter == B43_MAX_WRITES_IN_ROW) { ++dev->phy.writes_counter > B43_MAX_WRITES_IN_ROW) {
b43_read16(dev, B43_MMIO_PHY_VER); b43_read16(dev, B43_MMIO_PHY_VER);
dev->phy.writes_counter = 0; dev->phy.writes_counter = 1;
} }
dev->phy.ops->phy_write(dev, reg, value);
} }
void b43_phy_copy(struct b43_wldev *dev, u16 destreg, u16 srcreg) void b43_phy_copy(struct b43_wldev *dev, u16 destreg, u16 srcreg)
......
...@@ -6517,6 +6517,7 @@ static void b43_nphy_op_maskset(struct b43_wldev *dev, u16 reg, u16 mask, ...@@ -6517,6 +6517,7 @@ static void b43_nphy_op_maskset(struct b43_wldev *dev, u16 reg, u16 mask,
check_phyreg(dev, reg); check_phyreg(dev, reg);
b43_write16(dev, B43_MMIO_PHY_CONTROL, reg); b43_write16(dev, B43_MMIO_PHY_CONTROL, reg);
b43_maskset16(dev, B43_MMIO_PHY_DATA, mask, set); b43_maskset16(dev, B43_MMIO_PHY_DATA, mask, set);
dev->phy.writes_counter = 1;
} }
static u16 b43_nphy_op_radio_read(struct b43_wldev *dev, u16 reg) static u16 b43_nphy_op_radio_read(struct b43_wldev *dev, u16 reg)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部