2015-07-12 11:57:04 +00:00
|
|
|
--- a/main.c
|
|
|
|
+++ b/main.c
|
2016-05-14 17:38:56 +02:00
|
|
|
@@ -497,7 +497,7 @@ int acx_free_mechanics(acx_device_t *ade
|
2015-07-12 11:57:04 +00:00
|
|
|
|
|
|
|
int acx_init_ieee80211(acx_device_t *adev, struct ieee80211_hw *hw)
|
|
|
|
{
|
|
|
|
- hw->flags &= ~IEEE80211_HW_RX_INCLUDES_FCS;
|
|
|
|
+ __clear_bit(IEEE80211_HW_RX_INCLUDES_FCS, hw->flags);
|
|
|
|
hw->queues = 1;
|
|
|
|
hw->wiphy->max_scan_ssids = 1;
|
|
|
|
|
2016-05-14 17:38:56 +02:00
|
|
|
@@ -525,14 +525,14 @@ int acx_init_ieee80211(acx_device_t *ade
|
2015-07-12 11:57:04 +00:00
|
|
|
/* We base signal quality on winlevel approach of previous driver
|
|
|
|
* TODO OW 20100615 This should into a common init code
|
|
|
|
*/
|
|
|
|
- hw->flags |= IEEE80211_HW_SIGNAL_UNSPEC;
|
|
|
|
+ __set_bit(IEEE80211_HW_SIGNAL_UNSPEC, hw->flags);
|
|
|
|
hw->max_signal = 100;
|
|
|
|
|
|
|
|
if (IS_ACX100(adev)) {
|
2016-05-14 17:38:56 +02:00
|
|
|
- adev->hw->wiphy->bands[IEEE80211_BAND_2GHZ] =
|
|
|
|
+ adev->hw->wiphy->bands[NL80211_BAND_2GHZ] =
|
|
|
|
&acx100_band_2GHz;
|
|
|
|
} else if (IS_ACX111(adev))
|
|
|
|
- adev->hw->wiphy->bands[IEEE80211_BAND_2GHZ] =
|
|
|
|
+ adev->hw->wiphy->bands[NL80211_BAND_2GHZ] =
|
|
|
|
&acx111_band_2GHz;
|
|
|
|
else {
|
|
|
|
log(L_ANY, "Error: Unknown device");
|
|
|
|
@@ -945,8 +945,8 @@ void acx_op_configure_filter(struct ieee
|
2015-07-12 11:57:04 +00:00
|
|
|
changed_flags, *total_flags);
|
|
|
|
|
|
|
|
/* OWI TODO: Set also FIF_PROBE_REQ ? */
|
|
|
|
- *total_flags &= (FIF_PROMISC_IN_BSS | FIF_ALLMULTI | FIF_FCSFAIL
|
|
|
|
- | FIF_CONTROL | FIF_OTHER_BSS);
|
|
|
|
+ *total_flags &= (FIF_ALLMULTI | FIF_FCSFAIL | FIF_CONTROL
|
|
|
|
+ | FIF_OTHER_BSS);
|
|
|
|
|
|
|
|
logf1(L_DEBUG, "2: *total_flags=0x%08x\n", *total_flags);
|
|
|
|
|
2016-05-14 17:38:56 +02:00
|
|
|
@@ -1045,9 +1045,10 @@ void acx_op_tx(struct ieee80211_hw *hw,
|
2015-07-12 11:57:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int acx_op_hw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
|
|
- struct cfg80211_scan_request *req)
|
|
|
|
+ struct ieee80211_scan_request *hw_req)
|
|
|
|
{
|
|
|
|
acx_device_t *adev = hw2adev(hw);
|
|
|
|
+ struct cfg80211_scan_request *req = &hw_req->req;
|
|
|
|
struct sk_buff *skb;
|
|
|
|
size_t ssid_len = 0;
|
|
|
|
u8 *ssid = NULL;
|
2016-05-14 17:38:56 +02:00
|
|
|
@@ -1082,7 +1083,7 @@ int acx_op_hw_scan(struct ieee80211_hw *
|
2015-07-12 11:57:04 +00:00
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
- skb = ieee80211_probereq_get(adev->hw, adev->vif, ssid, ssid_len,
|
|
|
|
+ skb = ieee80211_probereq_get(adev->hw, vif->addr, ssid, ssid_len,
|
|
|
|
req->ie_len);
|
|
|
|
if (!skb) {
|
|
|
|
ret = -ENOMEM;
|
|
|
|
--- a/main.h
|
|
|
|
+++ b/main.h
|
2016-05-14 17:38:56 +02:00
|
|
|
@@ -62,7 +62,7 @@ void acx_op_tx(struct ieee80211_hw *hw,
|
2015-07-12 11:57:04 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
int acx_op_hw_scan(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
|
|
- struct cfg80211_scan_request *req);
|
|
|
|
+ struct ieee80211_scan_request *req);
|
|
|
|
|
|
|
|
int acx_recover_hw(acx_device_t *adev);
|
|
|
|
|
2016-05-14 17:38:56 +02:00
|
|
|
--- a/cardsetting.c
|
|
|
|
+++ b/cardsetting.c
|
|
|
|
@@ -159,7 +159,7 @@ int acx_set_channel(acx_device_t *adev,
|
|
|
|
int res = 0;
|
|
|
|
|
|
|
|
adev->rx_status.freq = freq;
|
|
|
|
- adev->rx_status.band = IEEE80211_BAND_2GHZ;
|
|
|
|
+ adev->rx_status.band = NL80211_BAND_2GHZ;
|
|
|
|
|
|
|
|
adev->channel = channel;
|
|
|
|
|
2017-01-27 11:11:00 +01:00
|
|
|
--- a/merge.c
|
|
|
|
+++ b/merge.c
|
|
|
|
@@ -2776,7 +2776,10 @@ void acx_irq_work(struct work_struct *wo
|
|
|
|
/* HOST_INT_SCAN_COMPLETE */
|
|
|
|
if (irqmasked & HOST_INT_SCAN_COMPLETE) {
|
|
|
|
if (test_bit(ACX_FLAG_SCANNING, &adev->flags)) {
|
|
|
|
- ieee80211_scan_completed(adev->hw, false);
|
|
|
|
+ struct cfg80211_scan_info info = {
|
|
|
|
+ .aborted = false
|
|
|
|
+ };
|
|
|
|
+ ieee80211_scan_completed(adev->hw, &info);
|
|
|
|
log(L_INIT, "scan completed\n");
|
|
|
|
clear_bit(ACX_FLAG_SCANNING, &adev->flags);
|
|
|
|
}
|
|
|
|
@@ -3138,10 +3141,13 @@ int acx_op_start(struct ieee80211_hw *hw
|
|
|
|
|
|
|
|
void acx_stop(acx_device_t *adev)
|
|
|
|
{
|
|
|
|
+ struct cfg80211_scan_info info = {
|
|
|
|
+ .aborted = true
|
|
|
|
+ };
|
|
|
|
acxmem_lock_flags;
|
|
|
|
|
|
|
|
if (test_bit(ACX_FLAG_SCANNING, &adev->flags)) {
|
|
|
|
- ieee80211_scan_completed(adev->hw, true);
|
|
|
|
+ ieee80211_scan_completed(adev->hw, &info);
|
|
|
|
acx_issue_cmd(adev, ACX1xx_CMD_STOP_SCAN, NULL, 0);
|
|
|
|
clear_bit(ACX_FLAG_SCANNING, &adev->flags);
|
|
|
|
}
|