diff options
author | Rafał Miłecki <zajec5@gmail.com> | 2011-08-28 08:28:43 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-09-13 15:42:29 -0400 |
commit | f533d0fa5efe4bb7a08ead8c6fcf7af243a9035f (patch) | |
tree | 279c10dcedeb3a62dbba001c8f7593b86f8370fe /drivers/net/wireless/b43 | |
parent | adb5066ae2cefede1807c29ac16e1faa381416da (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.c | 42 |
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 | |||
239 | static 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 | |||
245 | static 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 | |||
251 | static 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 | |||
259 | static 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 | |||
268 | static 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 | /* |