diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/wireless/hostap/hostap.c | 10 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_80211_rx.c | 61 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_80211_tx.c | 20 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_ap.c | 24 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_common.h | 10 | ||||
-rw-r--r-- | drivers/net/wireless/hostap/hostap_hw.c | 7 |
6 files changed, 65 insertions, 67 deletions
diff --git a/drivers/net/wireless/hostap/hostap.c b/drivers/net/wireless/hostap/hostap.c index 9ce18b6d6cb8..e7f5821b4942 100644 --- a/drivers/net/wireless/hostap/hostap.c +++ b/drivers/net/wireless/hostap/hostap.c | |||
@@ -597,8 +597,8 @@ void hostap_dump_rx_header(const char *name, const struct hfa384x_rx_frame *rx) | |||
597 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, | 597 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, |
598 | __le16_to_cpu(rx->duration_id), __le16_to_cpu(rx->seq_ctrl), | 598 | __le16_to_cpu(rx->duration_id), __le16_to_cpu(rx->seq_ctrl), |
599 | __le16_to_cpu(rx->data_len), | 599 | __le16_to_cpu(rx->data_len), |
600 | fc & WLAN_FC_TODS ? " [ToDS]" : "", | 600 | fc & IEEE80211_FCTL_TODS ? " [ToDS]" : "", |
601 | fc & WLAN_FC_FROMDS ? " [FromDS]" : ""); | 601 | fc & IEEE80211_FCTL_FROMDS ? " [FromDS]" : ""); |
602 | 602 | ||
603 | printk(KERN_DEBUG " A1=" MACSTR " A2=" MACSTR " A3=" MACSTR " A4=" | 603 | printk(KERN_DEBUG " A1=" MACSTR " A2=" MACSTR " A3=" MACSTR " A4=" |
604 | MACSTR "\n", | 604 | MACSTR "\n", |
@@ -626,8 +626,8 @@ void hostap_dump_tx_header(const char *name, const struct hfa384x_tx_frame *tx) | |||
626 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, | 626 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, |
627 | __le16_to_cpu(tx->duration_id), __le16_to_cpu(tx->seq_ctrl), | 627 | __le16_to_cpu(tx->duration_id), __le16_to_cpu(tx->seq_ctrl), |
628 | __le16_to_cpu(tx->data_len), | 628 | __le16_to_cpu(tx->data_len), |
629 | fc & WLAN_FC_TODS ? " [ToDS]" : "", | 629 | fc & IEEE80211_FCTL_TODS ? " [ToDS]" : "", |
630 | fc & WLAN_FC_FROMDS ? " [FromDS]" : ""); | 630 | fc & IEEE80211_FCTL_FROMDS ? " [FromDS]" : ""); |
631 | 631 | ||
632 | printk(KERN_DEBUG " A1=" MACSTR " A2=" MACSTR " A3=" MACSTR " A4=" | 632 | printk(KERN_DEBUG " A1=" MACSTR " A2=" MACSTR " A3=" MACSTR " A4=" |
633 | MACSTR "\n", | 633 | MACSTR "\n", |
@@ -668,7 +668,7 @@ int hostap_80211_get_hdrlen(u16 fc) | |||
668 | 668 | ||
669 | switch (WLAN_FC_GET_TYPE(fc)) { | 669 | switch (WLAN_FC_GET_TYPE(fc)) { |
670 | case IEEE80211_FTYPE_DATA: | 670 | case IEEE80211_FTYPE_DATA: |
671 | if ((fc & WLAN_FC_FROMDS) && (fc & WLAN_FC_TODS)) | 671 | if ((fc & IEEE80211_FCTL_FROMDS) && (fc & IEEE80211_FCTL_TODS)) |
672 | hdrlen = 30; /* Addr4 */ | 672 | hdrlen = 30; /* Addr4 */ |
673 | break; | 673 | break; |
674 | case IEEE80211_FTYPE_CTL: | 674 | case IEEE80211_FTYPE_CTL: |
diff --git a/drivers/net/wireless/hostap/hostap_80211_rx.c b/drivers/net/wireless/hostap/hostap_80211_rx.c index 3752a677abb6..051a59075ea8 100644 --- a/drivers/net/wireless/hostap/hostap_80211_rx.c +++ b/drivers/net/wireless/hostap/hostap_80211_rx.c | |||
@@ -22,8 +22,8 @@ void hostap_dump_rx_80211(const char *name, struct sk_buff *skb, | |||
22 | fc = le16_to_cpu(hdr->frame_ctl); | 22 | fc = le16_to_cpu(hdr->frame_ctl); |
23 | printk(KERN_DEBUG " FC=0x%04x (type=%d:%d)%s%s", | 23 | printk(KERN_DEBUG " FC=0x%04x (type=%d:%d)%s%s", |
24 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, | 24 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, |
25 | fc & WLAN_FC_TODS ? " [ToDS]" : "", | 25 | fc & IEEE80211_FCTL_TODS ? " [ToDS]" : "", |
26 | fc & WLAN_FC_FROMDS ? " [FromDS]" : ""); | 26 | fc & IEEE80211_FCTL_FROMDS ? " [FromDS]" : ""); |
27 | 27 | ||
28 | if (skb->len < IEEE80211_DATA_HDR3_LEN) { | 28 | if (skb->len < IEEE80211_DATA_HDR3_LEN) { |
29 | printk("\n"); | 29 | printk("\n"); |
@@ -73,9 +73,9 @@ int prism2_rx_80211(struct net_device *dev, struct sk_buff *skb, | |||
73 | hdr = (struct ieee80211_hdr *) skb->data; | 73 | hdr = (struct ieee80211_hdr *) skb->data; |
74 | fc = le16_to_cpu(hdr->frame_ctl); | 74 | fc = le16_to_cpu(hdr->frame_ctl); |
75 | 75 | ||
76 | if (type == PRISM2_RX_MGMT && (fc & WLAN_FC_PVER)) { | 76 | if (type == PRISM2_RX_MGMT && (fc & IEEE80211_FCTL_VERS)) { |
77 | printk(KERN_DEBUG "%s: dropped management frame with header " | 77 | printk(KERN_DEBUG "%s: dropped management frame with header " |
78 | "version %d\n", dev->name, fc & WLAN_FC_PVER); | 78 | "version %d\n", dev->name, fc & IEEE80211_FCTL_VERS); |
79 | dev_kfree_skb_any(skb); | 79 | dev_kfree_skb_any(skb); |
80 | return 0; | 80 | return 0; |
81 | } | 81 | } |
@@ -525,9 +525,9 @@ hostap_rx_frame_wds(local_info_t *local, struct ieee80211_hdr *hdr, | |||
525 | { | 525 | { |
526 | /* FIX: is this really supposed to accept WDS frames only in Master | 526 | /* FIX: is this really supposed to accept WDS frames only in Master |
527 | * mode? What about Repeater or Managed with WDS frames? */ | 527 | * mode? What about Repeater or Managed with WDS frames? */ |
528 | if ((fc & (WLAN_FC_TODS | WLAN_FC_FROMDS)) != | 528 | if ((fc & (IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS)) != |
529 | (WLAN_FC_TODS | WLAN_FC_FROMDS) && | 529 | (IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS) && |
530 | (local->iw_mode != IW_MODE_MASTER || !(fc & WLAN_FC_TODS))) | 530 | (local->iw_mode != IW_MODE_MASTER || !(fc & IEEE80211_FCTL_TODS))) |
531 | return 0; /* not a WDS frame */ | 531 | return 0; /* not a WDS frame */ |
532 | 532 | ||
533 | /* Possible WDS frame: either IEEE 802.11 compliant (if FromDS) | 533 | /* Possible WDS frame: either IEEE 802.11 compliant (if FromDS) |
@@ -539,14 +539,15 @@ hostap_rx_frame_wds(local_info_t *local, struct ieee80211_hdr *hdr, | |||
539 | /* RA (or BSSID) is not ours - drop */ | 539 | /* RA (or BSSID) is not ours - drop */ |
540 | PDEBUG(DEBUG_EXTRA, "%s: received WDS frame with " | 540 | PDEBUG(DEBUG_EXTRA, "%s: received WDS frame with " |
541 | "not own or broadcast %s=" MACSTR "\n", | 541 | "not own or broadcast %s=" MACSTR "\n", |
542 | local->dev->name, fc & WLAN_FC_FROMDS ? "RA" : "BSSID", | 542 | local->dev->name, |
543 | fc & IEEE80211_FCTL_FROMDS ? "RA" : "BSSID", | ||
543 | MAC2STR(hdr->addr1)); | 544 | MAC2STR(hdr->addr1)); |
544 | return -1; | 545 | return -1; |
545 | } | 546 | } |
546 | 547 | ||
547 | /* check if the frame came from a registered WDS connection */ | 548 | /* check if the frame came from a registered WDS connection */ |
548 | *wds = prism2_rx_get_wds(local, hdr->addr2); | 549 | *wds = prism2_rx_get_wds(local, hdr->addr2); |
549 | if (*wds == NULL && fc & WLAN_FC_FROMDS && | 550 | if (*wds == NULL && fc & IEEE80211_FCTL_FROMDS && |
550 | (local->iw_mode != IW_MODE_INFRA || | 551 | (local->iw_mode != IW_MODE_INFRA || |
551 | !(local->wds_type & HOSTAP_WDS_AP_CLIENT) || | 552 | !(local->wds_type & HOSTAP_WDS_AP_CLIENT) || |
552 | memcmp(hdr->addr2, local->bssid, ETH_ALEN) != 0)) { | 553 | memcmp(hdr->addr2, local->bssid, ETH_ALEN) != 0)) { |
@@ -560,7 +561,7 @@ hostap_rx_frame_wds(local_info_t *local, struct ieee80211_hdr *hdr, | |||
560 | return -1; | 561 | return -1; |
561 | } | 562 | } |
562 | 563 | ||
563 | if (*wds && !(fc & WLAN_FC_FROMDS) && local->ap && | 564 | if (*wds && !(fc & IEEE80211_FCTL_FROMDS) && local->ap && |
564 | hostap_is_sta_assoc(local->ap, hdr->addr2)) { | 565 | hostap_is_sta_assoc(local->ap, hdr->addr2)) { |
565 | /* STA is actually associated with us even though it has a | 566 | /* STA is actually associated with us even though it has a |
566 | * registered WDS link. Assume it is in 'AP client' mode. | 567 | * registered WDS link. Assume it is in 'AP client' mode. |
@@ -588,11 +589,13 @@ static int hostap_is_eapol_frame(local_info_t *local, struct sk_buff *skb) | |||
588 | fc = le16_to_cpu(hdr->frame_ctl); | 589 | fc = le16_to_cpu(hdr->frame_ctl); |
589 | 590 | ||
590 | /* check that the frame is unicast frame to us */ | 591 | /* check that the frame is unicast frame to us */ |
591 | if ((fc & (WLAN_FC_TODS | WLAN_FC_FROMDS)) == WLAN_FC_TODS && | 592 | if ((fc & (IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS)) == |
593 | IEEE80211_FCTL_TODS && | ||
592 | memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN) == 0 && | 594 | memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN) == 0 && |
593 | memcmp(hdr->addr3, dev->dev_addr, ETH_ALEN) == 0) { | 595 | memcmp(hdr->addr3, dev->dev_addr, ETH_ALEN) == 0) { |
594 | /* ToDS frame with own addr BSSID and DA */ | 596 | /* ToDS frame with own addr BSSID and DA */ |
595 | } else if ((fc & (WLAN_FC_TODS | WLAN_FC_FROMDS)) == WLAN_FC_FROMDS && | 597 | } else if ((fc & (IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS)) == |
598 | IEEE80211_FCTL_FROMDS && | ||
596 | memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN) == 0) { | 599 | memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN) == 0) { |
597 | /* FromDS frame with own addr as DA */ | 600 | /* FromDS frame with own addr as DA */ |
598 | } else | 601 | } else |
@@ -770,7 +773,7 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
770 | crypt->ops->decrypt_mpdu == NULL)) | 773 | crypt->ops->decrypt_mpdu == NULL)) |
771 | crypt = NULL; | 774 | crypt = NULL; |
772 | 775 | ||
773 | if (!crypt && (fc & WLAN_FC_ISWEP)) { | 776 | if (!crypt && (fc & IEEE80211_FCTL_WEP)) { |
774 | #if 0 | 777 | #if 0 |
775 | /* This seems to be triggered by some (multicast?) | 778 | /* This seems to be triggered by some (multicast?) |
776 | * frames from other than current BSS, so just drop the | 779 | * frames from other than current BSS, so just drop the |
@@ -788,7 +791,7 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
788 | if (type != IEEE80211_FTYPE_DATA) { | 791 | if (type != IEEE80211_FTYPE_DATA) { |
789 | if (type == IEEE80211_FTYPE_MGMT && | 792 | if (type == IEEE80211_FTYPE_MGMT && |
790 | stype == IEEE80211_STYPE_AUTH && | 793 | stype == IEEE80211_STYPE_AUTH && |
791 | fc & WLAN_FC_ISWEP && local->host_decrypt && | 794 | fc & IEEE80211_FCTL_WEP && local->host_decrypt && |
792 | (keyidx = hostap_rx_frame_decrypt(local, skb, crypt)) < 0) | 795 | (keyidx = hostap_rx_frame_decrypt(local, skb, crypt)) < 0) |
793 | { | 796 | { |
794 | printk(KERN_DEBUG "%s: failed to decrypt mgmt::auth " | 797 | printk(KERN_DEBUG "%s: failed to decrypt mgmt::auth " |
@@ -809,16 +812,16 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
809 | if (skb->len < IEEE80211_DATA_HDR3_LEN) | 812 | if (skb->len < IEEE80211_DATA_HDR3_LEN) |
810 | goto rx_dropped; | 813 | goto rx_dropped; |
811 | 814 | ||
812 | switch (fc & (WLAN_FC_FROMDS | WLAN_FC_TODS)) { | 815 | switch (fc & (IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS)) { |
813 | case WLAN_FC_FROMDS: | 816 | case IEEE80211_FCTL_FROMDS: |
814 | memcpy(dst, hdr->addr1, ETH_ALEN); | 817 | memcpy(dst, hdr->addr1, ETH_ALEN); |
815 | memcpy(src, hdr->addr3, ETH_ALEN); | 818 | memcpy(src, hdr->addr3, ETH_ALEN); |
816 | break; | 819 | break; |
817 | case WLAN_FC_TODS: | 820 | case IEEE80211_FCTL_TODS: |
818 | memcpy(dst, hdr->addr3, ETH_ALEN); | 821 | memcpy(dst, hdr->addr3, ETH_ALEN); |
819 | memcpy(src, hdr->addr2, ETH_ALEN); | 822 | memcpy(src, hdr->addr2, ETH_ALEN); |
820 | break; | 823 | break; |
821 | case WLAN_FC_FROMDS | WLAN_FC_TODS: | 824 | case IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS: |
822 | if (skb->len < IEEE80211_DATA_HDR4_LEN) | 825 | if (skb->len < IEEE80211_DATA_HDR4_LEN) |
823 | goto rx_dropped; | 826 | goto rx_dropped; |
824 | memcpy(dst, hdr->addr3, ETH_ALEN); | 827 | memcpy(dst, hdr->addr3, ETH_ALEN); |
@@ -838,7 +841,8 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
838 | } | 841 | } |
839 | 842 | ||
840 | if (local->iw_mode == IW_MODE_MASTER && !wds && | 843 | if (local->iw_mode == IW_MODE_MASTER && !wds && |
841 | (fc & (WLAN_FC_TODS | WLAN_FC_FROMDS)) == WLAN_FC_FROMDS && | 844 | (fc & (IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS)) == |
845 | IEEE80211_FCTL_FROMDS && | ||
842 | local->stadev && | 846 | local->stadev && |
843 | memcmp(hdr->addr2, local->assoc_ap_addr, ETH_ALEN) == 0) { | 847 | memcmp(hdr->addr2, local->assoc_ap_addr, ETH_ALEN) == 0) { |
844 | /* Frame from BSSID of the AP for which we are a client */ | 848 | /* Frame from BSSID of the AP for which we are a client */ |
@@ -882,22 +886,22 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
882 | 886 | ||
883 | /* skb: hdr + (possibly fragmented, possibly encrypted) payload */ | 887 | /* skb: hdr + (possibly fragmented, possibly encrypted) payload */ |
884 | 888 | ||
885 | if (local->host_decrypt && (fc & WLAN_FC_ISWEP) && | 889 | if (local->host_decrypt && (fc & IEEE80211_FCTL_WEP) && |
886 | (keyidx = hostap_rx_frame_decrypt(local, skb, crypt)) < 0) | 890 | (keyidx = hostap_rx_frame_decrypt(local, skb, crypt)) < 0) |
887 | goto rx_dropped; | 891 | goto rx_dropped; |
888 | hdr = (struct ieee80211_hdr *) skb->data; | 892 | hdr = (struct ieee80211_hdr *) skb->data; |
889 | 893 | ||
890 | /* skb: hdr + (possibly fragmented) plaintext payload */ | 894 | /* skb: hdr + (possibly fragmented) plaintext payload */ |
891 | 895 | ||
892 | if (local->host_decrypt && (fc & WLAN_FC_ISWEP) && | 896 | if (local->host_decrypt && (fc & IEEE80211_FCTL_WEP) && |
893 | (frag != 0 || (fc & WLAN_FC_MOREFRAG))) { | 897 | (frag != 0 || (fc & IEEE80211_FCTL_MOREFRAGS))) { |
894 | int flen; | 898 | int flen; |
895 | struct sk_buff *frag_skb = | 899 | struct sk_buff *frag_skb = |
896 | prism2_frag_cache_get(local, hdr); | 900 | prism2_frag_cache_get(local, hdr); |
897 | if (!frag_skb) { | 901 | if (!frag_skb) { |
898 | printk(KERN_DEBUG "%s: Rx cannot get skb from " | 902 | printk(KERN_DEBUG "%s: Rx cannot get skb from " |
899 | "fragment cache (morefrag=%d seq=%u frag=%u)\n", | 903 | "fragment cache (morefrag=%d seq=%u frag=%u)\n", |
900 | dev->name, (fc & WLAN_FC_MOREFRAG) != 0, | 904 | dev->name, (fc & IEEE80211_FCTL_MOREFRAGS) != 0, |
901 | WLAN_GET_SEQ_SEQ(sc) >> 4, frag); | 905 | WLAN_GET_SEQ_SEQ(sc) >> 4, frag); |
902 | goto rx_dropped; | 906 | goto rx_dropped; |
903 | } | 907 | } |
@@ -927,7 +931,7 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
927 | dev_kfree_skb(skb); | 931 | dev_kfree_skb(skb); |
928 | skb = NULL; | 932 | skb = NULL; |
929 | 933 | ||
930 | if (fc & WLAN_FC_MOREFRAG) { | 934 | if (fc & IEEE80211_FCTL_MOREFRAGS) { |
931 | /* more fragments expected - leave the skb in fragment | 935 | /* more fragments expected - leave the skb in fragment |
932 | * cache for now; it will be delivered to upper layers | 936 | * cache for now; it will be delivered to upper layers |
933 | * after all fragments have been received */ | 937 | * after all fragments have been received */ |
@@ -944,12 +948,12 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
944 | /* skb: hdr + (possible reassembled) full MSDU payload; possibly still | 948 | /* skb: hdr + (possible reassembled) full MSDU payload; possibly still |
945 | * encrypted/authenticated */ | 949 | * encrypted/authenticated */ |
946 | 950 | ||
947 | if (local->host_decrypt && (fc & WLAN_FC_ISWEP) && | 951 | if (local->host_decrypt && (fc & IEEE80211_FCTL_WEP) && |
948 | hostap_rx_frame_decrypt_msdu(local, skb, keyidx, crypt)) | 952 | hostap_rx_frame_decrypt_msdu(local, skb, keyidx, crypt)) |
949 | goto rx_dropped; | 953 | goto rx_dropped; |
950 | 954 | ||
951 | hdr = (struct ieee80211_hdr *) skb->data; | 955 | hdr = (struct ieee80211_hdr *) skb->data; |
952 | if (crypt && !(fc & WLAN_FC_ISWEP) && !local->open_wep) { | 956 | if (crypt && !(fc & IEEE80211_FCTL_WEP) && !local->open_wep) { |
953 | if (local->ieee_802_1x && | 957 | if (local->ieee_802_1x && |
954 | hostap_is_eapol_frame(local, skb)) { | 958 | hostap_is_eapol_frame(local, skb)) { |
955 | /* pass unencrypted EAPOL frames even if encryption is | 959 | /* pass unencrypted EAPOL frames even if encryption is |
@@ -964,7 +968,7 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
964 | } | 968 | } |
965 | } | 969 | } |
966 | 970 | ||
967 | if (local->drop_unencrypted && !(fc & WLAN_FC_ISWEP) && | 971 | if (local->drop_unencrypted && !(fc & IEEE80211_FCTL_WEP) && |
968 | !hostap_is_eapol_frame(local, skb)) { | 972 | !hostap_is_eapol_frame(local, skb)) { |
969 | if (net_ratelimit()) { | 973 | if (net_ratelimit()) { |
970 | printk(KERN_DEBUG "%s: dropped unencrypted RX data " | 974 | printk(KERN_DEBUG "%s: dropped unencrypted RX data " |
@@ -1023,7 +1027,8 @@ void hostap_80211_rx(struct net_device *dev, struct sk_buff *skb, | |||
1023 | memcpy(skb_push(skb, ETH_ALEN), dst, ETH_ALEN); | 1027 | memcpy(skb_push(skb, ETH_ALEN), dst, ETH_ALEN); |
1024 | } | 1028 | } |
1025 | 1029 | ||
1026 | if (wds && ((fc & (WLAN_FC_TODS | WLAN_FC_FROMDS)) == WLAN_FC_TODS) && | 1030 | if (wds && ((fc & (IEEE80211_FCTL_TODS | IEEE80211_FCTL_FROMDS)) == |
1031 | IEEE80211_FCTL_TODS) && | ||
1027 | skb->len >= ETH_HLEN + ETH_ALEN) { | 1032 | skb->len >= ETH_HLEN + ETH_ALEN) { |
1028 | /* Non-standard frame: get addr4 from its bogus location after | 1033 | /* Non-standard frame: get addr4 from its bogus location after |
1029 | * the payload */ | 1034 | * the payload */ |
diff --git a/drivers/net/wireless/hostap/hostap_80211_tx.c b/drivers/net/wireless/hostap/hostap_80211_tx.c index 79cf55338d88..fb378046ab39 100644 --- a/drivers/net/wireless/hostap/hostap_80211_tx.c +++ b/drivers/net/wireless/hostap/hostap_80211_tx.c | |||
@@ -14,8 +14,8 @@ void hostap_dump_tx_80211(const char *name, struct sk_buff *skb) | |||
14 | fc = le16_to_cpu(hdr->frame_ctl); | 14 | fc = le16_to_cpu(hdr->frame_ctl); |
15 | printk(KERN_DEBUG " FC=0x%04x (type=%d:%d)%s%s", | 15 | printk(KERN_DEBUG " FC=0x%04x (type=%d:%d)%s%s", |
16 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, | 16 | fc, WLAN_FC_GET_TYPE(fc) >> 2, WLAN_FC_GET_STYPE(fc) >> 4, |
17 | fc & WLAN_FC_TODS ? " [ToDS]" : "", | 17 | fc & IEEE80211_FCTL_TODS ? " [ToDS]" : "", |
18 | fc & WLAN_FC_FROMDS ? " [FromDS]" : ""); | 18 | fc & IEEE80211_FCTL_FROMDS ? " [FromDS]" : ""); |
19 | 19 | ||
20 | if (skb->len < IEEE80211_DATA_HDR3_LEN) { | 20 | if (skb->len < IEEE80211_DATA_HDR3_LEN) { |
21 | printk("\n"); | 21 | printk("\n"); |
@@ -128,7 +128,7 @@ int hostap_data_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
128 | * frame format */ | 128 | * frame format */ |
129 | 129 | ||
130 | if (use_wds == WDS_COMPLIANT_FRAME) { | 130 | if (use_wds == WDS_COMPLIANT_FRAME) { |
131 | fc |= WLAN_FC_FROMDS | WLAN_FC_TODS; | 131 | fc |= IEEE80211_FCTL_FROMDS | IEEE80211_FCTL_TODS; |
132 | /* From&To DS: Addr1 = RA, Addr2 = TA, Addr3 = DA, | 132 | /* From&To DS: Addr1 = RA, Addr2 = TA, Addr3 = DA, |
133 | * Addr4 = SA */ | 133 | * Addr4 = SA */ |
134 | memcpy(&hdr.addr4, skb->data + ETH_ALEN, ETH_ALEN); | 134 | memcpy(&hdr.addr4, skb->data + ETH_ALEN, ETH_ALEN); |
@@ -136,7 +136,7 @@ int hostap_data_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
136 | } else { | 136 | } else { |
137 | /* bogus 4-addr format to workaround Prism2 station | 137 | /* bogus 4-addr format to workaround Prism2 station |
138 | * f/w bug */ | 138 | * f/w bug */ |
139 | fc |= WLAN_FC_TODS; | 139 | fc |= IEEE80211_FCTL_TODS; |
140 | /* From DS: Addr1 = DA (used as RA), | 140 | /* From DS: Addr1 = DA (used as RA), |
141 | * Addr2 = BSSID (used as TA), Addr3 = SA (used as DA), | 141 | * Addr2 = BSSID (used as TA), Addr3 = SA (used as DA), |
142 | */ | 142 | */ |
@@ -161,13 +161,13 @@ int hostap_data_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
161 | memcpy(&hdr.addr2, dev->dev_addr, ETH_ALEN); | 161 | memcpy(&hdr.addr2, dev->dev_addr, ETH_ALEN); |
162 | memcpy(&hdr.addr3, skb->data, ETH_ALEN); | 162 | memcpy(&hdr.addr3, skb->data, ETH_ALEN); |
163 | } else if (local->iw_mode == IW_MODE_MASTER && !to_assoc_ap) { | 163 | } else if (local->iw_mode == IW_MODE_MASTER && !to_assoc_ap) { |
164 | fc |= WLAN_FC_FROMDS; | 164 | fc |= IEEE80211_FCTL_FROMDS; |
165 | /* From DS: Addr1 = DA, Addr2 = BSSID, Addr3 = SA */ | 165 | /* From DS: Addr1 = DA, Addr2 = BSSID, Addr3 = SA */ |
166 | memcpy(&hdr.addr1, skb->data, ETH_ALEN); | 166 | memcpy(&hdr.addr1, skb->data, ETH_ALEN); |
167 | memcpy(&hdr.addr2, dev->dev_addr, ETH_ALEN); | 167 | memcpy(&hdr.addr2, dev->dev_addr, ETH_ALEN); |
168 | memcpy(&hdr.addr3, skb->data + ETH_ALEN, ETH_ALEN); | 168 | memcpy(&hdr.addr3, skb->data + ETH_ALEN, ETH_ALEN); |
169 | } else if (local->iw_mode == IW_MODE_INFRA || to_assoc_ap) { | 169 | } else if (local->iw_mode == IW_MODE_INFRA || to_assoc_ap) { |
170 | fc |= WLAN_FC_TODS; | 170 | fc |= IEEE80211_FCTL_TODS; |
171 | /* To DS: Addr1 = BSSID, Addr2 = SA, Addr3 = DA */ | 171 | /* To DS: Addr1 = BSSID, Addr2 = SA, Addr3 = DA */ |
172 | memcpy(&hdr.addr1, to_assoc_ap ? | 172 | memcpy(&hdr.addr1, to_assoc_ap ? |
173 | local->assoc_ap_addr : local->bssid, ETH_ALEN); | 173 | local->assoc_ap_addr : local->bssid, ETH_ALEN); |
@@ -439,12 +439,12 @@ int hostap_master_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
439 | /* Request TX callback if protocol version is 2 in 802.11 header; | 439 | /* Request TX callback if protocol version is 2 in 802.11 header; |
440 | * this version 2 is a special case used between hostapd and kernel | 440 | * this version 2 is a special case used between hostapd and kernel |
441 | * driver */ | 441 | * driver */ |
442 | if (((fc & WLAN_FC_PVER) == BIT(1)) && | 442 | if (((fc & IEEE80211_FCTL_VERS) == BIT(1)) && |
443 | local->ap && local->ap->tx_callback_idx && meta->tx_cb_idx == 0) { | 443 | local->ap && local->ap->tx_callback_idx && meta->tx_cb_idx == 0) { |
444 | meta->tx_cb_idx = local->ap->tx_callback_idx; | 444 | meta->tx_cb_idx = local->ap->tx_callback_idx; |
445 | 445 | ||
446 | /* remove special version from the frame header */ | 446 | /* remove special version from the frame header */ |
447 | fc &= ~WLAN_FC_PVER; | 447 | fc &= ~IEEE80211_FCTL_VERS; |
448 | hdr->frame_ctl = cpu_to_le16(fc); | 448 | hdr->frame_ctl = cpu_to_le16(fc); |
449 | } | 449 | } |
450 | 450 | ||
@@ -454,7 +454,7 @@ int hostap_master_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
454 | } | 454 | } |
455 | 455 | ||
456 | if (local->ieee_802_1x && meta->ethertype == ETH_P_PAE && tx.crypt && | 456 | if (local->ieee_802_1x && meta->ethertype == ETH_P_PAE && tx.crypt && |
457 | !(fc & WLAN_FC_ISWEP)) { | 457 | !(fc & IEEE80211_FCTL_VERS)) { |
458 | no_encrypt = 1; | 458 | no_encrypt = 1; |
459 | PDEBUG(DEBUG_EXTRA2, "%s: TX: IEEE 802.1X - passing " | 459 | PDEBUG(DEBUG_EXTRA2, "%s: TX: IEEE 802.1X - passing " |
460 | "unencrypted EAPOL frame\n", dev->name); | 460 | "unencrypted EAPOL frame\n", dev->name); |
@@ -466,7 +466,7 @@ int hostap_master_start_xmit(struct sk_buff *skb, struct net_device *dev) | |||
466 | else if ((tx.crypt || local->crypt[local->tx_keyidx]) && !no_encrypt) { | 466 | else if ((tx.crypt || local->crypt[local->tx_keyidx]) && !no_encrypt) { |
467 | /* Add ISWEP flag both for firmware and host based encryption | 467 | /* Add ISWEP flag both for firmware and host based encryption |
468 | */ | 468 | */ |
469 | fc |= WLAN_FC_ISWEP; | 469 | fc |= IEEE80211_FCTL_WEP; |
470 | hdr->frame_ctl = cpu_to_le16(fc); | 470 | hdr->frame_ctl = cpu_to_le16(fc); |
471 | } else if (local->drop_unencrypted && | 471 | } else if (local->drop_unencrypted && |
472 | WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA && | 472 | WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA && |
diff --git a/drivers/net/wireless/hostap/hostap_ap.c b/drivers/net/wireless/hostap/hostap_ap.c index 596c4dde079d..2c6ea796e00e 100644 --- a/drivers/net/wireless/hostap/hostap_ap.c +++ b/drivers/net/wireless/hostap/hostap_ap.c | |||
@@ -604,7 +604,7 @@ static void hostap_ap_tx_cb(struct sk_buff *skb, int ok, void *data) | |||
604 | /* Pass the TX callback frame to the hostapd; use 802.11 header version | 604 | /* Pass the TX callback frame to the hostapd; use 802.11 header version |
605 | * 1 to indicate failure (no ACK) and 2 success (frame ACKed) */ | 605 | * 1 to indicate failure (no ACK) and 2 success (frame ACKed) */ |
606 | 606 | ||
607 | fc &= ~WLAN_FC_PVER; | 607 | fc &= ~IEEE80211_FCTL_VERS; |
608 | fc |= ok ? BIT(1) : BIT(0); | 608 | fc |= ok ? BIT(1) : BIT(0); |
609 | hdr->frame_ctl = cpu_to_le16(fc); | 609 | hdr->frame_ctl = cpu_to_le16(fc); |
610 | 610 | ||
@@ -956,7 +956,7 @@ static void prism2_send_mgmt(struct net_device *dev, | |||
956 | 956 | ||
957 | memcpy(hdr->addr1, addr, ETH_ALEN); /* DA / RA */ | 957 | memcpy(hdr->addr1, addr, ETH_ALEN); /* DA / RA */ |
958 | if (WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA) { | 958 | if (WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA) { |
959 | fc |= WLAN_FC_FROMDS; | 959 | fc |= IEEE80211_FCTL_FROMDS; |
960 | memcpy(hdr->addr2, dev->dev_addr, ETH_ALEN); /* BSSID */ | 960 | memcpy(hdr->addr2, dev->dev_addr, ETH_ALEN); /* BSSID */ |
961 | memcpy(hdr->addr3, dev->dev_addr, ETH_ALEN); /* SA */ | 961 | memcpy(hdr->addr3, dev->dev_addr, ETH_ALEN); /* SA */ |
962 | } else if (WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_CTL) { | 962 | } else if (WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_CTL) { |
@@ -1436,7 +1436,7 @@ static void handle_authen(local_info_t *local, struct sk_buff *skb, | |||
1436 | challenge == NULL || | 1436 | challenge == NULL || |
1437 | memcmp(sta->u.sta.challenge, challenge, | 1437 | memcmp(sta->u.sta.challenge, challenge, |
1438 | WLAN_AUTH_CHALLENGE_LEN) != 0 || | 1438 | WLAN_AUTH_CHALLENGE_LEN) != 0 || |
1439 | !(fc & WLAN_FC_ISWEP)) { | 1439 | !(fc & IEEE80211_FCTL_WEP)) { |
1440 | txt = "challenge response incorrect"; | 1440 | txt = "challenge response incorrect"; |
1441 | resp = WLAN_STATUS_CHALLENGE_FAIL; | 1441 | resp = WLAN_STATUS_CHALLENGE_FAIL; |
1442 | goto fail; | 1442 | goto fail; |
@@ -1871,7 +1871,7 @@ static void handle_pspoll(local_info_t *local, | |||
1871 | PDEBUG(DEBUG_PS2, "handle_pspoll: BSSID=" MACSTR ", TA=" MACSTR | 1871 | PDEBUG(DEBUG_PS2, "handle_pspoll: BSSID=" MACSTR ", TA=" MACSTR |
1872 | " PWRMGT=%d\n", | 1872 | " PWRMGT=%d\n", |
1873 | MAC2STR(hdr->addr1), MAC2STR(hdr->addr2), | 1873 | MAC2STR(hdr->addr1), MAC2STR(hdr->addr2), |
1874 | !!(le16_to_cpu(hdr->frame_ctl) & WLAN_FC_PWRMGT)); | 1874 | !!(le16_to_cpu(hdr->frame_ctl) & IEEE80211_FCTL_PM)); |
1875 | 1875 | ||
1876 | if (memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN)) { | 1876 | if (memcmp(hdr->addr1, dev->dev_addr, ETH_ALEN)) { |
1877 | PDEBUG(DEBUG_AP, "handle_pspoll - addr1(BSSID)=" MACSTR | 1877 | PDEBUG(DEBUG_AP, "handle_pspoll - addr1(BSSID)=" MACSTR |
@@ -2150,7 +2150,8 @@ static void handle_ap_item(local_info_t *local, struct sk_buff *skb, | |||
2150 | if (!local->hostapd && type == IEEE80211_FTYPE_DATA) { | 2150 | if (!local->hostapd && type == IEEE80211_FTYPE_DATA) { |
2151 | PDEBUG(DEBUG_AP, "handle_ap_item - data frame\n"); | 2151 | PDEBUG(DEBUG_AP, "handle_ap_item - data frame\n"); |
2152 | 2152 | ||
2153 | if (!(fc & WLAN_FC_TODS) || (fc & WLAN_FC_FROMDS)) { | 2153 | if (!(fc & IEEE80211_FCTL_TODS) || |
2154 | (fc & IEEE80211_FCTL_FROMDS)) { | ||
2154 | if (stype == IEEE80211_STYPE_NULLFUNC) { | 2155 | if (stype == IEEE80211_STYPE_NULLFUNC) { |
2155 | /* no ToDS nullfunc seems to be used to check | 2156 | /* no ToDS nullfunc seems to be used to check |
2156 | * AP association; so send reject message to | 2157 | * AP association; so send reject message to |
@@ -2746,7 +2747,8 @@ ap_tx_ret hostap_handle_sta_tx(local_info_t *local, struct hostap_tx_data *tx) | |||
2746 | 2747 | ||
2747 | if (meta->flags & HOSTAP_TX_FLAGS_ADD_MOREDATA) { | 2748 | if (meta->flags & HOSTAP_TX_FLAGS_ADD_MOREDATA) { |
2748 | /* indicate to STA that more frames follow */ | 2749 | /* indicate to STA that more frames follow */ |
2749 | hdr->frame_ctl |= __constant_cpu_to_le16(WLAN_FC_MOREDATA); | 2750 | hdr->frame_ctl |= |
2751 | __constant_cpu_to_le16(IEEE80211_FCTL_MOREDATA); | ||
2750 | } | 2752 | } |
2751 | 2753 | ||
2752 | if (meta->flags & HOSTAP_TX_FLAGS_BUFFERED_FRAME) { | 2754 | if (meta->flags & HOSTAP_TX_FLAGS_BUFFERED_FRAME) { |
@@ -2905,7 +2907,7 @@ int hostap_update_sta_ps(local_info_t *local, struct ieee80211_hdr *hdr) | |||
2905 | return -1; | 2907 | return -1; |
2906 | 2908 | ||
2907 | fc = le16_to_cpu(hdr->frame_ctl); | 2909 | fc = le16_to_cpu(hdr->frame_ctl); |
2908 | hostap_update_sta_ps2(local, sta, fc & WLAN_FC_PWRMGT, | 2910 | hostap_update_sta_ps2(local, sta, fc & IEEE80211_FCTL_PM, |
2909 | WLAN_FC_GET_TYPE(fc), WLAN_FC_GET_STYPE(fc)); | 2911 | WLAN_FC_GET_TYPE(fc), WLAN_FC_GET_STYPE(fc)); |
2910 | 2912 | ||
2911 | atomic_dec(&sta->users); | 2913 | atomic_dec(&sta->users); |
@@ -2946,7 +2948,7 @@ ap_rx_ret hostap_handle_sta_rx(local_info_t *local, struct net_device *dev, | |||
2946 | ret = AP_RX_CONTINUE; | 2948 | ret = AP_RX_CONTINUE; |
2947 | 2949 | ||
2948 | 2950 | ||
2949 | if (fc & WLAN_FC_TODS) { | 2951 | if (fc & IEEE80211_FCTL_TODS) { |
2950 | if (!wds && (sta == NULL || !(sta->flags & WLAN_STA_ASSOC))) { | 2952 | if (!wds && (sta == NULL || !(sta->flags & WLAN_STA_ASSOC))) { |
2951 | if (local->hostapd) { | 2953 | if (local->hostapd) { |
2952 | prism2_rx_80211(local->apdev, skb, rx_stats, | 2954 | prism2_rx_80211(local->apdev, skb, rx_stats, |
@@ -2964,7 +2966,7 @@ ap_rx_ret hostap_handle_sta_rx(local_info_t *local, struct net_device *dev, | |||
2964 | ret = AP_RX_EXIT; | 2966 | ret = AP_RX_EXIT; |
2965 | goto out; | 2967 | goto out; |
2966 | } | 2968 | } |
2967 | } else if (fc & WLAN_FC_FROMDS) { | 2969 | } else if (fc & IEEE80211_FCTL_FROMDS) { |
2968 | if (!wds) { | 2970 | if (!wds) { |
2969 | /* FromDS frame - not for us; probably | 2971 | /* FromDS frame - not for us; probably |
2970 | * broadcast/multicast in another BSS - drop */ | 2972 | * broadcast/multicast in another BSS - drop */ |
@@ -3019,7 +3021,7 @@ ap_rx_ret hostap_handle_sta_rx(local_info_t *local, struct net_device *dev, | |||
3019 | } | 3021 | } |
3020 | 3022 | ||
3021 | if (sta) { | 3023 | if (sta) { |
3022 | hostap_update_sta_ps2(local, sta, fc & WLAN_FC_PWRMGT, | 3024 | hostap_update_sta_ps2(local, sta, fc & IEEE80211_FCTL_PM, |
3023 | type, stype); | 3025 | type, stype); |
3024 | 3026 | ||
3025 | sta->rx_packets++; | 3027 | sta->rx_packets++; |
@@ -3028,7 +3030,7 @@ ap_rx_ret hostap_handle_sta_rx(local_info_t *local, struct net_device *dev, | |||
3028 | } | 3030 | } |
3029 | 3031 | ||
3030 | if (local->ap->nullfunc_ack && stype == IEEE80211_STYPE_NULLFUNC && | 3032 | if (local->ap->nullfunc_ack && stype == IEEE80211_STYPE_NULLFUNC && |
3031 | fc & WLAN_FC_TODS) { | 3033 | fc & IEEE80211_FCTL_TODS) { |
3032 | if (local->hostapd) { | 3034 | if (local->hostapd) { |
3033 | prism2_rx_80211(local->apdev, skb, rx_stats, | 3035 | prism2_rx_80211(local->apdev, skb, rx_stats, |
3034 | PRISM2_RX_NULLFUNC_ACK); | 3036 | PRISM2_RX_NULLFUNC_ACK); |
diff --git a/drivers/net/wireless/hostap/hostap_common.h b/drivers/net/wireless/hostap/hostap_common.h index e0ce34f165e0..6f4fa9dc308f 100644 --- a/drivers/net/wireless/hostap/hostap_common.h +++ b/drivers/net/wireless/hostap/hostap_common.h | |||
@@ -9,16 +9,6 @@ | |||
9 | 9 | ||
10 | /* IEEE 802.11 defines */ | 10 | /* IEEE 802.11 defines */ |
11 | 11 | ||
12 | #define WLAN_FC_PVER (BIT(1) | BIT(0)) | ||
13 | #define WLAN_FC_TODS BIT(8) | ||
14 | #define WLAN_FC_FROMDS BIT(9) | ||
15 | #define WLAN_FC_MOREFRAG BIT(10) | ||
16 | #define WLAN_FC_RETRY BIT(11) | ||
17 | #define WLAN_FC_PWRMGT BIT(12) | ||
18 | #define WLAN_FC_MOREDATA BIT(13) | ||
19 | #define WLAN_FC_ISWEP BIT(14) | ||
20 | #define WLAN_FC_ORDER BIT(15) | ||
21 | |||
22 | /* Information Element IDs */ | 12 | /* Information Element IDs */ |
23 | #define WLAN_EID_SSID 0 | 13 | #define WLAN_EID_SSID 0 |
24 | #define WLAN_EID_SUPP_RATES 1 | 14 | #define WLAN_EID_SUPP_RATES 1 |
diff --git a/drivers/net/wireless/hostap/hostap_hw.c b/drivers/net/wireless/hostap/hostap_hw.c index 34037b599ebc..e533a663deda 100644 --- a/drivers/net/wireless/hostap/hostap_hw.c +++ b/drivers/net/wireless/hostap/hostap_hw.c | |||
@@ -1844,7 +1844,8 @@ static int prism2_tx_80211(struct sk_buff *skb, struct net_device *dev) | |||
1844 | memcpy(&txdesc.frame_control, skb->data, hdr_len); | 1844 | memcpy(&txdesc.frame_control, skb->data, hdr_len); |
1845 | fc = le16_to_cpu(txdesc.frame_control); | 1845 | fc = le16_to_cpu(txdesc.frame_control); |
1846 | if (WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA && | 1846 | if (WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA && |
1847 | (fc & WLAN_FC_FROMDS) && (fc & WLAN_FC_TODS) && skb->len >= 30) { | 1847 | (fc & IEEE80211_FCTL_FROMDS) && (fc & IEEE80211_FCTL_TODS) && |
1848 | skb->len >= 30) { | ||
1848 | /* Addr4 */ | 1849 | /* Addr4 */ |
1849 | memcpy(txdesc.addr4, skb->data + hdr_len, ETH_ALEN); | 1850 | memcpy(txdesc.addr4, skb->data + hdr_len, ETH_ALEN); |
1850 | hdr_len += ETH_ALEN; | 1851 | hdr_len += ETH_ALEN; |
@@ -2399,8 +2400,8 @@ static void prism2_txexc(local_info_t *local) | |||
2399 | WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_CTL ? "Ctrl" : "", | 2400 | WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_CTL ? "Ctrl" : "", |
2400 | WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA ? "Data" : "", | 2401 | WLAN_FC_GET_TYPE(fc) == IEEE80211_FTYPE_DATA ? "Data" : "", |
2401 | WLAN_FC_GET_STYPE(fc) >> 4, | 2402 | WLAN_FC_GET_STYPE(fc) >> 4, |
2402 | fc & WLAN_FC_TODS ? " ToDS" : "", | 2403 | fc & IEEE80211_FCTL_TODS ? " ToDS" : "", |
2403 | fc & WLAN_FC_FROMDS ? " FromDS" : ""); | 2404 | fc & IEEE80211_FCTL_FROMDS ? " FromDS" : ""); |
2404 | PDEBUG(DEBUG_EXTRA, " A1=" MACSTR " A2=" MACSTR " A3=" | 2405 | PDEBUG(DEBUG_EXTRA, " A1=" MACSTR " A2=" MACSTR " A3=" |
2405 | MACSTR " A4=" MACSTR "\n", | 2406 | MACSTR " A4=" MACSTR "\n", |
2406 | MAC2STR(txdesc.addr1), MAC2STR(txdesc.addr2), | 2407 | MAC2STR(txdesc.addr1), MAC2STR(txdesc.addr2), |