diff options
-rw-r--r-- | net/mac80211/tx.c | 54 |
1 files changed, 25 insertions, 29 deletions
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c index 7a14a39ebd78..bf3600a04776 100644 --- a/net/mac80211/tx.c +++ b/net/mac80211/tx.c | |||
@@ -52,9 +52,8 @@ static inline void ieee80211_include_sequence(struct ieee80211_sub_if_data *sdat | |||
52 | static void ieee80211_dump_frame(const char *ifname, const char *title, | 52 | static void ieee80211_dump_frame(const char *ifname, const char *title, |
53 | const struct sk_buff *skb) | 53 | const struct sk_buff *skb) |
54 | { | 54 | { |
55 | const struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data; | 55 | const struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; |
56 | u16 fc; | 56 | unsigned int hdrlen; |
57 | int hdrlen; | ||
58 | DECLARE_MAC_BUF(mac); | 57 | DECLARE_MAC_BUF(mac); |
59 | 58 | ||
60 | printk(KERN_DEBUG "%s: %s (len=%d)", ifname, title, skb->len); | 59 | printk(KERN_DEBUG "%s: %s (len=%d)", ifname, title, skb->len); |
@@ -63,13 +62,12 @@ static void ieee80211_dump_frame(const char *ifname, const char *title, | |||
63 | return; | 62 | return; |
64 | } | 63 | } |
65 | 64 | ||
66 | fc = le16_to_cpu(hdr->frame_control); | 65 | hdrlen = ieee80211_hdrlen(hdr->frame_control); |
67 | hdrlen = ieee80211_get_hdrlen(fc); | ||
68 | if (hdrlen > skb->len) | 66 | if (hdrlen > skb->len) |
69 | hdrlen = skb->len; | 67 | hdrlen = skb->len; |
70 | if (hdrlen >= 4) | 68 | if (hdrlen >= 4) |
71 | printk(" FC=0x%04x DUR=0x%04x", | 69 | printk(" FC=0x%04x DUR=0x%04x", |
72 | fc, le16_to_cpu(hdr->duration_id)); | 70 | le16_to_cpu(hdr->frame_control), le16_to_cpu(hdr->duration_id)); |
73 | if (hdrlen >= 10) | 71 | if (hdrlen >= 10) |
74 | printk(" A1=%s", print_mac(mac, hdr->addr1)); | 72 | printk(" A1=%s", print_mac(mac, hdr->addr1)); |
75 | if (hdrlen >= 16) | 73 | if (hdrlen >= 16) |
@@ -281,7 +279,7 @@ ieee80211_tx_h_sequence(struct ieee80211_tx_data *tx) | |||
281 | { | 279 | { |
282 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; | 280 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; |
283 | 281 | ||
284 | if (ieee80211_get_hdrlen(le16_to_cpu(hdr->frame_control)) >= 24) | 282 | if (ieee80211_hdrlen(hdr->frame_control) >= 24) |
285 | ieee80211_include_sequence(tx->sdata, hdr); | 283 | ieee80211_include_sequence(tx->sdata, hdr); |
286 | 284 | ||
287 | return TX_CONTINUE; | 285 | return TX_CONTINUE; |
@@ -542,8 +540,7 @@ ieee80211_tx_h_rate_ctrl(struct ieee80211_tx_data *tx) | |||
542 | static ieee80211_tx_result | 540 | static ieee80211_tx_result |
543 | ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) | 541 | ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) |
544 | { | 542 | { |
545 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) tx->skb->data; | 543 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; |
546 | u16 fc = le16_to_cpu(hdr->frame_control); | ||
547 | u16 dur; | 544 | u16 dur; |
548 | struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb); | 545 | struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb); |
549 | struct ieee80211_supported_band *sband; | 546 | struct ieee80211_supported_band *sband; |
@@ -595,7 +592,7 @@ ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) | |||
595 | /* Transmit data frames using short preambles if the driver supports | 592 | /* Transmit data frames using short preambles if the driver supports |
596 | * short preambles at the selected rate and short preambles are | 593 | * short preambles at the selected rate and short preambles are |
597 | * available on the network at the current point in time. */ | 594 | * available on the network at the current point in time. */ |
598 | if (((fc & IEEE80211_FCTL_FTYPE) == IEEE80211_FTYPE_DATA) && | 595 | if (ieee80211_is_data(hdr->frame_control) && |
599 | (sband->bitrates[tx->rate_idx].flags & IEEE80211_RATE_SHORT_PREAMBLE) && | 596 | (sband->bitrates[tx->rate_idx].flags & IEEE80211_RATE_SHORT_PREAMBLE) && |
600 | tx->sdata->bss_conf.use_short_preamble && | 597 | tx->sdata->bss_conf.use_short_preamble && |
601 | (!tx->sta || test_sta_flags(tx->sta, WLAN_STA_SHORT_PREAMBLE))) { | 598 | (!tx->sta || test_sta_flags(tx->sta, WLAN_STA_SHORT_PREAMBLE))) { |
@@ -647,7 +644,7 @@ ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) | |||
647 | static ieee80211_tx_result | 644 | static ieee80211_tx_result |
648 | ieee80211_tx_h_fragment(struct ieee80211_tx_data *tx) | 645 | ieee80211_tx_h_fragment(struct ieee80211_tx_data *tx) |
649 | { | 646 | { |
650 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) tx->skb->data; | 647 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; |
651 | size_t hdrlen, per_fragm, num_fragm, payload_len, left; | 648 | size_t hdrlen, per_fragm, num_fragm, payload_len, left; |
652 | struct sk_buff **frags, *first, *frag; | 649 | struct sk_buff **frags, *first, *frag; |
653 | int i; | 650 | int i; |
@@ -670,7 +667,7 @@ ieee80211_tx_h_fragment(struct ieee80211_tx_data *tx) | |||
670 | 667 | ||
671 | first = tx->skb; | 668 | first = tx->skb; |
672 | 669 | ||
673 | hdrlen = ieee80211_get_hdrlen(tx->fc); | 670 | hdrlen = ieee80211_hdrlen(hdr->frame_control); |
674 | payload_len = first->len - hdrlen; | 671 | payload_len = first->len - hdrlen; |
675 | per_fragm = frag_threshold - hdrlen - FCS_LEN; | 672 | per_fragm = frag_threshold - hdrlen - FCS_LEN; |
676 | num_fragm = DIV_ROUND_UP(payload_len, per_fragm); | 673 | num_fragm = DIV_ROUND_UP(payload_len, per_fragm); |
@@ -1395,7 +1392,8 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1395 | struct ieee80211_tx_info *info; | 1392 | struct ieee80211_tx_info *info; |
1396 | struct ieee80211_sub_if_data *sdata; | 1393 | struct ieee80211_sub_if_data *sdata; |
1397 | int ret = 1, head_need; | 1394 | int ret = 1, head_need; |
1398 | u16 ethertype, hdrlen, meshhdrlen = 0, fc; | 1395 | u16 ethertype, hdrlen, meshhdrlen = 0; |
1396 | __le16 fc; | ||
1399 | struct ieee80211_hdr hdr; | 1397 | struct ieee80211_hdr hdr; |
1400 | struct ieee80211s_hdr mesh_hdr; | 1398 | struct ieee80211s_hdr mesh_hdr; |
1401 | const u8 *encaps_data; | 1399 | const u8 *encaps_data; |
@@ -1418,12 +1416,12 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1418 | /* convert Ethernet header to proper 802.11 header (based on | 1416 | /* convert Ethernet header to proper 802.11 header (based on |
1419 | * operation mode) */ | 1417 | * operation mode) */ |
1420 | ethertype = (skb->data[12] << 8) | skb->data[13]; | 1418 | ethertype = (skb->data[12] << 8) | skb->data[13]; |
1421 | fc = IEEE80211_FTYPE_DATA | IEEE80211_STYPE_DATA; | 1419 | fc = cpu_to_le16(IEEE80211_FTYPE_DATA | IEEE80211_STYPE_DATA); |
1422 | 1420 | ||
1423 | switch (sdata->vif.type) { | 1421 | switch (sdata->vif.type) { |
1424 | case IEEE80211_IF_TYPE_AP: | 1422 | case IEEE80211_IF_TYPE_AP: |
1425 | case IEEE80211_IF_TYPE_VLAN: | 1423 | case IEEE80211_IF_TYPE_VLAN: |
1426 | fc |= IEEE80211_FCTL_FROMDS; | 1424 | fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS); |
1427 | /* DA BSSID SA */ | 1425 | /* DA BSSID SA */ |
1428 | memcpy(hdr.addr1, skb->data, ETH_ALEN); | 1426 | memcpy(hdr.addr1, skb->data, ETH_ALEN); |
1429 | memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); | 1427 | memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); |
@@ -1431,7 +1429,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1431 | hdrlen = 24; | 1429 | hdrlen = 24; |
1432 | break; | 1430 | break; |
1433 | case IEEE80211_IF_TYPE_WDS: | 1431 | case IEEE80211_IF_TYPE_WDS: |
1434 | fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; | 1432 | fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS); |
1435 | /* RA TA DA SA */ | 1433 | /* RA TA DA SA */ |
1436 | memcpy(hdr.addr1, sdata->u.wds.remote_addr, ETH_ALEN); | 1434 | memcpy(hdr.addr1, sdata->u.wds.remote_addr, ETH_ALEN); |
1437 | memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); | 1435 | memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); |
@@ -1441,7 +1439,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1441 | break; | 1439 | break; |
1442 | #ifdef CONFIG_MAC80211_MESH | 1440 | #ifdef CONFIG_MAC80211_MESH |
1443 | case IEEE80211_IF_TYPE_MESH_POINT: | 1441 | case IEEE80211_IF_TYPE_MESH_POINT: |
1444 | fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; | 1442 | fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS); |
1445 | /* RA TA DA SA */ | 1443 | /* RA TA DA SA */ |
1446 | if (is_multicast_ether_addr(skb->data)) | 1444 | if (is_multicast_ether_addr(skb->data)) |
1447 | memcpy(hdr.addr1, skb->data, ETH_ALEN); | 1445 | memcpy(hdr.addr1, skb->data, ETH_ALEN); |
@@ -1471,7 +1469,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1471 | break; | 1469 | break; |
1472 | #endif | 1470 | #endif |
1473 | case IEEE80211_IF_TYPE_STA: | 1471 | case IEEE80211_IF_TYPE_STA: |
1474 | fc |= IEEE80211_FCTL_TODS; | 1472 | fc |= cpu_to_le16(IEEE80211_FCTL_TODS); |
1475 | /* BSSID SA DA */ | 1473 | /* BSSID SA DA */ |
1476 | memcpy(hdr.addr1, sdata->u.sta.bssid, ETH_ALEN); | 1474 | memcpy(hdr.addr1, sdata->u.sta.bssid, ETH_ALEN); |
1477 | memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); | 1475 | memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); |
@@ -1506,7 +1504,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1506 | /* receiver and we are QoS enabled, use a QoS type frame */ | 1504 | /* receiver and we are QoS enabled, use a QoS type frame */ |
1507 | if (sta_flags & WLAN_STA_WME && | 1505 | if (sta_flags & WLAN_STA_WME && |
1508 | ieee80211_num_regular_queues(&local->hw) >= 4) { | 1506 | ieee80211_num_regular_queues(&local->hw) >= 4) { |
1509 | fc |= IEEE80211_STYPE_QOS_DATA; | 1507 | fc |= cpu_to_le16(IEEE80211_STYPE_QOS_DATA); |
1510 | hdrlen += 2; | 1508 | hdrlen += 2; |
1511 | } | 1509 | } |
1512 | 1510 | ||
@@ -1534,7 +1532,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1534 | goto fail; | 1532 | goto fail; |
1535 | } | 1533 | } |
1536 | 1534 | ||
1537 | hdr.frame_control = cpu_to_le16(fc); | 1535 | hdr.frame_control = fc; |
1538 | hdr.duration_id = 0; | 1536 | hdr.duration_id = 0; |
1539 | hdr.seq_ctrl = 0; | 1537 | hdr.seq_ctrl = 0; |
1540 | 1538 | ||
@@ -1603,7 +1601,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, | |||
1603 | h_pos += meshhdrlen; | 1601 | h_pos += meshhdrlen; |
1604 | } | 1602 | } |
1605 | 1603 | ||
1606 | if (fc & IEEE80211_STYPE_QOS_DATA) { | 1604 | if (ieee80211_is_data_qos(fc)) { |
1607 | __le16 *qos_control; | 1605 | __le16 *qos_control; |
1608 | 1606 | ||
1609 | qos_control = (__le16*) skb_push(skb, 2); | 1607 | qos_control = (__le16*) skb_push(skb, 2); |
@@ -1861,8 +1859,8 @@ struct sk_buff *ieee80211_beacon_get(struct ieee80211_hw *hw, | |||
1861 | mgmt = (struct ieee80211_mgmt *) | 1859 | mgmt = (struct ieee80211_mgmt *) |
1862 | skb_put(skb, 24 + sizeof(mgmt->u.beacon)); | 1860 | skb_put(skb, 24 + sizeof(mgmt->u.beacon)); |
1863 | memset(mgmt, 0, 24 + sizeof(mgmt->u.beacon)); | 1861 | memset(mgmt, 0, 24 + sizeof(mgmt->u.beacon)); |
1864 | mgmt->frame_control = IEEE80211_FC(IEEE80211_FTYPE_MGMT, | 1862 | mgmt->frame_control = |
1865 | IEEE80211_STYPE_BEACON); | 1863 | cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_BEACON); |
1866 | memset(mgmt->da, 0xff, ETH_ALEN); | 1864 | memset(mgmt->da, 0xff, ETH_ALEN); |
1867 | memcpy(mgmt->sa, sdata->dev->dev_addr, ETH_ALEN); | 1865 | memcpy(mgmt->sa, sdata->dev->dev_addr, ETH_ALEN); |
1868 | /* BSSID is left zeroed, wildcard value */ | 1866 | /* BSSID is left zeroed, wildcard value */ |
@@ -1930,10 +1928,9 @@ void ieee80211_rts_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, | |||
1930 | struct ieee80211_rts *rts) | 1928 | struct ieee80211_rts *rts) |
1931 | { | 1929 | { |
1932 | const struct ieee80211_hdr *hdr = frame; | 1930 | const struct ieee80211_hdr *hdr = frame; |
1933 | u16 fctl; | ||
1934 | 1931 | ||
1935 | fctl = IEEE80211_FTYPE_CTL | IEEE80211_STYPE_RTS; | 1932 | rts->frame_control = |
1936 | rts->frame_control = cpu_to_le16(fctl); | 1933 | cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_RTS); |
1937 | rts->duration = ieee80211_rts_duration(hw, vif, frame_len, | 1934 | rts->duration = ieee80211_rts_duration(hw, vif, frame_len, |
1938 | frame_txctl); | 1935 | frame_txctl); |
1939 | memcpy(rts->ra, hdr->addr1, sizeof(rts->ra)); | 1936 | memcpy(rts->ra, hdr->addr1, sizeof(rts->ra)); |
@@ -1947,10 +1944,9 @@ void ieee80211_ctstoself_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, | |||
1947 | struct ieee80211_cts *cts) | 1944 | struct ieee80211_cts *cts) |
1948 | { | 1945 | { |
1949 | const struct ieee80211_hdr *hdr = frame; | 1946 | const struct ieee80211_hdr *hdr = frame; |
1950 | u16 fctl; | ||
1951 | 1947 | ||
1952 | fctl = IEEE80211_FTYPE_CTL | IEEE80211_STYPE_CTS; | 1948 | cts->frame_control = |
1953 | cts->frame_control = cpu_to_le16(fctl); | 1949 | cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_CTS); |
1954 | cts->duration = ieee80211_ctstoself_duration(hw, vif, | 1950 | cts->duration = ieee80211_ctstoself_duration(hw, vif, |
1955 | frame_len, frame_txctl); | 1951 | frame_len, frame_txctl); |
1956 | memcpy(cts->ra, hdr->addr1, sizeof(cts->ra)); | 1952 | memcpy(cts->ra, hdr->addr1, sizeof(cts->ra)); |