aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/b43
diff options
context:
space:
mode:
authorRafał Miłecki <zajec5@gmail.com>2011-08-28 08:28:43 -0400
committerJohn W. Linville <linville@tuxdriver.com>2011-09-13 15:42:29 -0400
commitf533d0fa5efe4bb7a08ead8c6fcf7af243a9035f (patch)
tree279c10dcedeb3a62dbba001c8f7593b86f8370fe /drivers/net/wireless/b43
parentadb5066ae2cefede1807c29ac16e1faa381416da (diff)
b43: LCN-PHY: add R/W ops for PHY and radio
Signed-off-by: Rafał Miłecki <zajec5@gmail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/b43')
-rw-r--r--drivers/net/wireless/b43/phy_lcn.c42
1 files changed, 40 insertions, 2 deletions
diff --git a/drivers/net/wireless/b43/phy_lcn.c b/drivers/net/wireless/b43/phy_lcn.c
index 4b2cd6d24ce..cf75d3dce88 100644
--- a/drivers/net/wireless/b43/phy_lcn.c
+++ b/drivers/net/wireless/b43/phy_lcn.c
@@ -233,6 +233,46 @@ static void b43_phy_lcn_op_adjust_txpower(struct b43_wldev *dev)
233} 233}
234 234
235/************************************************** 235/**************************************************
236 * R/W ops.
237 **************************************************/
238
239static u16 b43_phy_lcn_op_read(struct b43_wldev *dev, u16 reg)
240{
241 b43_write16(dev, B43_MMIO_PHY_CONTROL, reg);
242 return b43_read16(dev, B43_MMIO_PHY_DATA);
243}
244
245static void b43_phy_lcn_op_write(struct b43_wldev *dev, u16 reg, u16 value)
246{
247 b43_write16(dev, B43_MMIO_PHY_CONTROL, reg);
248 b43_write16(dev, B43_MMIO_PHY_DATA, value);
249}
250
251static void b43_phy_lcn_op_maskset(struct b43_wldev *dev, u16 reg, u16 mask,
252 u16 set)
253{
254 b43_write16(dev, B43_MMIO_PHY_CONTROL, reg);
255 b43_write16(dev, B43_MMIO_PHY_DATA,
256 (b43_read16(dev, B43_MMIO_PHY_DATA) & mask) | set);
257}
258
259static u16 b43_phy_lcn_op_radio_read(struct b43_wldev *dev, u16 reg)
260{
261 /* LCN-PHY needs 0x200 for read access */
262 reg |= 0x200;
263
264 b43_write16(dev, B43_MMIO_RADIO24_CONTROL, reg);
265 return b43_read16(dev, B43_MMIO_RADIO24_DATA);
266}
267
268static void b43_phy_lcn_op_radio_write(struct b43_wldev *dev, u16 reg,
269 u16 value)
270{
271 b43_write16(dev, B43_MMIO_RADIO24_CONTROL, reg);
272 b43_write16(dev, B43_MMIO_RADIO24_DATA, value);
273}
274
275/**************************************************
236 * PHY ops struct. 276 * PHY ops struct.
237 **************************************************/ 277 **************************************************/
238 278
@@ -241,13 +281,11 @@ const struct b43_phy_operations b43_phyops_lcn = {
241 .free = b43_phy_lcn_op_free, 281 .free = b43_phy_lcn_op_free,
242 .prepare_structs = b43_phy_lcn_op_prepare_structs, 282 .prepare_structs = b43_phy_lcn_op_prepare_structs,
243 .init = b43_phy_lcn_op_init, 283 .init = b43_phy_lcn_op_init,
244 /*
245 .phy_read = b43_phy_lcn_op_read, 284 .phy_read = b43_phy_lcn_op_read,
246 .phy_write = b43_phy_lcn_op_write, 285 .phy_write = b43_phy_lcn_op_write,
247 .phy_maskset = b43_phy_lcn_op_maskset, 286 .phy_maskset = b43_phy_lcn_op_maskset,
248 .radio_read = b43_phy_lcn_op_radio_read, 287 .radio_read = b43_phy_lcn_op_radio_read,
249 .radio_write = b43_phy_lcn_op_radio_write, 288 .radio_write = b43_phy_lcn_op_radio_write,
250 */
251 .software_rfkill = b43_phy_lcn_op_software_rfkill, 289 .software_rfkill = b43_phy_lcn_op_software_rfkill,
252 .switch_analog = b43_phy_lcn_op_switch_analog, 290 .switch_analog = b43_phy_lcn_op_switch_analog,
253 /* 291 /*