Loading net/mac80211/tx.c +25 −29 Original line number Original line Diff line number Diff line Loading @@ -53,8 +53,7 @@ static void ieee80211_dump_frame(const char *ifname, const char *title, const struct sk_buff *skb) const struct sk_buff *skb) { { const struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; const struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; u16 fc; unsigned int hdrlen; int hdrlen; DECLARE_MAC_BUF(mac); DECLARE_MAC_BUF(mac); printk(KERN_DEBUG "%s: %s (len=%d)", ifname, title, skb->len); printk(KERN_DEBUG "%s: %s (len=%d)", ifname, title, skb->len); Loading @@ -63,13 +62,12 @@ static void ieee80211_dump_frame(const char *ifname, const char *title, return; return; } } fc = le16_to_cpu(hdr->frame_control); hdrlen = ieee80211_hdrlen(hdr->frame_control); hdrlen = ieee80211_get_hdrlen(fc); if (hdrlen > skb->len) if (hdrlen > skb->len) hdrlen = skb->len; hdrlen = skb->len; if (hdrlen >= 4) if (hdrlen >= 4) printk(" FC=0x%04x DUR=0x%04x", printk(" FC=0x%04x DUR=0x%04x", fc, le16_to_cpu(hdr->duration_id)); le16_to_cpu(hdr->frame_control), le16_to_cpu(hdr->duration_id)); if (hdrlen >= 10) if (hdrlen >= 10) printk(" A1=%s", print_mac(mac, hdr->addr1)); printk(" A1=%s", print_mac(mac, hdr->addr1)); if (hdrlen >= 16) if (hdrlen >= 16) Loading Loading @@ -281,7 +279,7 @@ ieee80211_tx_h_sequence(struct ieee80211_tx_data *tx) { { struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; if (ieee80211_get_hdrlen(le16_to_cpu(hdr->frame_control)) >= 24) if (ieee80211_hdrlen(hdr->frame_control) >= 24) ieee80211_include_sequence(tx->sdata, hdr); ieee80211_include_sequence(tx->sdata, hdr); return TX_CONTINUE; return TX_CONTINUE; Loading Loading @@ -543,7 +541,6 @@ static ieee80211_tx_result ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) { { struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; u16 fc = le16_to_cpu(hdr->frame_control); u16 dur; u16 dur; struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb); struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb); struct ieee80211_supported_band *sband; struct ieee80211_supported_band *sband; Loading Loading @@ -595,7 +592,7 @@ ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) /* Transmit data frames using short preambles if the driver supports /* Transmit data frames using short preambles if the driver supports * short preambles at the selected rate and short preambles are * short preambles at the selected rate and short preambles are * available on the network at the current point in time. */ * available on the network at the current point in time. */ if (((fc & IEEE80211_FCTL_FTYPE) == IEEE80211_FTYPE_DATA) && if (ieee80211_is_data(hdr->frame_control) && (sband->bitrates[tx->rate_idx].flags & IEEE80211_RATE_SHORT_PREAMBLE) && (sband->bitrates[tx->rate_idx].flags & IEEE80211_RATE_SHORT_PREAMBLE) && tx->sdata->bss_conf.use_short_preamble && tx->sdata->bss_conf.use_short_preamble && (!tx->sta || test_sta_flags(tx->sta, WLAN_STA_SHORT_PREAMBLE))) { (!tx->sta || test_sta_flags(tx->sta, WLAN_STA_SHORT_PREAMBLE))) { Loading Loading @@ -670,7 +667,7 @@ ieee80211_tx_h_fragment(struct ieee80211_tx_data *tx) first = tx->skb; first = tx->skb; hdrlen = ieee80211_get_hdrlen(tx->fc); hdrlen = ieee80211_hdrlen(hdr->frame_control); payload_len = first->len - hdrlen; payload_len = first->len - hdrlen; per_fragm = frag_threshold - hdrlen - FCS_LEN; per_fragm = frag_threshold - hdrlen - FCS_LEN; num_fragm = DIV_ROUND_UP(payload_len, per_fragm); num_fragm = DIV_ROUND_UP(payload_len, per_fragm); Loading Loading @@ -1395,7 +1392,8 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, struct ieee80211_tx_info *info; struct ieee80211_tx_info *info; struct ieee80211_sub_if_data *sdata; struct ieee80211_sub_if_data *sdata; int ret = 1, head_need; int ret = 1, head_need; u16 ethertype, hdrlen, meshhdrlen = 0, fc; u16 ethertype, hdrlen, meshhdrlen = 0; __le16 fc; struct ieee80211_hdr hdr; struct ieee80211_hdr hdr; struct ieee80211s_hdr mesh_hdr; struct ieee80211s_hdr mesh_hdr; const u8 *encaps_data; const u8 *encaps_data; Loading @@ -1418,12 +1416,12 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, /* convert Ethernet header to proper 802.11 header (based on /* convert Ethernet header to proper 802.11 header (based on * operation mode) */ * operation mode) */ ethertype = (skb->data[12] << 8) | skb->data[13]; ethertype = (skb->data[12] << 8) | skb->data[13]; fc = IEEE80211_FTYPE_DATA | IEEE80211_STYPE_DATA; fc = cpu_to_le16(IEEE80211_FTYPE_DATA | IEEE80211_STYPE_DATA); switch (sdata->vif.type) { switch (sdata->vif.type) { case IEEE80211_IF_TYPE_AP: case IEEE80211_IF_TYPE_AP: case IEEE80211_IF_TYPE_VLAN: case IEEE80211_IF_TYPE_VLAN: fc |= IEEE80211_FCTL_FROMDS; fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS); /* DA BSSID SA */ /* DA BSSID SA */ memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); Loading @@ -1431,7 +1429,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, hdrlen = 24; hdrlen = 24; break; break; case IEEE80211_IF_TYPE_WDS: case IEEE80211_IF_TYPE_WDS: fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS); /* RA TA DA SA */ /* RA TA DA SA */ memcpy(hdr.addr1, sdata->u.wds.remote_addr, ETH_ALEN); memcpy(hdr.addr1, sdata->u.wds.remote_addr, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); Loading @@ -1441,7 +1439,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, break; break; #ifdef CONFIG_MAC80211_MESH #ifdef CONFIG_MAC80211_MESH case IEEE80211_IF_TYPE_MESH_POINT: case IEEE80211_IF_TYPE_MESH_POINT: fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS); /* RA TA DA SA */ /* RA TA DA SA */ if (is_multicast_ether_addr(skb->data)) if (is_multicast_ether_addr(skb->data)) memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr1, skb->data, ETH_ALEN); Loading Loading @@ -1471,7 +1469,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, break; break; #endif #endif case IEEE80211_IF_TYPE_STA: case IEEE80211_IF_TYPE_STA: fc |= IEEE80211_FCTL_TODS; fc |= cpu_to_le16(IEEE80211_FCTL_TODS); /* BSSID SA DA */ /* BSSID SA DA */ memcpy(hdr.addr1, sdata->u.sta.bssid, ETH_ALEN); memcpy(hdr.addr1, sdata->u.sta.bssid, ETH_ALEN); memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); Loading Loading @@ -1506,7 +1504,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, /* receiver and we are QoS enabled, use a QoS type frame */ /* receiver and we are QoS enabled, use a QoS type frame */ if (sta_flags & WLAN_STA_WME && if (sta_flags & WLAN_STA_WME && ieee80211_num_regular_queues(&local->hw) >= 4) { ieee80211_num_regular_queues(&local->hw) >= 4) { fc |= IEEE80211_STYPE_QOS_DATA; fc |= cpu_to_le16(IEEE80211_STYPE_QOS_DATA); hdrlen += 2; hdrlen += 2; } } Loading Loading @@ -1534,7 +1532,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, goto fail; goto fail; } } hdr.frame_control = cpu_to_le16(fc); hdr.frame_control = fc; hdr.duration_id = 0; hdr.duration_id = 0; hdr.seq_ctrl = 0; hdr.seq_ctrl = 0; Loading Loading @@ -1603,7 +1601,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, h_pos += meshhdrlen; h_pos += meshhdrlen; } } if (fc & IEEE80211_STYPE_QOS_DATA) { if (ieee80211_is_data_qos(fc)) { __le16 *qos_control; __le16 *qos_control; qos_control = (__le16*) skb_push(skb, 2); qos_control = (__le16*) skb_push(skb, 2); Loading Loading @@ -1861,8 +1859,8 @@ struct sk_buff *ieee80211_beacon_get(struct ieee80211_hw *hw, mgmt = (struct ieee80211_mgmt *) mgmt = (struct ieee80211_mgmt *) skb_put(skb, 24 + sizeof(mgmt->u.beacon)); skb_put(skb, 24 + sizeof(mgmt->u.beacon)); memset(mgmt, 0, 24 + sizeof(mgmt->u.beacon)); memset(mgmt, 0, 24 + sizeof(mgmt->u.beacon)); mgmt->frame_control = IEEE80211_FC(IEEE80211_FTYPE_MGMT, mgmt->frame_control = IEEE80211_STYPE_BEACON); cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_BEACON); memset(mgmt->da, 0xff, ETH_ALEN); memset(mgmt->da, 0xff, ETH_ALEN); memcpy(mgmt->sa, sdata->dev->dev_addr, ETH_ALEN); memcpy(mgmt->sa, sdata->dev->dev_addr, ETH_ALEN); /* BSSID is left zeroed, wildcard value */ /* BSSID is left zeroed, wildcard value */ Loading Loading @@ -1930,10 +1928,9 @@ void ieee80211_rts_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, struct ieee80211_rts *rts) struct ieee80211_rts *rts) { { const struct ieee80211_hdr *hdr = frame; const struct ieee80211_hdr *hdr = frame; u16 fctl; fctl = IEEE80211_FTYPE_CTL | IEEE80211_STYPE_RTS; rts->frame_control = rts->frame_control = cpu_to_le16(fctl); cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_RTS); rts->duration = ieee80211_rts_duration(hw, vif, frame_len, rts->duration = ieee80211_rts_duration(hw, vif, frame_len, frame_txctl); frame_txctl); memcpy(rts->ra, hdr->addr1, sizeof(rts->ra)); memcpy(rts->ra, hdr->addr1, sizeof(rts->ra)); Loading @@ -1947,10 +1944,9 @@ void ieee80211_ctstoself_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, struct ieee80211_cts *cts) struct ieee80211_cts *cts) { { const struct ieee80211_hdr *hdr = frame; const struct ieee80211_hdr *hdr = frame; u16 fctl; fctl = IEEE80211_FTYPE_CTL | IEEE80211_STYPE_CTS; cts->frame_control = cts->frame_control = cpu_to_le16(fctl); cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_CTS); cts->duration = ieee80211_ctstoself_duration(hw, vif, cts->duration = ieee80211_ctstoself_duration(hw, vif, frame_len, frame_txctl); frame_len, frame_txctl); memcpy(cts->ra, hdr->addr1, sizeof(cts->ra)); memcpy(cts->ra, hdr->addr1, sizeof(cts->ra)); Loading Loading
net/mac80211/tx.c +25 −29 Original line number Original line Diff line number Diff line Loading @@ -53,8 +53,7 @@ static void ieee80211_dump_frame(const char *ifname, const char *title, const struct sk_buff *skb) const struct sk_buff *skb) { { const struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; const struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; u16 fc; unsigned int hdrlen; int hdrlen; DECLARE_MAC_BUF(mac); DECLARE_MAC_BUF(mac); printk(KERN_DEBUG "%s: %s (len=%d)", ifname, title, skb->len); printk(KERN_DEBUG "%s: %s (len=%d)", ifname, title, skb->len); Loading @@ -63,13 +62,12 @@ static void ieee80211_dump_frame(const char *ifname, const char *title, return; return; } } fc = le16_to_cpu(hdr->frame_control); hdrlen = ieee80211_hdrlen(hdr->frame_control); hdrlen = ieee80211_get_hdrlen(fc); if (hdrlen > skb->len) if (hdrlen > skb->len) hdrlen = skb->len; hdrlen = skb->len; if (hdrlen >= 4) if (hdrlen >= 4) printk(" FC=0x%04x DUR=0x%04x", printk(" FC=0x%04x DUR=0x%04x", fc, le16_to_cpu(hdr->duration_id)); le16_to_cpu(hdr->frame_control), le16_to_cpu(hdr->duration_id)); if (hdrlen >= 10) if (hdrlen >= 10) printk(" A1=%s", print_mac(mac, hdr->addr1)); printk(" A1=%s", print_mac(mac, hdr->addr1)); if (hdrlen >= 16) if (hdrlen >= 16) Loading Loading @@ -281,7 +279,7 @@ ieee80211_tx_h_sequence(struct ieee80211_tx_data *tx) { { struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; if (ieee80211_get_hdrlen(le16_to_cpu(hdr->frame_control)) >= 24) if (ieee80211_hdrlen(hdr->frame_control) >= 24) ieee80211_include_sequence(tx->sdata, hdr); ieee80211_include_sequence(tx->sdata, hdr); return TX_CONTINUE; return TX_CONTINUE; Loading Loading @@ -543,7 +541,6 @@ static ieee80211_tx_result ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) { { struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)tx->skb->data; u16 fc = le16_to_cpu(hdr->frame_control); u16 dur; u16 dur; struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb); struct ieee80211_tx_info *info = IEEE80211_SKB_CB(tx->skb); struct ieee80211_supported_band *sband; struct ieee80211_supported_band *sband; Loading Loading @@ -595,7 +592,7 @@ ieee80211_tx_h_misc(struct ieee80211_tx_data *tx) /* Transmit data frames using short preambles if the driver supports /* Transmit data frames using short preambles if the driver supports * short preambles at the selected rate and short preambles are * short preambles at the selected rate and short preambles are * available on the network at the current point in time. */ * available on the network at the current point in time. */ if (((fc & IEEE80211_FCTL_FTYPE) == IEEE80211_FTYPE_DATA) && if (ieee80211_is_data(hdr->frame_control) && (sband->bitrates[tx->rate_idx].flags & IEEE80211_RATE_SHORT_PREAMBLE) && (sband->bitrates[tx->rate_idx].flags & IEEE80211_RATE_SHORT_PREAMBLE) && tx->sdata->bss_conf.use_short_preamble && tx->sdata->bss_conf.use_short_preamble && (!tx->sta || test_sta_flags(tx->sta, WLAN_STA_SHORT_PREAMBLE))) { (!tx->sta || test_sta_flags(tx->sta, WLAN_STA_SHORT_PREAMBLE))) { Loading Loading @@ -670,7 +667,7 @@ ieee80211_tx_h_fragment(struct ieee80211_tx_data *tx) first = tx->skb; first = tx->skb; hdrlen = ieee80211_get_hdrlen(tx->fc); hdrlen = ieee80211_hdrlen(hdr->frame_control); payload_len = first->len - hdrlen; payload_len = first->len - hdrlen; per_fragm = frag_threshold - hdrlen - FCS_LEN; per_fragm = frag_threshold - hdrlen - FCS_LEN; num_fragm = DIV_ROUND_UP(payload_len, per_fragm); num_fragm = DIV_ROUND_UP(payload_len, per_fragm); Loading Loading @@ -1395,7 +1392,8 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, struct ieee80211_tx_info *info; struct ieee80211_tx_info *info; struct ieee80211_sub_if_data *sdata; struct ieee80211_sub_if_data *sdata; int ret = 1, head_need; int ret = 1, head_need; u16 ethertype, hdrlen, meshhdrlen = 0, fc; u16 ethertype, hdrlen, meshhdrlen = 0; __le16 fc; struct ieee80211_hdr hdr; struct ieee80211_hdr hdr; struct ieee80211s_hdr mesh_hdr; struct ieee80211s_hdr mesh_hdr; const u8 *encaps_data; const u8 *encaps_data; Loading @@ -1418,12 +1416,12 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, /* convert Ethernet header to proper 802.11 header (based on /* convert Ethernet header to proper 802.11 header (based on * operation mode) */ * operation mode) */ ethertype = (skb->data[12] << 8) | skb->data[13]; ethertype = (skb->data[12] << 8) | skb->data[13]; fc = IEEE80211_FTYPE_DATA | IEEE80211_STYPE_DATA; fc = cpu_to_le16(IEEE80211_FTYPE_DATA | IEEE80211_STYPE_DATA); switch (sdata->vif.type) { switch (sdata->vif.type) { case IEEE80211_IF_TYPE_AP: case IEEE80211_IF_TYPE_AP: case IEEE80211_IF_TYPE_VLAN: case IEEE80211_IF_TYPE_VLAN: fc |= IEEE80211_FCTL_FROMDS; fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS); /* DA BSSID SA */ /* DA BSSID SA */ memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); Loading @@ -1431,7 +1429,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, hdrlen = 24; hdrlen = 24; break; break; case IEEE80211_IF_TYPE_WDS: case IEEE80211_IF_TYPE_WDS: fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS); /* RA TA DA SA */ /* RA TA DA SA */ memcpy(hdr.addr1, sdata->u.wds.remote_addr, ETH_ALEN); memcpy(hdr.addr1, sdata->u.wds.remote_addr, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); memcpy(hdr.addr2, dev->dev_addr, ETH_ALEN); Loading @@ -1441,7 +1439,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, break; break; #ifdef CONFIG_MAC80211_MESH #ifdef CONFIG_MAC80211_MESH case IEEE80211_IF_TYPE_MESH_POINT: case IEEE80211_IF_TYPE_MESH_POINT: fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; fc |= cpu_to_le16(IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS); /* RA TA DA SA */ /* RA TA DA SA */ if (is_multicast_ether_addr(skb->data)) if (is_multicast_ether_addr(skb->data)) memcpy(hdr.addr1, skb->data, ETH_ALEN); memcpy(hdr.addr1, skb->data, ETH_ALEN); Loading Loading @@ -1471,7 +1469,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, break; break; #endif #endif case IEEE80211_IF_TYPE_STA: case IEEE80211_IF_TYPE_STA: fc |= IEEE80211_FCTL_TODS; fc |= cpu_to_le16(IEEE80211_FCTL_TODS); /* BSSID SA DA */ /* BSSID SA DA */ memcpy(hdr.addr1, sdata->u.sta.bssid, ETH_ALEN); memcpy(hdr.addr1, sdata->u.sta.bssid, ETH_ALEN); memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); memcpy(hdr.addr2, skb->data + ETH_ALEN, ETH_ALEN); Loading Loading @@ -1506,7 +1504,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, /* receiver and we are QoS enabled, use a QoS type frame */ /* receiver and we are QoS enabled, use a QoS type frame */ if (sta_flags & WLAN_STA_WME && if (sta_flags & WLAN_STA_WME && ieee80211_num_regular_queues(&local->hw) >= 4) { ieee80211_num_regular_queues(&local->hw) >= 4) { fc |= IEEE80211_STYPE_QOS_DATA; fc |= cpu_to_le16(IEEE80211_STYPE_QOS_DATA); hdrlen += 2; hdrlen += 2; } } Loading Loading @@ -1534,7 +1532,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, goto fail; goto fail; } } hdr.frame_control = cpu_to_le16(fc); hdr.frame_control = fc; hdr.duration_id = 0; hdr.duration_id = 0; hdr.seq_ctrl = 0; hdr.seq_ctrl = 0; Loading Loading @@ -1603,7 +1601,7 @@ int ieee80211_subif_start_xmit(struct sk_buff *skb, h_pos += meshhdrlen; h_pos += meshhdrlen; } } if (fc & IEEE80211_STYPE_QOS_DATA) { if (ieee80211_is_data_qos(fc)) { __le16 *qos_control; __le16 *qos_control; qos_control = (__le16*) skb_push(skb, 2); qos_control = (__le16*) skb_push(skb, 2); Loading Loading @@ -1861,8 +1859,8 @@ struct sk_buff *ieee80211_beacon_get(struct ieee80211_hw *hw, mgmt = (struct ieee80211_mgmt *) mgmt = (struct ieee80211_mgmt *) skb_put(skb, 24 + sizeof(mgmt->u.beacon)); skb_put(skb, 24 + sizeof(mgmt->u.beacon)); memset(mgmt, 0, 24 + sizeof(mgmt->u.beacon)); memset(mgmt, 0, 24 + sizeof(mgmt->u.beacon)); mgmt->frame_control = IEEE80211_FC(IEEE80211_FTYPE_MGMT, mgmt->frame_control = IEEE80211_STYPE_BEACON); cpu_to_le16(IEEE80211_FTYPE_MGMT | IEEE80211_STYPE_BEACON); memset(mgmt->da, 0xff, ETH_ALEN); memset(mgmt->da, 0xff, ETH_ALEN); memcpy(mgmt->sa, sdata->dev->dev_addr, ETH_ALEN); memcpy(mgmt->sa, sdata->dev->dev_addr, ETH_ALEN); /* BSSID is left zeroed, wildcard value */ /* BSSID is left zeroed, wildcard value */ Loading Loading @@ -1930,10 +1928,9 @@ void ieee80211_rts_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, struct ieee80211_rts *rts) struct ieee80211_rts *rts) { { const struct ieee80211_hdr *hdr = frame; const struct ieee80211_hdr *hdr = frame; u16 fctl; fctl = IEEE80211_FTYPE_CTL | IEEE80211_STYPE_RTS; rts->frame_control = rts->frame_control = cpu_to_le16(fctl); cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_RTS); rts->duration = ieee80211_rts_duration(hw, vif, frame_len, rts->duration = ieee80211_rts_duration(hw, vif, frame_len, frame_txctl); frame_txctl); memcpy(rts->ra, hdr->addr1, sizeof(rts->ra)); memcpy(rts->ra, hdr->addr1, sizeof(rts->ra)); Loading @@ -1947,10 +1944,9 @@ void ieee80211_ctstoself_get(struct ieee80211_hw *hw, struct ieee80211_vif *vif, struct ieee80211_cts *cts) struct ieee80211_cts *cts) { { const struct ieee80211_hdr *hdr = frame; const struct ieee80211_hdr *hdr = frame; u16 fctl; fctl = IEEE80211_FTYPE_CTL | IEEE80211_STYPE_CTS; cts->frame_control = cts->frame_control = cpu_to_le16(fctl); cpu_to_le16(IEEE80211_FTYPE_CTL | IEEE80211_STYPE_CTS); cts->duration = ieee80211_ctstoself_duration(hw, vif, cts->duration = ieee80211_ctstoself_duration(hw, vif, frame_len, frame_txctl); frame_len, frame_txctl); memcpy(cts->ra, hdr->addr1, sizeof(cts->ra)); memcpy(cts->ra, hdr->addr1, sizeof(cts->ra)); Loading