mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-18 10:46:41 +00:00
mwlwifi: update to version 10.4.10-20231120
Upstream PR 416 improvements: -AMPDU Optimization of priority calculation. (8864/8897) -8864/8897 fix wpa3 -Add cypher suite to driver capabilities (all chip) -Alignment of pcie_tx_ctrl* (all chip) -"feature" normalization for all chips (all chip) -Add modprobe parameters (all chip) -fix monitoring (all chip) -Code separation by chipset (8864/8897 <=> 8997) -dump_prob decommissioning (8864/8897/8997) -fix amsdu high ping latency (8864/8897/8997) -drop debug info in hostcmd_get_hw_spec() (8864/8897) -Add wcb_base in debug info (8864) -Rewrite AMSDU packets (8864/8897/8997) -debug rewrite output mwl_debugfs_sta_read (all chip) -Improved encryption interoperability (8864/8897/8997) -factorization encrypted packet test (8864/8897/8997) -Change 88W8864 firmware to 7.2.9.27 (8864/8897) -Fix the AMPDU session lifecycle (8864/8897/8997) -Remove the tx done packets mechanism (8864/8897) Signed-off-by: Michael Trinidad <trinidude4@hotmail.com>
This commit is contained in:
parent
c9c35dca7a
commit
9cf5769636
@ -15,9 +15,9 @@ PKG_LICENSE_FILES:=
|
|||||||
|
|
||||||
PKG_SOURCE_URL:=https://github.com/kaloz/mwlwifi
|
PKG_SOURCE_URL:=https://github.com/kaloz/mwlwifi
|
||||||
PKG_SOURCE_PROTO:=git
|
PKG_SOURCE_PROTO:=git
|
||||||
PKG_SOURCE_DATE:=2023-04-29
|
PKG_SOURCE_DATE:=2023-11-20
|
||||||
PKG_SOURCE_VERSION:=6a436714d2ea0d0adf39fc4d7d45e6a17fcc9371
|
PKG_SOURCE_VERSION:=2a5a4ae31a2ad1b432a1dcb6ef6c3298e3330b2c
|
||||||
PKG_MIRROR_HASH:=dcc320a8f859b732ff65c7ded0b5199a625bfba05a775a6bed15ed3c10cb2748
|
PKG_MIRROR_HASH:=b1151051ed6eba063c05916d8dbc4f03f804772d217e8c65b7baa263ded7a961
|
||||||
|
|
||||||
PKG_MAINTAINER:=Imre Kaloz <kaloz@openwrt.org>
|
PKG_MAINTAINER:=Imre Kaloz <kaloz@openwrt.org>
|
||||||
PKG_BUILD_PARALLEL:=1
|
PKG_BUILD_PARALLEL:=1
|
||||||
|
@ -117,11 +117,9 @@ Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
|
|||||||
hif/pcie/tx_ndp.c | 2 +-
|
hif/pcie/tx_ndp.c | 2 +-
|
||||||
4 files changed, 5 insertions(+), 5 deletions(-)
|
4 files changed, 5 insertions(+), 5 deletions(-)
|
||||||
|
|
||||||
diff --git a/debugfs.c b/debugfs.c
|
|
||||||
index 39b09fd..42efd28 100644
|
|
||||||
--- a/debugfs.c
|
--- a/debugfs.c
|
||||||
+++ b/debugfs.c
|
+++ b/debugfs.c
|
||||||
@@ -1332,7 +1332,7 @@ done:
|
@@ -1342,7 +1342,7 @@ done:
|
||||||
priv->reg_value);
|
priv->reg_value);
|
||||||
else
|
else
|
||||||
len += scnprintf(p + len, size - len,
|
len += scnprintf(p + len, size - len,
|
||||||
@ -130,11 +128,9 @@ index 39b09fd..42efd28 100644
|
|||||||
ret, priv->reg_type, priv->reg_offset,
|
ret, priv->reg_type, priv->reg_offset,
|
||||||
priv->reg_value);
|
priv->reg_value);
|
||||||
|
|
||||||
diff --git a/hif/fwcmd.c b/hif/fwcmd.c
|
|
||||||
index 376b58f..582c8d2 100644
|
|
||||||
--- a/hif/fwcmd.c
|
--- a/hif/fwcmd.c
|
||||||
+++ b/hif/fwcmd.c
|
+++ b/hif/fwcmd.c
|
||||||
@@ -3604,7 +3604,7 @@ int mwl_fwcmd_get_fw_core_dump(struct ieee80211_hw *hw,
|
@@ -3623,7 +3623,7 @@ int mwl_fwcmd_get_fw_core_dump(struct ie
|
||||||
core_dump->size_kb = pcmd->cmd_data.coredump.size_kb;
|
core_dump->size_kb = pcmd->cmd_data.coredump.size_kb;
|
||||||
core_dump->flags = pcmd->cmd_data.coredump.flags;
|
core_dump->flags = pcmd->cmd_data.coredump.flags;
|
||||||
memcpy(buff,
|
memcpy(buff,
|
||||||
@ -143,11 +139,20 @@ index 376b58f..582c8d2 100644
|
|||||||
sizeof(struct hostcmd_cmd_get_fw_core_dump) -
|
sizeof(struct hostcmd_cmd_get_fw_core_dump) -
|
||||||
sizeof(struct hostcmd_cmd_get_fw_core_dump_)),
|
sizeof(struct hostcmd_cmd_get_fw_core_dump_)),
|
||||||
MAX_CORE_DUMP_BUFFER);
|
MAX_CORE_DUMP_BUFFER);
|
||||||
diff --git a/hif/pcie/pcie.c b/hif/pcie/pcie.c
|
--- a/hif/pcie/8964/tx_ndp.c
|
||||||
index 24453b6..5b6c633 100644
|
+++ b/hif/pcie/8964/tx_ndp.c
|
||||||
|
@@ -336,7 +336,7 @@ int pcie_tx_init_ndp(struct ieee80211_hw
|
||||||
|
|
||||||
|
if (sizeof(struct pcie_tx_ctrl_ndp) >
|
||||||
|
sizeof(tx_info->driver_data)) {
|
||||||
|
- wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n",
|
||||||
|
+ wiphy_err(hw->wiphy, "driver data is not enough: %zu (%zu)\n",
|
||||||
|
sizeof(struct pcie_tx_ctrl_ndp),
|
||||||
|
sizeof(tx_info->driver_data));
|
||||||
|
return -ENOMEM;
|
||||||
--- a/hif/pcie/pcie.c
|
--- a/hif/pcie/pcie.c
|
||||||
+++ b/hif/pcie/pcie.c
|
+++ b/hif/pcie/pcie.c
|
||||||
@@ -1320,8 +1320,8 @@ static void pcie_bf_mimo_ctrl_decode(struct mwl_priv *priv,
|
@@ -1464,8 +1464,8 @@ static void pcie_bf_mimo_ctrl_decode(str
|
||||||
&fp_data->f_pos);
|
&fp_data->f_pos);
|
||||||
filp_close(fp_data, current->files);
|
filp_close(fp_data, current->files);
|
||||||
} else {
|
} else {
|
||||||
@ -158,19 +163,3 @@ index 24453b6..5b6c633 100644
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5,10,0)
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(5,10,0)
|
||||||
diff --git a/hif/pcie/tx_ndp.c b/hif/pcie/tx_ndp.c
|
|
||||||
index 6758cde..3140a2e 100644
|
|
||||||
--- a/hif/pcie/tx_ndp.c
|
|
||||||
+++ b/hif/pcie/tx_ndp.c
|
|
||||||
@@ -335,7 +335,7 @@ int pcie_tx_init_ndp(struct ieee80211_hw *hw)
|
|
||||||
|
|
||||||
if (sizeof(struct pcie_tx_ctrl_ndp) >
|
|
||||||
sizeof(tx_info->status.status_driver_data)) {
|
|
||||||
- wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n",
|
|
||||||
+ wiphy_err(hw->wiphy, "driver data is not enough: %zu (%zu)\n",
|
|
||||||
sizeof(struct pcie_tx_ctrl_ndp),
|
|
||||||
sizeof(tx_info->status.status_driver_data));
|
|
||||||
return -ENOMEM;
|
|
||||||
--
|
|
||||||
2.39.2
|
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ Signed-off-by: Robert Marko <robert.marko@sartura.hr>
|
|||||||
|
|
||||||
--- a/hif/pcie/pcie.c
|
--- a/hif/pcie/pcie.c
|
||||||
+++ b/hif/pcie/pcie.c
|
+++ b/hif/pcie/pcie.c
|
||||||
@@ -573,7 +573,8 @@ static struct device_node *pcie_get_devi
|
@@ -685,7 +685,8 @@ static struct device_node *pcie_get_devi
|
||||||
struct device_node *dev_node;
|
struct device_node *dev_node;
|
||||||
|
|
||||||
dev_node = pci_bus_to_OF_node(pcie_priv->pdev->bus);
|
dev_node = pci_bus_to_OF_node(pcie_priv->pdev->bus);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/core.c
|
--- a/core.c
|
||||||
+++ b/core.c
|
+++ b/core.c
|
||||||
@@ -706,7 +706,7 @@ static void mwl_chnl_switch_event(struct
|
@@ -718,7 +718,7 @@ static void mwl_chnl_switch_event(struct
|
||||||
vif = container_of((void *)mwl_vif, struct ieee80211_vif,
|
vif = container_of((void *)mwl_vif, struct ieee80211_vif,
|
||||||
drv_priv);
|
drv_priv);
|
||||||
|
|
||||||
@ -11,7 +11,7 @@
|
|||||||
spin_unlock_bh(&priv->vif_lock);
|
spin_unlock_bh(&priv->vif_lock);
|
||||||
--- a/debugfs.c
|
--- a/debugfs.c
|
||||||
+++ b/debugfs.c
|
+++ b/debugfs.c
|
||||||
@@ -455,9 +455,9 @@ static ssize_t mwl_debugfs_vif_read(stru
|
@@ -498,9 +498,9 @@ static ssize_t mwl_debugfs_vif_read(stru
|
||||||
switch (vif->type) {
|
switch (vif->type) {
|
||||||
case NL80211_IFTYPE_AP:
|
case NL80211_IFTYPE_AP:
|
||||||
len += scnprintf(p + len, size - len, "type: ap\n");
|
len += scnprintf(p + len, size - len, "type: ap\n");
|
||||||
@ -24,7 +24,7 @@
|
|||||||
len += scnprintf(p + len, size - len,
|
len += scnprintf(p + len, size - len,
|
||||||
"ssid: %s\n", ssid);
|
"ssid: %s\n", ssid);
|
||||||
len += scnprintf(p + len, size - len,
|
len += scnprintf(p + len, size - len,
|
||||||
@@ -479,8 +479,8 @@ static ssize_t mwl_debugfs_vif_read(stru
|
@@ -522,8 +522,8 @@ static ssize_t mwl_debugfs_vif_read(stru
|
||||||
"type: unknown\n");
|
"type: unknown\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -35,62 +35,58 @@
|
|||||||
len += scnprintf(p + len, size - len,
|
len += scnprintf(p + len, size - len,
|
||||||
"channel: %d: width: %d\n",
|
"channel: %d: width: %d\n",
|
||||||
chan_def->chan->hw_value,
|
chan_def->chan->hw_value,
|
||||||
@@ -564,28 +564,28 @@ static ssize_t mwl_debugfs_sta_read(stru
|
@@ -596,18 +596,18 @@ static ssize_t mwl_debugfs_sta_read(stru
|
||||||
"amsdu cap: 0x%02x\n",
|
sta_info->wds ? "true" : "false",
|
||||||
sta_info->amsdu_ctrl.cap);
|
sta_info->ba_hist.enable ? "enable" : "disable",
|
||||||
}
|
sta_info->is_amsdu_allowed ? sta_info->amsdu_ctrl.cap : 0 ,
|
||||||
- if (sta->ht_cap.ht_supported) {
|
- sta->ht_cap.ht_supported ? sta->ht_cap.cap : 0,
|
||||||
+ if (sta->deflink.ht_cap.ht_supported) {
|
- sta->ht_cap.ht_supported ? sta->ht_cap.ampdu_factor : 0,
|
||||||
len += scnprintf(p + len, size - len,
|
- sta->ht_cap.ht_supported ? sta->ht_cap.ampdu_density : 0,
|
||||||
"ht_cap: 0x%04x, ampdu: %02x, %02x\n",
|
- sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[0] : 0,
|
||||||
- sta->ht_cap.cap,
|
- sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[1] : 0,
|
||||||
- sta->ht_cap.ampdu_factor,
|
- sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[2] : 0,
|
||||||
- sta->ht_cap.ampdu_density);
|
- sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[3] : 0,
|
||||||
+ sta->deflink.ht_cap.cap,
|
- sta->vht_cap.vht_supported ? sta->vht_cap.cap : 0,
|
||||||
+ sta->deflink.ht_cap.ampdu_factor,
|
- sta->vht_cap.vht_supported ? sta->vht_cap.vht_mcs.rx_mcs_map : 0,
|
||||||
+ sta->deflink.ht_cap.ampdu_density);
|
- sta->vht_cap.vht_supported ? sta->vht_cap.vht_mcs.tx_mcs_map : 0,
|
||||||
len += scnprintf(p + len, size - len,
|
- sta->bandwidth,
|
||||||
"rx_mask: 0x%02x, %02x, %02x, %02x\n",
|
- sta->rx_nss,
|
||||||
- sta->ht_cap.mcs.rx_mask[0],
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.cap : 0,
|
||||||
- sta->ht_cap.mcs.rx_mask[1],
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.ampdu_factor : 0,
|
||||||
- sta->ht_cap.mcs.rx_mask[2],
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.ampdu_density : 0,
|
||||||
- sta->ht_cap.mcs.rx_mask[3]);
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[0] : 0,
|
||||||
+ sta->deflink.ht_cap.mcs.rx_mask[0],
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[1] : 0,
|
||||||
+ sta->deflink.ht_cap.mcs.rx_mask[1],
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[2] : 0,
|
||||||
+ sta->deflink.ht_cap.mcs.rx_mask[2],
|
+ sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[3] : 0,
|
||||||
+ sta->deflink.ht_cap.mcs.rx_mask[3]);
|
+ sta->deflink.vht_cap.vht_supported ? sta->deflink.vht_cap.cap : 0,
|
||||||
}
|
+ sta->deflink.vht_cap.vht_supported ? sta->deflink.vht_cap.vht_mcs.rx_mcs_map : 0,
|
||||||
- if (sta->vht_cap.vht_supported) {
|
+ sta->deflink.vht_cap.vht_supported ? sta->deflink.vht_cap.vht_mcs.tx_mcs_map : 0,
|
||||||
+ if (sta->deflink.vht_cap.vht_supported) {
|
+ sta->deflink.bandwidth,
|
||||||
len += scnprintf(p + len, size - len,
|
+ sta->deflink.rx_nss,
|
||||||
"vht_cap: 0x%08x, mcs: %02x, %02x\n",
|
sta->tdls,
|
||||||
- sta->vht_cap.cap,
|
sta->tdls_initiator,
|
||||||
- sta->vht_cap.vht_mcs.rx_mcs_map,
|
sta->wme,
|
||||||
- sta->vht_cap.vht_mcs.tx_mcs_map);
|
|
||||||
+ sta->deflink.vht_cap.cap,
|
|
||||||
+ sta->deflink.vht_cap.vht_mcs.rx_mcs_map,
|
|
||||||
+ sta->deflink.vht_cap.vht_mcs.tx_mcs_map);
|
|
||||||
}
|
|
||||||
len += scnprintf(p + len, size - len, "rx_bw: %d, rx_nss: %d\n",
|
|
||||||
- sta->bandwidth, sta->rx_nss);
|
|
||||||
+ sta->deflink.bandwidth, sta->deflink.rx_nss);
|
|
||||||
len += scnprintf(p + len, size - len,
|
|
||||||
"tdls: %d, tdls_init: %d\n",
|
|
||||||
sta->tdls, sta->tdls_initiator);
|
|
||||||
--- a/hif/fwcmd.c
|
--- a/hif/fwcmd.c
|
||||||
+++ b/hif/fwcmd.c
|
+++ b/hif/fwcmd.c
|
||||||
@@ -634,8 +634,9 @@ einval:
|
@@ -633,11 +633,15 @@ einval:
|
||||||
|
}
|
||||||
|
|
||||||
static int mwl_fwcmd_set_ap_beacon(struct mwl_priv *priv,
|
static int mwl_fwcmd_set_ap_beacon(struct mwl_priv *priv,
|
||||||
struct mwl_vif *mwl_vif,
|
- struct mwl_vif *mwl_vif,
|
||||||
- struct ieee80211_bss_conf *bss_conf)
|
- struct ieee80211_bss_conf *bss_conf)
|
||||||
+ struct ieee80211_vif *vif)
|
+ struct ieee80211_vif *vif)
|
||||||
{
|
{
|
||||||
+ struct ieee80211_bss_conf *bss_conf = &vif->bss_conf;
|
|
||||||
struct hostcmd_cmd_ap_beacon *pcmd;
|
struct hostcmd_cmd_ap_beacon *pcmd;
|
||||||
struct ds_params *phy_ds_param_set;
|
struct ds_params *phy_ds_param_set;
|
||||||
|
+ struct mwl_vif *mwl_vif;
|
||||||
|
+ struct ieee80211_bss_conf *bss_conf;
|
||||||
|
+
|
||||||
|
+ mwl_vif = mwl_dev_get_vif(vif);
|
||||||
|
+ bss_conf = &vif->bss_conf;
|
||||||
|
|
||||||
@@ -664,7 +665,7 @@ static int mwl_fwcmd_set_ap_beacon(struc
|
/* wmm structure of start command is defined less one byte,
|
||||||
|
* due to following field country is not used, add byte one
|
||||||
|
@@ -664,7 +668,7 @@ static int mwl_fwcmd_set_ap_beacon(struc
|
||||||
pcmd->cmd_hdr.macid = mwl_vif->macid;
|
pcmd->cmd_hdr.macid = mwl_vif->macid;
|
||||||
|
|
||||||
ether_addr_copy(pcmd->start_cmd.sta_mac_addr, mwl_vif->bssid);
|
ether_addr_copy(pcmd->start_cmd.sta_mac_addr, mwl_vif->bssid);
|
||||||
@ -99,16 +95,16 @@
|
|||||||
if (priv->chip_type == MWL8997)
|
if (priv->chip_type == MWL8997)
|
||||||
ether_addr_copy(pcmd->start_cmd.bssid, mwl_vif->bssid);
|
ether_addr_copy(pcmd->start_cmd.bssid, mwl_vif->bssid);
|
||||||
pcmd->start_cmd.bss_type = 1;
|
pcmd->start_cmd.bss_type = 1;
|
||||||
@@ -2091,7 +2092,7 @@ int mwl_fwcmd_set_beacon(struct ieee8021
|
@@ -2090,7 +2094,7 @@ int mwl_fwcmd_set_beacon(struct ieee8021
|
||||||
if (mwl_fwcmd_set_wsc_ie(hw, b_inf->ie_wsc_len, b_inf->ie_wsc_ptr))
|
if (mwl_fwcmd_set_wsc_ie(hw, b_inf->ie_wsc_len, b_inf->ie_wsc_ptr))
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
- if (mwl_fwcmd_set_ap_beacon(priv, mwl_vif, &vif->bss_conf))
|
- if (mwl_fwcmd_set_ap_beacon(priv, mwl_vif, &vif->bss_conf))
|
||||||
+ if (mwl_fwcmd_set_ap_beacon(priv, mwl_vif, vif))
|
+ if (mwl_fwcmd_set_ap_beacon(priv, vif))
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
if (b_inf->cap_info & WLAN_CAPABILITY_SPECTRUM_MGMT)
|
if (b_inf->cap_info & WLAN_CAPABILITY_SPECTRUM_MGMT)
|
||||||
@@ -2153,38 +2154,38 @@ int mwl_fwcmd_set_new_stn_add(struct iee
|
@@ -2152,38 +2156,38 @@ int mwl_fwcmd_set_new_stn_add(struct iee
|
||||||
ether_addr_copy(pcmd->mac_addr, sta->addr);
|
ether_addr_copy(pcmd->mac_addr, sta->addr);
|
||||||
|
|
||||||
if (hw->conf.chandef.chan->band == NL80211_BAND_2GHZ)
|
if (hw->conf.chandef.chan->band == NL80211_BAND_2GHZ)
|
||||||
@ -161,7 +157,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
pcmd->is_qos_sta = sta->wme;
|
pcmd->is_qos_sta = sta->wme;
|
||||||
@@ -2240,38 +2241,38 @@ int mwl_fwcmd_set_new_stn_add_sc4(struct
|
@@ -2239,38 +2243,38 @@ int mwl_fwcmd_set_new_stn_add_sc4(struct
|
||||||
ether_addr_copy(pcmd->mac_addr, sta->addr);
|
ether_addr_copy(pcmd->mac_addr, sta->addr);
|
||||||
|
|
||||||
if (hw->conf.chandef.chan->band == NL80211_BAND_2GHZ)
|
if (hw->conf.chandef.chan->band == NL80211_BAND_2GHZ)
|
||||||
@ -214,7 +210,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
pcmd->is_qos_sta = sta->wme;
|
pcmd->is_qos_sta = sta->wme;
|
||||||
@@ -2788,9 +2789,9 @@ int mwl_fwcmd_create_ba(struct ieee80211
|
@@ -2787,9 +2791,9 @@ int mwl_fwcmd_create_ba(struct ieee80211
|
||||||
pcmd->ba_info.create_params.flags = cpu_to_le32(ba_flags);
|
pcmd->ba_info.create_params.flags = cpu_to_le32(ba_flags);
|
||||||
pcmd->ba_info.create_params.queue_id = stream->idx;
|
pcmd->ba_info.create_params.queue_id = stream->idx;
|
||||||
pcmd->ba_info.create_params.param_info =
|
pcmd->ba_info.create_params.param_info =
|
||||||
@ -226,7 +222,7 @@
|
|||||||
IEEE80211_HT_AMPDU_PARM_DENSITY);
|
IEEE80211_HT_AMPDU_PARM_DENSITY);
|
||||||
if (direction == BA_FLAG_DIRECTION_UP) {
|
if (direction == BA_FLAG_DIRECTION_UP) {
|
||||||
pcmd->ba_info.create_params.reset_seq_no = 0;
|
pcmd->ba_info.create_params.reset_seq_no = 0;
|
||||||
@@ -2800,9 +2801,9 @@ int mwl_fwcmd_create_ba(struct ieee80211
|
@@ -2799,9 +2803,9 @@ int mwl_fwcmd_create_ba(struct ieee80211
|
||||||
pcmd->ba_info.create_params.current_seq = cpu_to_le16(0);
|
pcmd->ba_info.create_params.current_seq = cpu_to_le16(0);
|
||||||
}
|
}
|
||||||
if (priv->chip_type == MWL8964 &&
|
if (priv->chip_type == MWL8964 &&
|
||||||
@ -238,9 +234,51 @@
|
|||||||
IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >>
|
IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >>
|
||||||
IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT);
|
IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT);
|
||||||
}
|
}
|
||||||
|
--- a/hif/pcie/8864/tx.c
|
||||||
|
+++ b/hif/pcie/8864/tx.c
|
||||||
|
@@ -743,7 +743,7 @@ void pcie_8864_tx_xmit(struct ieee80211_
|
||||||
|
index = SYSADPT_TX_WMM_QUEUES - index - 1;
|
||||||
|
txpriority = index;
|
||||||
|
|
||||||
|
- if (sta && sta->ht_cap.ht_supported &&
|
||||||
|
+ if (sta && sta->deflink.ht_cap.ht_supported &&
|
||||||
|
!(xmitcontrol & EAGLE_TXD_XMITCTRL_USE_MC_RATE) &&
|
||||||
|
ieee80211_is_data_qos(wh->frame_control)) {
|
||||||
|
tid = qos & 0xf;
|
||||||
|
--- a/hif/pcie/8964/tx_ndp.c
|
||||||
|
+++ b/hif/pcie/8964/tx_ndp.c
|
||||||
|
@@ -607,7 +607,7 @@ void pcie_tx_xmit_ndp(struct ieee80211_h
|
||||||
|
pcie_tx_encapsulate_frame(priv, skb, k_conf);
|
||||||
|
} else {
|
||||||
|
tid = qos & 0x7;
|
||||||
|
- if (sta && sta->ht_cap.ht_supported && !eapol_frame &&
|
||||||
|
+ if (sta && sta->deflink.ht_cap.ht_supported && !eapol_frame &&
|
||||||
|
qos != 0xFFFF) {
|
||||||
|
pcie_tx_count_packet(sta, tid);
|
||||||
|
spin_lock_bh(&priv->stream_lock);
|
||||||
|
--- a/hif/pcie/8997/tx.c
|
||||||
|
+++ b/hif/pcie/8997/tx.c
|
||||||
|
@@ -81,7 +81,7 @@ static int pcie_txbd_ring_create(struct
|
||||||
|
wiphy_info(priv->hw->wiphy,
|
||||||
|
"TX ring: - base: %p, pbase: 0x%x, len: %d\n",
|
||||||
|
pcie_priv->txbd_ring_vbase,
|
||||||
|
- pcie_priv->txbd_ring_pbase,
|
||||||
|
+ (u32)pcie_priv->txbd_ring_pbase,
|
||||||
|
pcie_priv->txbd_ring_size);
|
||||||
|
|
||||||
|
for (num = 0; num < PCIE_MAX_TXRX_BD; num++) {
|
||||||
|
@@ -694,7 +694,7 @@ void pcie_8997_tx_xmit(struct ieee80211_
|
||||||
|
index = SYSADPT_TX_WMM_QUEUES - index - 1;
|
||||||
|
txpriority = index;
|
||||||
|
|
||||||
|
- if (sta && sta->ht_cap.ht_supported &&
|
||||||
|
+ if (sta && sta->deflink.ht_cap.ht_supported &&
|
||||||
|
!(xmitcontrol & EAGLE_TXD_XMITCTRL_USE_MC_RATE) &&
|
||||||
|
ieee80211_is_data_qos(wh->frame_control)) {
|
||||||
|
tid = qos & 0xf;
|
||||||
--- a/mac80211.c
|
--- a/mac80211.c
|
||||||
+++ b/mac80211.c
|
+++ b/mac80211.c
|
||||||
@@ -371,15 +371,15 @@ static void mwl_mac80211_bss_info_change
|
@@ -368,15 +368,15 @@ static void mwl_mac80211_bss_info_change
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -259,7 +297,7 @@
|
|||||||
{
|
{
|
||||||
struct mwl_priv *priv = hw->priv;
|
struct mwl_priv *priv = hw->priv;
|
||||||
struct mwl_vif *mwl_vif;
|
struct mwl_vif *mwl_vif;
|
||||||
@@ -429,8 +429,8 @@ static void mwl_mac80211_bss_info_change
|
@@ -426,8 +426,8 @@ static void mwl_mac80211_bss_info_change
|
||||||
if (changed & (BSS_CHANGED_BEACON_INT | BSS_CHANGED_BEACON)) {
|
if (changed & (BSS_CHANGED_BEACON_INT | BSS_CHANGED_BEACON)) {
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
|
|
||||||
@ -270,7 +308,7 @@
|
|||||||
(!info->hidden_ssid)) {
|
(!info->hidden_ssid)) {
|
||||||
if (mwl_vif->broadcast_ssid != true) {
|
if (mwl_vif->broadcast_ssid != true) {
|
||||||
mwl_fwcmd_broadcast_ssid_enable(hw, vif, true);
|
mwl_fwcmd_broadcast_ssid_enable(hw, vif, true);
|
||||||
@@ -444,7 +444,7 @@ static void mwl_mac80211_bss_info_change
|
@@ -441,7 +441,7 @@ static void mwl_mac80211_bss_info_change
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mwl_vif->set_beacon) {
|
if (!mwl_vif->set_beacon) {
|
||||||
@ -279,7 +317,7 @@
|
|||||||
|
|
||||||
if (skb) {
|
if (skb) {
|
||||||
mwl_fwcmd_set_beacon(hw, vif, skb->data, skb->len);
|
mwl_fwcmd_set_beacon(hw, vif, skb->data, skb->len);
|
||||||
@@ -461,7 +461,7 @@ static void mwl_mac80211_bss_info_change
|
@@ -458,7 +458,7 @@ static void mwl_mac80211_bss_info_change
|
||||||
static void mwl_mac80211_bss_info_changed(struct ieee80211_hw *hw,
|
static void mwl_mac80211_bss_info_changed(struct ieee80211_hw *hw,
|
||||||
struct ieee80211_vif *vif,
|
struct ieee80211_vif *vif,
|
||||||
struct ieee80211_bss_conf *info,
|
struct ieee80211_bss_conf *info,
|
||||||
@ -288,7 +326,7 @@
|
|||||||
{
|
{
|
||||||
switch (vif->type) {
|
switch (vif->type) {
|
||||||
case NL80211_IFTYPE_AP:
|
case NL80211_IFTYPE_AP:
|
||||||
@@ -584,10 +584,10 @@ static int mwl_mac80211_sta_add(struct i
|
@@ -583,10 +583,10 @@ static int mwl_mac80211_sta_add(struct i
|
||||||
if (vif->type == NL80211_IFTYPE_MESH_POINT)
|
if (vif->type == NL80211_IFTYPE_MESH_POINT)
|
||||||
sta_info->is_mesh_node = true;
|
sta_info->is_mesh_node = true;
|
||||||
|
|
||||||
@ -296,12 +334,12 @@
|
|||||||
+ if (sta->deflink.ht_cap.ht_supported) {
|
+ if (sta->deflink.ht_cap.ht_supported) {
|
||||||
sta_info->is_ampdu_allowed = true;
|
sta_info->is_ampdu_allowed = true;
|
||||||
sta_info->is_amsdu_allowed = false;
|
sta_info->is_amsdu_allowed = false;
|
||||||
- if (sta->ht_cap.cap & IEEE80211_HT_CAP_MAX_AMSDU)
|
- if (sta->ht_cap.cap & IEEE80211_HT_CAP_MAX_AMSDU) {
|
||||||
+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_MAX_AMSDU)
|
+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_MAX_AMSDU) {
|
||||||
sta_info->amsdu_ctrl.cap = MWL_AMSDU_SIZE_8K;
|
sta_info->amsdu_ctrl.cap = MWL_AMSDU_SIZE_8K;
|
||||||
else
|
sta_info->amsdu_ctrl.amsdu_allow_size = SYSADPT_AMSDU_8K_MAX_SIZE;
|
||||||
sta_info->amsdu_ctrl.cap = MWL_AMSDU_SIZE_4K;
|
}
|
||||||
@@ -669,7 +669,7 @@ static int mwl_mac80211_sta_remove(struc
|
@@ -670,7 +670,7 @@ static int mwl_mac80211_sta_remove(struc
|
||||||
|
|
||||||
static int mwl_mac80211_conf_tx(struct ieee80211_hw *hw,
|
static int mwl_mac80211_conf_tx(struct ieee80211_hw *hw,
|
||||||
struct ieee80211_vif *vif,
|
struct ieee80211_vif *vif,
|
||||||
@ -310,7 +348,7 @@
|
|||||||
const struct ieee80211_tx_queue_params *params)
|
const struct ieee80211_tx_queue_params *params)
|
||||||
{
|
{
|
||||||
struct mwl_priv *priv = hw->priv;
|
struct mwl_priv *priv = hw->priv;
|
||||||
@@ -928,4 +928,5 @@ const struct ieee80211_ops mwl_mac80211_
|
@@ -934,4 +934,5 @@ const struct ieee80211_ops mwl_mac80211_
|
||||||
.pre_channel_switch = mwl_mac80211_chnl_switch,
|
.pre_channel_switch = mwl_mac80211_chnl_switch,
|
||||||
.sw_scan_start = mwl_mac80211_sw_scan_start,
|
.sw_scan_start = mwl_mac80211_sw_scan_start,
|
||||||
.sw_scan_complete = mwl_mac80211_sw_scan_complete,
|
.sw_scan_complete = mwl_mac80211_sw_scan_complete,
|
||||||
@ -360,34 +398,3 @@
|
|||||||
|
|
||||||
switch (format) {
|
switch (format) {
|
||||||
case TX_RATE_FORMAT_LEGACY:
|
case TX_RATE_FORMAT_LEGACY:
|
||||||
--- a/hif/pcie/tx.c
|
|
||||||
+++ b/hif/pcie/tx.c
|
|
||||||
@@ -153,7 +153,7 @@ static int pcie_txbd_ring_create(struct
|
|
||||||
wiphy_info(priv->hw->wiphy,
|
|
||||||
"TX ring: - base: %p, pbase: 0x%x, len: %d\n",
|
|
||||||
pcie_priv->txbd_ring_vbase,
|
|
||||||
- pcie_priv->txbd_ring_pbase,
|
|
||||||
+ (u32)pcie_priv->txbd_ring_pbase,
|
|
||||||
pcie_priv->txbd_ring_size);
|
|
||||||
|
|
||||||
for (num = 0; num < PCIE_MAX_TXRX_BD; num++) {
|
|
||||||
@@ -1091,7 +1091,7 @@ void pcie_tx_xmit(struct ieee80211_hw *h
|
|
||||||
index = SYSADPT_TX_WMM_QUEUES - index - 1;
|
|
||||||
txpriority = index;
|
|
||||||
|
|
||||||
- if (sta && sta->ht_cap.ht_supported && !eapol_frame &&
|
|
||||||
+ if (sta && sta->deflink.ht_cap.ht_supported && !eapol_frame &&
|
|
||||||
ieee80211_is_data_qos(wh->frame_control)) {
|
|
||||||
tid = qos & 0xf;
|
|
||||||
pcie_tx_count_packet(sta, tid);
|
|
||||||
--- a/hif/pcie/tx_ndp.c
|
|
||||||
+++ b/hif/pcie/tx_ndp.c
|
|
||||||
@@ -602,7 +602,7 @@ void pcie_tx_xmit_ndp(struct ieee80211_h
|
|
||||||
pcie_tx_encapsulate_frame(priv, skb, k_conf, NULL);
|
|
||||||
} else {
|
|
||||||
tid = qos & 0x7;
|
|
||||||
- if (sta && sta->ht_cap.ht_supported && !eapol_frame &&
|
|
||||||
+ if (sta && sta->deflink.ht_cap.ht_supported && !eapol_frame &&
|
|
||||||
qos != 0xFFFF) {
|
|
||||||
pcie_tx_count_packet(sta, tid);
|
|
||||||
spin_lock_bh(&priv->stream_lock);
|
|
||||||
|
@ -0,0 +1,51 @@
|
|||||||
|
From ad911365cac3723d1c00d048905a5e22ff4a10f3 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Stefan Kalscheuer <stefan@stklcode.de>
|
||||||
|
Date: Sun, 18 Jun 2023 17:53:27 +0200
|
||||||
|
Subject: [PATCH 1/2] remove uaccess and get_fs calls from PCIe for Kenel >=
|
||||||
|
5.18
|
||||||
|
|
||||||
|
Remove the calls to deprecated get_fs and force_uaccess_* API for modern
|
||||||
|
kernels.
|
||||||
|
|
||||||
|
The get_fs functionality and the transitional force_uaccess_* calls have
|
||||||
|
been removed Kernel 5.18 [1] while read and write operations have been
|
||||||
|
refactored, so the code can work on kernel- and userspace data without
|
||||||
|
the need to shifting the boundary using set_fs().
|
||||||
|
|
||||||
|
[1] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=967747bbc084b93b54e66f9047d342232314cd25
|
||||||
|
|
||||||
|
Signed-off-by: Stefan Kalscheuer <stefan@stklcode.de>
|
||||||
|
---
|
||||||
|
hif/pcie/pcie.c | 6 ++++--
|
||||||
|
1 file changed, 4 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
--- a/hif/pcie/pcie.c
|
||||||
|
+++ b/hif/pcie/pcie.c
|
||||||
|
@@ -1439,7 +1439,9 @@ static void pcie_bf_mimo_ctrl_decode(str
|
||||||
|
const char filename[] = "/tmp/BF_MIMO_Ctrl_Field_Output.txt";
|
||||||
|
char str_buf[256];
|
||||||
|
char *buf = &str_buf[0];
|
||||||
|
+#if LINUX_VERSION_CODE < KERNEL_VERSION(5,18,0)
|
||||||
|
mm_segment_t oldfs;
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(5,0,0)
|
||||||
|
oldfs = get_fs();
|
||||||
|
@@ -1447,7 +1449,7 @@ static void pcie_bf_mimo_ctrl_decode(str
|
||||||
|
#elif LINUX_VERSION_CODE < KERNEL_VERSION(5,10,0)
|
||||||
|
oldfs = get_fs();
|
||||||
|
set_fs(KERNEL_DS);
|
||||||
|
-#else
|
||||||
|
+#elif LINUX_VERSION_CODE < KERNEL_VERSION(5,18,0)
|
||||||
|
oldfs = force_uaccess_begin();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@@ -1471,7 +1473,7 @@ static void pcie_bf_mimo_ctrl_decode(str
|
||||||
|
|
||||||
|
#if LINUX_VERSION_CODE < KERNEL_VERSION(5,10,0)
|
||||||
|
set_fs(oldfs);
|
||||||
|
-#else
|
||||||
|
+#elif LINUX_VERSION_CODE < KERNEL_VERSION(5,18,0)
|
||||||
|
force_uaccess_end(oldfs);
|
||||||
|
#endif
|
||||||
|
}
|
@ -0,0 +1,352 @@
|
|||||||
|
From 61c75dce424c180b633c64613a1948df5a41cf1e Mon Sep 17 00:00:00 2001
|
||||||
|
From: Stefan Kalscheuer <stefan@stklcode.de>
|
||||||
|
Date: Sun, 18 Jun 2023 17:59:07 +0200
|
||||||
|
Subject: [PATCH 2/2] replace usage of the deprecated "pci-dma-compat.h" API
|
||||||
|
|
||||||
|
The pci-dma-compat API has been legacy for quite a while and was removed
|
||||||
|
with 5.18 [1]. Migrate all calls, so the module can be compiled against
|
||||||
|
modern kernel versions.
|
||||||
|
|
||||||
|
Replace some compat calls:
|
||||||
|
* pci_set_dma_mask with dma_set_mask
|
||||||
|
* pci_(un)map_single with dma_(un)map_single
|
||||||
|
* pci_dma_mapping_error with dma_mapping_error
|
||||||
|
* PCI_DMA_{FROM,TO}DEVICE with DMA_{FOM,TO}_DEVICE
|
||||||
|
|
||||||
|
[1] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=7968778914e53788a01c2dee2692cab157de9ac0
|
||||||
|
|
||||||
|
Signed-off-by: Stefan Kalscheuer <stefan@stklcode.de>
|
||||||
|
---
|
||||||
|
hif/pcie/pcie.c | 2 +-
|
||||||
|
hif/pcie/rx.c | 20 ++++++++++----------
|
||||||
|
hif/pcie/rx_ndp.c | 20 ++++++++++----------
|
||||||
|
hif/pcie/tx.c | 22 +++++++++++-----------
|
||||||
|
hif/pcie/tx_ndp.c | 14 +++++++-------
|
||||||
|
5 files changed, 39 insertions(+), 39 deletions(-)
|
||||||
|
|
||||||
|
--- a/hif/pcie/pcie.c
|
||||||
|
+++ b/hif/pcie/pcie.c
|
||||||
|
@@ -1701,7 +1701,7 @@ static int pcie_probe(struct pci_dev *pd
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
- rc = pci_set_dma_mask(pdev, DMA_BIT_MASK(32));
|
||||||
|
+ rc = dma_set_mask(&pdev->dev, DMA_BIT_MASK(32));
|
||||||
|
if (rc) {
|
||||||
|
pr_err("%s: 32-bit PCI DMA not supported\n",
|
||||||
|
PCIE_DRV_NAME);
|
||||||
|
--- a/hif/pcie/8864/rx.c
|
||||||
|
+++ b/hif/pcie/8864/rx.c
|
||||||
|
@@ -107,11 +107,11 @@ static int pcie_rx_ring_init(struct mwl_
|
||||||
|
desc->prx_ring[i].rssi = 0x00;
|
||||||
|
desc->prx_ring[i].pkt_len =
|
||||||
|
cpu_to_le16(SYSADPT_MAX_AGGR_SIZE);
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev,
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev,
|
||||||
|
rx_hndl->psk_buff->data,
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
return -ENOMEM;
|
||||||
|
@@ -153,11 +153,11 @@ static void pcie_rx_ring_cleanup(struct
|
||||||
|
if (!rx_hndl->psk_buff)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu
|
||||||
|
(rx_hndl->pdesc->pphys_buff_data),
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
|
||||||
|
dev_kfree_skb_any(rx_hndl->psk_buff);
|
||||||
|
|
||||||
|
@@ -332,11 +332,11 @@ static inline int pcie_rx_refill(struct
|
||||||
|
rx_hndl->pdesc->rssi = 0x00;
|
||||||
|
rx_hndl->pdesc->pkt_len = cpu_to_le16(desc->rx_buf_size);
|
||||||
|
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev,
|
||||||
|
+ dma = dma_map_single(&pcie_priv->pdev->dev,
|
||||||
|
rx_hndl->psk_buff->data,
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
dev_kfree_skb_any(rx_hndl->psk_buff);
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
@@ -410,10 +410,10 @@ void pcie_8864_rx_recv(unsigned long dat
|
||||||
|
prx_skb = curr_hndl->psk_buff;
|
||||||
|
if (!prx_skb)
|
||||||
|
goto out;
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(curr_hndl->pdesc->pphys_buff_data),
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
pkt_len = le16_to_cpu(curr_hndl->pdesc->pkt_len);
|
||||||
|
|
||||||
|
if (skb_tailroom(prx_skb) < pkt_len) {
|
||||||
|
--- a/hif/pcie/8864/tx.c
|
||||||
|
+++ b/hif/pcie/8864/tx.c
|
||||||
|
@@ -171,11 +171,11 @@ static void pcie_tx_ring_cleanup(struct
|
||||||
|
desc->tx_hndl[i].psk_buff->data,
|
||||||
|
le32_to_cpu(
|
||||||
|
desc->ptx_ring[i].pkt_ptr));
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(
|
||||||
|
desc->ptx_ring[i].pkt_ptr),
|
||||||
|
desc->tx_hndl[i].psk_buff->len,
|
||||||
|
- PCI_DMA_TODEVICE);
|
||||||
|
+ DMA_TO_DEVICE);
|
||||||
|
dev_kfree_skb_any(desc->tx_hndl[i].psk_buff);
|
||||||
|
desc->ptx_ring[i].status =
|
||||||
|
cpu_to_le32(EAGLE_TXD_STATUS_IDLE);
|
||||||
|
@@ -291,9 +291,9 @@ static inline void pcie_tx_skb(struct mw
|
||||||
|
tx_desc->type = tx_ctrl->type;
|
||||||
|
tx_desc->xmit_control = tx_ctrl->xmit_control;
|
||||||
|
tx_desc->sap_pkt_info = 0;
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev, tx_skb->data,
|
||||||
|
- tx_skb->len, PCI_DMA_TODEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev, tx_skb->data,
|
||||||
|
+ tx_skb->len, DMA_TO_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
dev_kfree_skb_any(tx_skb);
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
@@ -447,10 +447,10 @@ static void pcie_non_pfu_tx_done(struct
|
||||||
|
(tx_desc->status & cpu_to_le32(EAGLE_TXD_STATUS_OK)) &&
|
||||||
|
(!(tx_desc->status &
|
||||||
|
cpu_to_le32(EAGLE_TXD_STATUS_FW_OWNED)))) {
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(tx_desc->pkt_ptr),
|
||||||
|
le16_to_cpu(tx_desc->pkt_len),
|
||||||
|
- PCI_DMA_TODEVICE);
|
||||||
|
+ DMA_TO_DEVICE);
|
||||||
|
done_skb = tx_hndl->psk_buff;
|
||||||
|
rate = le32_to_cpu(tx_desc->rate_info);
|
||||||
|
tx_desc->pkt_ptr = 0;
|
||||||
|
@@ -925,4 +925,4 @@ void pcie_8864_tx_del_sta_amsdu_pkts(str
|
||||||
|
}
|
||||||
|
}
|
||||||
|
spin_unlock_bh(&sta_info->amsdu_lock);
|
||||||
|
-}
|
||||||
|
\ No newline at end of file
|
||||||
|
+}
|
||||||
|
--- a/hif/pcie/8964/rx_ndp.c
|
||||||
|
+++ b/hif/pcie/8964/rx_ndp.c
|
||||||
|
@@ -86,11 +86,11 @@ static int pcie_rx_ring_init_ndp(struct
|
||||||
|
}
|
||||||
|
skb_reserve(psk_buff, MIN_BYTES_RX_HEADROOM);
|
||||||
|
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev,
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev,
|
||||||
|
psk_buff->data,
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
return -ENOMEM;
|
||||||
|
@@ -120,11 +120,11 @@ static void pcie_rx_ring_cleanup_ndp(str
|
||||||
|
if (desc->prx_ring) {
|
||||||
|
for (i = 0; i < MAX_NUM_RX_DESC; i++) {
|
||||||
|
if (desc->rx_vbuflist[i]) {
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(
|
||||||
|
desc->prx_ring[i].data),
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
desc->rx_vbuflist[i] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -411,11 +411,11 @@ static inline int pcie_rx_refill_ndp(str
|
||||||
|
return -ENOMEM;
|
||||||
|
skb_reserve(psk_buff, MIN_BYTES_RX_HEADROOM);
|
||||||
|
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev,
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev,
|
||||||
|
psk_buff->data,
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"refill: failed to map pci memory!\n");
|
||||||
|
return -ENOMEM;
|
||||||
|
@@ -520,10 +520,10 @@ recheck:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(prx_desc->data),
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
|
||||||
|
bad_mic = false;
|
||||||
|
ctrl = le32_to_cpu(prx_ring_done->ctrl);
|
||||||
|
--- a/hif/pcie/8964/tx_ndp.c
|
||||||
|
+++ b/hif/pcie/8964/tx_ndp.c
|
||||||
|
@@ -132,10 +132,10 @@ static void pcie_tx_ring_cleanup_ndp(str
|
||||||
|
for (i = 0; i < MAX_TX_RING_SEND_SIZE; i++) {
|
||||||
|
tx_skb = desc->tx_vbuflist[i];
|
||||||
|
if (tx_skb) {
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
desc->pphys_tx_buflist[i],
|
||||||
|
tx_skb->len,
|
||||||
|
- PCI_DMA_TODEVICE);
|
||||||
|
+ DMA_TO_DEVICE);
|
||||||
|
dev_kfree_skb_any(tx_skb);
|
||||||
|
desc->pphys_tx_buflist[i] = 0;
|
||||||
|
desc->tx_vbuflist[i] = NULL;
|
||||||
|
@@ -267,9 +267,9 @@ static inline int pcie_tx_skb_ndp(struct
|
||||||
|
(TXRING_CTRL_TAG_MGMT << TXRING_CTRL_TAG_SHIFT));
|
||||||
|
}
|
||||||
|
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev, tx_skb->data,
|
||||||
|
- tx_skb->len, PCI_DMA_TODEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev, tx_skb->data,
|
||||||
|
+ tx_skb->len, DMA_TO_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
dev_kfree_skb_any(tx_skb);
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
@@ -451,10 +451,10 @@ void pcie_tx_done_ndp(struct ieee80211_h
|
||||||
|
"buffer is NULL for tx done ring\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
desc->pphys_tx_buflist[index],
|
||||||
|
skb->len,
|
||||||
|
- PCI_DMA_TODEVICE);
|
||||||
|
+ DMA_TO_DEVICE);
|
||||||
|
desc->pphys_tx_buflist[index] = 0;
|
||||||
|
desc->tx_vbuflist[index] = NULL;
|
||||||
|
|
||||||
|
--- a/hif/pcie/8997/rx.c
|
||||||
|
+++ b/hif/pcie/8997/rx.c
|
||||||
|
@@ -107,11 +107,11 @@ static int pcie_rx_ring_init(struct mwl_
|
||||||
|
desc->prx_ring[i].rssi = 0x00;
|
||||||
|
desc->prx_ring[i].pkt_len =
|
||||||
|
cpu_to_le16(SYSADPT_MAX_AGGR_SIZE);
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev,
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev,
|
||||||
|
rx_hndl->psk_buff->data,
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
return -ENOMEM;
|
||||||
|
@@ -153,11 +153,11 @@ static void pcie_rx_ring_cleanup(struct
|
||||||
|
if (!rx_hndl->psk_buff)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu
|
||||||
|
(rx_hndl->pdesc->pphys_buff_data),
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
|
||||||
|
dev_kfree_skb_any(rx_hndl->psk_buff);
|
||||||
|
|
||||||
|
@@ -332,11 +332,11 @@ static inline int pcie_rx_refill(struct
|
||||||
|
rx_hndl->pdesc->rssi = 0x00;
|
||||||
|
rx_hndl->pdesc->pkt_len = cpu_to_le16(desc->rx_buf_size);
|
||||||
|
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev,
|
||||||
|
+ dma = dma_map_single(&pcie_priv->pdev->dev,
|
||||||
|
rx_hndl->psk_buff->data,
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
dev_kfree_skb_any(rx_hndl->psk_buff);
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
@@ -410,10 +410,10 @@ void pcie_8997_rx_recv(unsigned long dat
|
||||||
|
prx_skb = curr_hndl->psk_buff;
|
||||||
|
if (!prx_skb)
|
||||||
|
goto out;
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(curr_hndl->pdesc->pphys_buff_data),
|
||||||
|
desc->rx_buf_size,
|
||||||
|
- PCI_DMA_FROMDEVICE);
|
||||||
|
+ DMA_FROM_DEVICE);
|
||||||
|
pkt_len = le16_to_cpu(curr_hndl->pdesc->pkt_len);
|
||||||
|
|
||||||
|
if (skb_tailroom(prx_skb) < pkt_len) {
|
||||||
|
--- a/hif/pcie/8997/tx.c
|
||||||
|
+++ b/hif/pcie/8997/tx.c
|
||||||
|
@@ -139,10 +139,10 @@ static void pcie_txbd_ring_delete(struct
|
||||||
|
skb = pcie_priv->tx_buf_list[num];
|
||||||
|
tx_desc = (struct pcie_tx_desc *)skb->data;
|
||||||
|
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(tx_desc->pkt_ptr),
|
||||||
|
skb->len,
|
||||||
|
- PCI_DMA_TODEVICE);
|
||||||
|
+ DMA_TO_DEVICE);
|
||||||
|
dev_kfree_skb_any(skb);
|
||||||
|
}
|
||||||
|
pcie_priv->tx_buf_list[num] = NULL;
|
||||||
|
@@ -222,9 +222,9 @@ static inline void pcie_tx_skb(struct mw
|
||||||
|
tx_desc->type = tx_ctrl->type;
|
||||||
|
tx_desc->xmit_control = tx_ctrl->xmit_control;
|
||||||
|
tx_desc->sap_pkt_info = 0;
|
||||||
|
- dma = pci_map_single(pcie_priv->pdev, tx_skb->data,
|
||||||
|
- tx_skb->len, PCI_DMA_TODEVICE);
|
||||||
|
- if (pci_dma_mapping_error(pcie_priv->pdev, dma)) {
|
||||||
|
+ dma = dma_map_single(&(pcie_priv->pdev)->dev, tx_skb->data,
|
||||||
|
+ tx_skb->len, DMA_TO_DEVICE);
|
||||||
|
+ if (dma_mapping_error(&(pcie_priv->pdev)->dev, dma)) {
|
||||||
|
dev_kfree_skb_any(tx_skb);
|
||||||
|
wiphy_err(priv->hw->wiphy,
|
||||||
|
"failed to map pci memory!\n");
|
||||||
|
@@ -401,10 +401,10 @@ static void pcie_pfu_tx_done(struct mwl_
|
||||||
|
pfu_dma = (struct pcie_pfu_dma_data *)done_skb->data;
|
||||||
|
tx_desc = &pfu_dma->tx_desc;
|
||||||
|
dma_data = &pfu_dma->dma_data;
|
||||||
|
- pci_unmap_single(pcie_priv->pdev,
|
||||||
|
+ dma_unmap_single(&(pcie_priv->pdev)->dev,
|
||||||
|
le32_to_cpu(data_buf->paddr),
|
||||||
|
le16_to_cpu(data_buf->len),
|
||||||
|
- PCI_DMA_TODEVICE);
|
||||||
|
+ DMA_TO_DEVICE);
|
||||||
|
tx_desc->pkt_ptr = 0;
|
||||||
|
tx_desc->pkt_len = 0;
|
||||||
|
tx_desc->status = cpu_to_le32(EAGLE_TXD_STATUS_IDLE);
|
||||||
|
@@ -875,4 +875,4 @@ void pcie_8997_tx_del_sta_amsdu_pkts(str
|
||||||
|
}
|
||||||
|
}
|
||||||
|
spin_unlock_bh(&sta_info->amsdu_lock);
|
||||||
|
-}
|
||||||
|
\ No newline at end of file
|
||||||
|
+}
|
Loading…
Reference in New Issue
Block a user