forked from Openwrt-EcoNet/openwrt
Renamed 046..051 pending patches with the merged tag/hash. Two patches were skipped, they make use of WQ_BH present since v6.14:13221be720
3e3aa566dd
Manually refreshed 062-v6.14-wifi-rtw88-Add-support-for-LED-blinking.patch Manually refreshed 063-v6.14-wifi-rtw88-add-RTW88_LEDS-depends-on-LEDS_CLASS-to-K.patch Manually backported 090-v6.15-wifi-rtw88-Enable-the-new-RTL8814AE-RTL8814AU-driver.patch git log --no-merges --pretty=oneline --abbrev-commit 4c2c372de...0daa521a drivers/net/wireless/realtek/rtw88: 4c2c372de2e1 wifi: rtw88: fix the 'para' buffer size to avoid reading out of bounds f24d0d8c3cd7 wifi: rtw88: Fix the random "error beacon valid" messages for USB 80fe0bc1659c wifi: rtw88: usb: Upload the firmware in bigger chunks 490340faddea wifi: rtw88: usb: Reduce control message timeout to 500 ms b7f0cc647e52 wifi: rtw88: rtw8822bu VID/PID for BUFFALO WI-U2-866DM 2c17afde9ff6 wifi: rtw88: Handle RTL8723D(S) with blank efuse 0ffa1ba81b35 wifi: rtw88: Fix RX aggregation settings for RTL8723DS 20d3c19bd8f9 wifi: rtw88: do not ignore hardware read error during DPK fc5f5a0ec463 wifi: rtw88: sdio: call rtw_sdio_indicate_tx_status unconditionally b2effcdc2379 wifi: rtw88: sdio: map mgmt frames to queue TX_DESC_QSEL_MGMT 581cf3a9cb61 wifi: rtw88: Fix the module names printed in dmesg b8d49bb8d16a wifi: rtw88: Don't set SUPPORTS_AMSDU_IN_AMPDU for RTL8814AU 0d2a88690e58 wifi: rtw88: Set AMPDU factor to hardware for RTL8814A dcbb7bb3a364 wifi: rtw88: usb: Enable RX aggregation for RTL8814AU bf1103654df9 wifi: rtw88: usb: Enable switching the RTL8814AU to USB 3 625fbc16524a wifi: rtw88: usb: Remove redundant 'flush_workqueue()' calls 5c4cf36c538b wifi: rtw88: sdio: Remove redundant 'flush_workqueue()' calls d58ad77d5cc2 wifi: rtw88: Add __nonstring annotations for unterminated strings deb3ddeb1865 wifi: rtw88: Enable the new RTL8814AE/RTL8814AU drivers bad060e8a425 wifi: rtw88: Add rtw8814au.c dad8e8793102 wifi: rtw88: Add rtw8814ae.c 1a7545784642 wifi: rtw88: Add rtw8814a.{c,h} e38246889cc9 wifi: rtw88: Add rtw8814a_table.c (part 2/2) f4debfcb1b3c wifi: rtw88: Add rtw8814a_table.c (part 1/2) 679ec431477c wifi: rtw88: Add some definitions for RTL8814AU c374281f8285 wifi: rtw88: Extend rtw_debugfs_get_tx_pwr_tbl() for RTL8814AU cfebabdd351e wifi: rtw88: Extend rtw_debugfs_get_phy_info() for RTL8814AU 8b42c46cf665 wifi: rtw88: Extend rtw_phy_config_swing_table() for RTL8814AU 053a7aace020 wifi: rtw88: Fix rtw_rx_phy_stat() for RTL8814AU 6be7544d19fc wifi: rtw88: Fix rtw_init_vht_cap() for RTL8814AU c7eea1ba05ca wifi: rtw88: Fix rtw_init_ht_cap() for RTL8814AU 86d04f8f991a wifi: rtw88: Fix rtw_desc_to_mcsrate() to handle MCS16-31 e66bca16638e wifi: rtw88: Fix rtw_mac_power_switch() for RTL8814AU 80c4668d024f wifi: rtw88: Add support for Mercusys MA30N and D-Link DWA-T185 rev. A1 9f00e2218e15 wifi: rtw88: Fix rtw_update_sta_info() for RTL8814AU 0f98a5959657 wifi: rtw88: Extend TX power stuff for 3-4 spatial streams ad815f392003 wifi: rtw88: Rename RTW_RATE_SECTION_MAX to RTW_RATE_SECTION_NUM e66f3b5c7535 wifi: rtw88: Constify some more structs and arrays 8f0076726b66 wifi: rtw88: Extend rtw_fw_send_ra_info() for RTL8814AU d80e7d9b6ba3 wifi: rtw88: Extend rf_base_addr and rf_sipi_addr for RTL8814AU 62f726848da4 wifi: rtw88: Extend struct rtw_pwr_track_tbl for RTL8814AU 9e8243025cc0 wifi: rtw88: Fix download_firmware_validate() for RTL8814AU 8425f5c8f04d wifi: rtw88: Fix __rtw_download_firmware() for RTL8814AU 105dc94233e4 wifi: rtw88: Fix a typo of debug message in rtw8723d_iqk_check_tx_failed() 0d1d165eff9d wifi: rtw88: Don't use static local variable in rtw8821c_set_tx_power_index_by_rate 00451eb3bec7 wifi: rtw88: Don't use static local variable in rtw8822b_set_tx_power_index_by_rate b4bfbc50b1b9 wifi: rtw88: add RTW88_LEDS depends on LEDS_CLASS to Kconfig 4b6652bc6d8d wifi: rtw88: Add support for LED blinking fb2fcfbe5eef wifi: rtw88: sdio: Fix disconnection after beacon loss a806a8160a0f wifi: rtw88: 8703b: Fix RX/TX issues 5ad483955acc wifi: rtw88: Delete rf_type member of struct rtw_sta_info 5b1b9545262b wifi: rtw88: Add USB PHY configuration not backported (3e3aa566dd18 wifi: rtw88: usb: Preallocate and reuse the RX skbs) not backported (13221be72034 wifi: rtw88: Handle C2H_ADAPTIVITY in rtw_fw_c2h_cmd_handle() ) e9048e2935f7 wifi: rtw88: usb: Copy instead of cloning the RX skb 74a72c367573 wifi: rtw88: 8821a/8812a: Set ptct_efuse_size to 0 59ab27a9f20f wifi: rtw88: 8812a: Support RFE type 2 Signed-off-by: Marty Jones <mj8263788@gmail.com> Link: https://github.com/openwrt/openwrt/pull/19052 Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
214 lines
6.7 KiB
Diff
214 lines
6.7 KiB
Diff
From e66f3b5c7535bb508e9c561a047b32de4ddc1cda Mon Sep 17 00:00:00 2001
|
|
From: Bitterblue Smith <rtl8821cerfe2@gmail.com>
|
|
Date: Tue, 4 Feb 2025 20:40:22 +0200
|
|
Subject: [PATCH] wifi: rtw88: Constify some more structs and arrays
|
|
|
|
These structs and arrays are never modified, so make them const:
|
|
|
|
rtw_band_2ghz
|
|
rtw_band_5ghz
|
|
rtw_pci_tx_queue_idx_addr
|
|
rtw_pci_ops
|
|
rtw_cck_rates
|
|
rtw_ofdm_rates
|
|
rtw_ht_1s_rates
|
|
rtw_ht_2s_rates
|
|
rtw_vht_1s_rates
|
|
rtw_vht_2s_rates
|
|
rtw_rate_section
|
|
rtw_rate_size
|
|
rtw_sdio_ops
|
|
rtw_usb_ops
|
|
|
|
Signed-off-by: Bitterblue Smith <rtl8821cerfe2@gmail.com>
|
|
Acked-by: Ping-Ke Shih <pkshih@realtek.com>
|
|
Signed-off-by: Ping-Ke Shih <pkshih@realtek.com>
|
|
Link: https://patch.msgid.link/502f124e-ccf3-4c09-80a4-1e5c5304822b@gmail.com
|
|
---
|
|
drivers/net/wireless/realtek/rtw88/main.c | 4 ++--
|
|
drivers/net/wireless/realtek/rtw88/main.h | 2 +-
|
|
drivers/net/wireless/realtek/rtw88/pci.c | 4 ++--
|
|
drivers/net/wireless/realtek/rtw88/phy.c | 26 ++++++++++++++---------
|
|
drivers/net/wireless/realtek/rtw88/phy.h | 16 +++++++-------
|
|
drivers/net/wireless/realtek/rtw88/sdio.c | 2 +-
|
|
drivers/net/wireless/realtek/rtw88/usb.c | 2 +-
|
|
7 files changed, 31 insertions(+), 25 deletions(-)
|
|
|
|
--- a/drivers/net/wireless/realtek/rtw88/main.c
|
|
+++ b/drivers/net/wireless/realtek/rtw88/main.c
|
|
@@ -136,7 +136,7 @@ u16 rtw_desc_to_bitrate(u8 desc_rate)
|
|
return rate.bitrate;
|
|
}
|
|
|
|
-static struct ieee80211_supported_band rtw_band_2ghz = {
|
|
+static const struct ieee80211_supported_band rtw_band_2ghz = {
|
|
.band = NL80211_BAND_2GHZ,
|
|
|
|
.channels = rtw_channeltable_2g,
|
|
@@ -149,7 +149,7 @@ static struct ieee80211_supported_band r
|
|
.vht_cap = {0},
|
|
};
|
|
|
|
-static struct ieee80211_supported_band rtw_band_5ghz = {
|
|
+static const struct ieee80211_supported_band rtw_band_5ghz = {
|
|
.band = NL80211_BAND_5GHZ,
|
|
|
|
.channels = rtw_channeltable_5g,
|
|
--- a/drivers/net/wireless/realtek/rtw88/main.h
|
|
+++ b/drivers/net/wireless/realtek/rtw88/main.h
|
|
@@ -61,7 +61,7 @@ enum rtw_hci_type {
|
|
};
|
|
|
|
struct rtw_hci {
|
|
- struct rtw_hci_ops *ops;
|
|
+ const struct rtw_hci_ops *ops;
|
|
enum rtw_hci_type type;
|
|
|
|
u32 rpwm_addr;
|
|
--- a/drivers/net/wireless/realtek/rtw88/pci.c
|
|
+++ b/drivers/net/wireless/realtek/rtw88/pci.c
|
|
@@ -20,7 +20,7 @@ module_param_named(disable_aspm, rtw_pci
|
|
MODULE_PARM_DESC(disable_msi, "Set Y to disable MSI interrupt support");
|
|
MODULE_PARM_DESC(disable_aspm, "Set Y to disable PCI ASPM support");
|
|
|
|
-static u32 rtw_pci_tx_queue_idx_addr[] = {
|
|
+static const u32 rtw_pci_tx_queue_idx_addr[] = {
|
|
[RTW_TX_QUEUE_BK] = RTK_PCI_TXBD_IDX_BKQ,
|
|
[RTW_TX_QUEUE_BE] = RTK_PCI_TXBD_IDX_BEQ,
|
|
[RTW_TX_QUEUE_VI] = RTK_PCI_TXBD_IDX_VIQ,
|
|
@@ -1591,7 +1591,7 @@ static void rtw_pci_destroy(struct rtw_d
|
|
rtw_pci_io_unmapping(rtwdev, pdev);
|
|
}
|
|
|
|
-static struct rtw_hci_ops rtw_pci_ops = {
|
|
+static const struct rtw_hci_ops rtw_pci_ops = {
|
|
.tx_write = rtw_pci_tx_write,
|
|
.tx_kick_off = rtw_pci_tx_kick_off,
|
|
.flush_queues = rtw_pci_flush_queues,
|
|
--- a/drivers/net/wireless/realtek/rtw88/phy.c
|
|
+++ b/drivers/net/wireless/realtek/rtw88/phy.c
|
|
@@ -52,44 +52,50 @@ static const u32 db_invert_table[12][8]
|
|
1995262315, 2511886432U, 3162277660U, 3981071706U}
|
|
};
|
|
|
|
-u8 rtw_cck_rates[] = { DESC_RATE1M, DESC_RATE2M, DESC_RATE5_5M, DESC_RATE11M };
|
|
-u8 rtw_ofdm_rates[] = {
|
|
+const u8 rtw_cck_rates[] = { DESC_RATE1M, DESC_RATE2M, DESC_RATE5_5M, DESC_RATE11M };
|
|
+
|
|
+const u8 rtw_ofdm_rates[] = {
|
|
DESC_RATE6M, DESC_RATE9M, DESC_RATE12M,
|
|
DESC_RATE18M, DESC_RATE24M, DESC_RATE36M,
|
|
DESC_RATE48M, DESC_RATE54M
|
|
};
|
|
-u8 rtw_ht_1s_rates[] = {
|
|
+
|
|
+const u8 rtw_ht_1s_rates[] = {
|
|
DESC_RATEMCS0, DESC_RATEMCS1, DESC_RATEMCS2,
|
|
DESC_RATEMCS3, DESC_RATEMCS4, DESC_RATEMCS5,
|
|
DESC_RATEMCS6, DESC_RATEMCS7
|
|
};
|
|
-u8 rtw_ht_2s_rates[] = {
|
|
+
|
|
+const u8 rtw_ht_2s_rates[] = {
|
|
DESC_RATEMCS8, DESC_RATEMCS9, DESC_RATEMCS10,
|
|
DESC_RATEMCS11, DESC_RATEMCS12, DESC_RATEMCS13,
|
|
DESC_RATEMCS14, DESC_RATEMCS15
|
|
};
|
|
-u8 rtw_vht_1s_rates[] = {
|
|
+
|
|
+const u8 rtw_vht_1s_rates[] = {
|
|
DESC_RATEVHT1SS_MCS0, DESC_RATEVHT1SS_MCS1,
|
|
DESC_RATEVHT1SS_MCS2, DESC_RATEVHT1SS_MCS3,
|
|
DESC_RATEVHT1SS_MCS4, DESC_RATEVHT1SS_MCS5,
|
|
DESC_RATEVHT1SS_MCS6, DESC_RATEVHT1SS_MCS7,
|
|
DESC_RATEVHT1SS_MCS8, DESC_RATEVHT1SS_MCS9
|
|
};
|
|
-u8 rtw_vht_2s_rates[] = {
|
|
+
|
|
+const u8 rtw_vht_2s_rates[] = {
|
|
DESC_RATEVHT2SS_MCS0, DESC_RATEVHT2SS_MCS1,
|
|
DESC_RATEVHT2SS_MCS2, DESC_RATEVHT2SS_MCS3,
|
|
DESC_RATEVHT2SS_MCS4, DESC_RATEVHT2SS_MCS5,
|
|
DESC_RATEVHT2SS_MCS6, DESC_RATEVHT2SS_MCS7,
|
|
DESC_RATEVHT2SS_MCS8, DESC_RATEVHT2SS_MCS9
|
|
};
|
|
-u8 *rtw_rate_section[RTW_RATE_SECTION_MAX] = {
|
|
+
|
|
+const u8 * const rtw_rate_section[RTW_RATE_SECTION_MAX] = {
|
|
rtw_cck_rates, rtw_ofdm_rates,
|
|
rtw_ht_1s_rates, rtw_ht_2s_rates,
|
|
rtw_vht_1s_rates, rtw_vht_2s_rates
|
|
};
|
|
EXPORT_SYMBOL(rtw_rate_section);
|
|
|
|
-u8 rtw_rate_size[RTW_RATE_SECTION_MAX] = {
|
|
+const u8 rtw_rate_size[RTW_RATE_SECTION_MAX] = {
|
|
ARRAY_SIZE(rtw_cck_rates),
|
|
ARRAY_SIZE(rtw_ofdm_rates),
|
|
ARRAY_SIZE(rtw_ht_1s_rates),
|
|
@@ -2214,7 +2220,7 @@ static void rtw_phy_set_tx_power_index_b
|
|
{
|
|
struct rtw_hal *hal = &rtwdev->hal;
|
|
u8 regd = rtw_regd_get(rtwdev);
|
|
- u8 *rates;
|
|
+ const u8 *rates;
|
|
u8 size;
|
|
u8 rate;
|
|
u8 pwr_idx;
|
|
@@ -2274,7 +2280,7 @@ EXPORT_SYMBOL(rtw_phy_set_tx_power_level
|
|
|
|
static void
|
|
rtw_phy_tx_power_by_rate_config_by_path(struct rtw_hal *hal, u8 path,
|
|
- u8 rs, u8 size, u8 *rates)
|
|
+ u8 rs, u8 size, const u8 *rates)
|
|
{
|
|
u8 rate;
|
|
u8 base_idx, rate_idx;
|
|
--- a/drivers/net/wireless/realtek/rtw88/phy.h
|
|
+++ b/drivers/net/wireless/realtek/rtw88/phy.h
|
|
@@ -7,14 +7,14 @@
|
|
|
|
#include "debug.h"
|
|
|
|
-extern u8 rtw_cck_rates[];
|
|
-extern u8 rtw_ofdm_rates[];
|
|
-extern u8 rtw_ht_1s_rates[];
|
|
-extern u8 rtw_ht_2s_rates[];
|
|
-extern u8 rtw_vht_1s_rates[];
|
|
-extern u8 rtw_vht_2s_rates[];
|
|
-extern u8 *rtw_rate_section[];
|
|
-extern u8 rtw_rate_size[];
|
|
+extern const u8 rtw_cck_rates[];
|
|
+extern const u8 rtw_ofdm_rates[];
|
|
+extern const u8 rtw_ht_1s_rates[];
|
|
+extern const u8 rtw_ht_2s_rates[];
|
|
+extern const u8 rtw_vht_1s_rates[];
|
|
+extern const u8 rtw_vht_2s_rates[];
|
|
+extern const u8 * const rtw_rate_section[];
|
|
+extern const u8 rtw_rate_size[];
|
|
|
|
void rtw_phy_init(struct rtw_dev *rtwdev);
|
|
void rtw_phy_dynamic_mechanism(struct rtw_dev *rtwdev);
|
|
--- a/drivers/net/wireless/realtek/rtw88/sdio.c
|
|
+++ b/drivers/net/wireless/realtek/rtw88/sdio.c
|
|
@@ -1147,7 +1147,7 @@ static void rtw_sdio_declaim(struct rtw_
|
|
sdio_release_host(sdio_func);
|
|
}
|
|
|
|
-static struct rtw_hci_ops rtw_sdio_ops = {
|
|
+static const struct rtw_hci_ops rtw_sdio_ops = {
|
|
.tx_write = rtw_sdio_tx_write,
|
|
.tx_kick_off = rtw_sdio_tx_kick_off,
|
|
.setup = rtw_sdio_setup,
|
|
--- a/drivers/net/wireless/realtek/rtw88/usb.c
|
|
+++ b/drivers/net/wireless/realtek/rtw88/usb.c
|
|
@@ -844,7 +844,7 @@ static void rtw_usb_dynamic_rx_agg(struc
|
|
}
|
|
}
|
|
|
|
-static struct rtw_hci_ops rtw_usb_ops = {
|
|
+static const struct rtw_hci_ops rtw_usb_ops = {
|
|
.tx_write = rtw_usb_tx_write,
|
|
.tx_kick_off = rtw_usb_tx_kick_off,
|
|
.setup = rtw_usb_setup,
|