diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2007-12-18 19:31:26 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-01-28 18:09:36 -0500 |
commit | 32bfd35d4b63bd63de4bb0d791ef049c3c868726 (patch) | |
tree | c1c213a35a00bcbe71a2ecc6521e19dec66cf6eb /drivers/net/wireless/b43/xmit.c | |
parent | f653211197f3841f383fa9757ef8ce182c6cf627 (diff) |
mac80211: dont use interface indices in drivers
This patch gets rid of the if_id stuff where possible in favour of
a new per-virtual-interface structure "struct ieee80211_vif". This
structure is located at the end of the per-interface structure and
contains a variable length driver-use data area.
This has two advantages:
* removes the need to look up interfaces by if_id, this is better
for working with network namespaces and performance
* allows drivers to store and retrieve per-interface data without
having to allocate own lists/hash tables
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/b43/xmit.c')
-rw-r--r-- | drivers/net/wireless/b43/xmit.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/net/wireless/b43/xmit.c b/drivers/net/wireless/b43/xmit.c index 419aca1fc4fe..5014213b7752 100644 --- a/drivers/net/wireless/b43/xmit.c +++ b/drivers/net/wireless/b43/xmit.c | |||
@@ -221,7 +221,7 @@ static void generate_txhdr_fw4(struct b43_wldev *dev, | |||
221 | } else { | 221 | } else { |
222 | int fbrate_base100kbps = B43_RATE_TO_BASE100KBPS(rate_fb); | 222 | int fbrate_base100kbps = B43_RATE_TO_BASE100KBPS(rate_fb); |
223 | txhdr->dur_fb = ieee80211_generic_frame_duration(dev->wl->hw, | 223 | txhdr->dur_fb = ieee80211_generic_frame_duration(dev->wl->hw, |
224 | dev->wl->if_id, | 224 | txctl->vif, |
225 | fragment_len, | 225 | fragment_len, |
226 | fbrate_base100kbps); | 226 | fbrate_base100kbps); |
227 | } | 227 | } |
@@ -312,7 +312,7 @@ static void generate_txhdr_fw4(struct b43_wldev *dev, | |||
312 | rts_rate_fb_ofdm = b43_is_ofdm_rate(rts_rate_fb); | 312 | rts_rate_fb_ofdm = b43_is_ofdm_rate(rts_rate_fb); |
313 | 313 | ||
314 | if (txctl->flags & IEEE80211_TXCTL_USE_CTS_PROTECT) { | 314 | if (txctl->flags & IEEE80211_TXCTL_USE_CTS_PROTECT) { |
315 | ieee80211_ctstoself_get(dev->wl->hw, dev->wl->if_id, | 315 | ieee80211_ctstoself_get(dev->wl->hw, txctl->vif, |
316 | fragment_data, fragment_len, | 316 | fragment_data, fragment_len, |
317 | txctl, | 317 | txctl, |
318 | (struct ieee80211_cts *)(txhdr-> | 318 | (struct ieee80211_cts *)(txhdr-> |
@@ -320,7 +320,7 @@ static void generate_txhdr_fw4(struct b43_wldev *dev, | |||
320 | mac_ctl |= B43_TX4_MAC_SENDCTS; | 320 | mac_ctl |= B43_TX4_MAC_SENDCTS; |
321 | len = sizeof(struct ieee80211_cts); | 321 | len = sizeof(struct ieee80211_cts); |
322 | } else { | 322 | } else { |
323 | ieee80211_rts_get(dev->wl->hw, dev->wl->if_id, | 323 | ieee80211_rts_get(dev->wl->hw, txctl->vif, |
324 | fragment_data, fragment_len, txctl, | 324 | fragment_data, fragment_len, txctl, |
325 | (struct ieee80211_rts *)(txhdr-> | 325 | (struct ieee80211_rts *)(txhdr-> |
326 | rts_frame)); | 326 | rts_frame)); |