Initial commit
	
		
			
	
		
	
	
		
	
		
			Some checks failed
		
		
	
	
		
			
				
	
				Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			
		
			
				
	
				Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			
		
			
				
	
				Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			
		
			
				
	
				Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			
		
			
				
	
				Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			
		
			
				
	
				Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
		
	
	
				
					
				
			
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			This commit is contained in:
		
							
								
								
									
										104
									
								
								package/kernel/mwlwifi/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								package/kernel/mwlwifi/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | ||||
| # | ||||
| # Copyright (C) 2014-2016 OpenWrt.org | ||||
| # | ||||
| # This is free software, licensed under the GNU General Public License v2. | ||||
| # See /LICENSE for more information. | ||||
| # | ||||
|  | ||||
| include $(TOPDIR)/rules.mk | ||||
|  | ||||
| PKG_NAME:=mwlwifi | ||||
| PKG_RELEASE=1 | ||||
|  | ||||
| PKG_LICENSE:=ISC | ||||
| PKG_LICENSE_FILES:= | ||||
|  | ||||
| PKG_SOURCE_URL:=https://github.com/kaloz/mwlwifi | ||||
| PKG_SOURCE_PROTO:=git | ||||
| PKG_SOURCE_DATE:=2024-04-19 | ||||
| PKG_SOURCE_VERSION:=a737d348ef4fe00434b2bc44b2b6a68ea833d95b | ||||
| PKG_MIRROR_HASH:=d55f69c2fa48d02ba535b72b108fc77f5f13a52b29130a631489a053f1670d2c | ||||
|  | ||||
| PKG_MAINTAINER:=Imre Kaloz <kaloz@openwrt.org> | ||||
| PKG_BUILD_PARALLEL:=1 | ||||
| PKG_FLAGS:=nonshared | ||||
|  | ||||
| include $(INCLUDE_DIR)/kernel.mk | ||||
| include $(INCLUDE_DIR)/package.mk | ||||
|  | ||||
| define KernelPackage/mwlwifi | ||||
|   SUBMENU:=Wireless Drivers | ||||
|   TITLE:=Marvell 88W8864/88W8897/88W8964/88W8997 wireless driver | ||||
|   DEPENDS:=+kmod-mac80211 +@DRIVER_11AC_SUPPORT @PCI_SUPPORT @TARGET_mvebu | ||||
|   FILES:=$(PKG_BUILD_DIR)/mwlwifi.ko | ||||
|   AUTOLOAD:=$(call AutoLoad,50,mwlwifi) | ||||
| endef | ||||
|  | ||||
| NOSTDINC_FLAGS := \ | ||||
| 	$(KERNEL_NOSTDINC_FLAGS) \ | ||||
| 	-I$(PKG_BUILD_DIR) \ | ||||
| 	-I$(STAGING_DIR)/usr/include/mac80211-backport/uapi \ | ||||
| 	-I$(STAGING_DIR)/usr/include/mac80211-backport \ | ||||
| 	-I$(STAGING_DIR)/usr/include/mac80211/uapi \ | ||||
| 	-I$(STAGING_DIR)/usr/include/mac80211 \ | ||||
| 	-include backport/backport.h \ | ||||
| 	-Wno-unused-result | ||||
|  | ||||
| define Build/Compile | ||||
| 	+$(KERNEL_MAKE) $(PKG_JOBS) \ | ||||
| 		M="$(PKG_BUILD_DIR)" \ | ||||
| 		NOSTDINC_FLAGS="$(NOSTDINC_FLAGS)" \ | ||||
| 		modules | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-default | ||||
|   SECTION:=firmware | ||||
|   CATEGORY:=Firmware | ||||
|   TITLE:=Marvell $(1) firmware | ||||
|   DEPENDS:=+kmod-mwlwifi @TARGET_mvebu | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware/install | ||||
| 	$(INSTALL_DIR) $(1)/lib/firmware | ||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/mwlwifi | ||||
| 	$(CP) $(PKG_BUILD_DIR)/bin/firmware/$(2) $(1)/lib/firmware/mwlwifi/ | ||||
| 	$(CP) $(PKG_BUILD_DIR)/bin/firmware/Marvell_license.txt $(1)/lib/firmware/mwlwifi/$(2).Marvell_license.txt | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8864 | ||||
| $(call Package/mwlwifi-firmware-default,88W8864) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8864/install | ||||
| 	$(call Package/mwlwifi-firmware/install,$(1),88W8864.bin) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8897 | ||||
| $(call Package/mwlwifi-firmware-default,88W8897) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8897/install | ||||
| 	$(call Package/mwlwifi-firmware/install,$(1),88W8897.bin) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8964 | ||||
| $(call Package/mwlwifi-firmware-default,88W8964) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8964/install | ||||
| 	$(call Package/mwlwifi-firmware/install,$(1),88W8964.bin) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8997 | ||||
| $(call Package/mwlwifi-firmware-default,88W8997) | ||||
| endef | ||||
|  | ||||
| define Package/mwlwifi-firmware-88w8997/install | ||||
| 	$(call Package/mwlwifi-firmware/install,$(1),88W8997.bin) | ||||
| endef | ||||
|  | ||||
| $(eval $(call KernelPackage,mwlwifi)) | ||||
| $(eval $(call BuildPackage,mwlwifi-firmware-88w8864)) | ||||
| $(eval $(call BuildPackage,mwlwifi-firmware-88w8897)) | ||||
| $(eval $(call BuildPackage,mwlwifi-firmware-88w8964)) | ||||
| $(eval $(call BuildPackage,mwlwifi-firmware-88w8997)) | ||||
| @@ -0,0 +1,165 @@ | ||||
| From ed4422e98ababf956674da3438ac42b3aa32c66e Mon Sep 17 00:00:00 2001 | ||||
| From: Christian Marangi <ansuelsmth@gmail.com> | ||||
| Date: Wed, 10 May 2023 00:41:06 +0200 | ||||
| Subject: [PATCH] Fix compilation warning with 64 bit system | ||||
|  | ||||
| Use %zu and %zd where possible for ssize_t and size_t. | ||||
| Use PTR_ERR to correctly convert to negative error. | ||||
| Use universal pointer to support both 32 and 64bit systems. | ||||
|  | ||||
| Fix compilation warning: | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/fwcmd.c: In function 'mwl_fwcmd_get_fw_core_dump': | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/fwcmd.c:3608:31: error: cast from pointer to integer of different size [-Werror=pointer-to-int-cast] | ||||
|  3608 |                (const void *)((u32)pcmd + | ||||
|       |                               ^ | ||||
| In file included from ./include/linux/device.h:15, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/device.h:3, | ||||
|                  from ./include/linux/dma-mapping.h:7, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/dma-mapping.h:3, | ||||
|                  from ./include/linux/skbuff.h:31, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/skbuff.h:3, | ||||
|                  from ./include/linux/if_ether.h:19, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/if_ether.h:3, | ||||
|                  from ./include/linux/etherdevice.h:20, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/etherdevice.h:3, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:20: | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c: In function 'pcie_tx_init_ndp': | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:338:38: error: format '%d' expects argument of type 'int', but argument 3 has type 'long unsigned int' [-Werror=format=] | ||||
|   338 |                 wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n", | ||||
|       |                                      ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
| ./include/linux/dev_printk.h:110:30: note: in definition of macro 'dev_printk_index_wrap' | ||||
|   110 |                 _p_func(dev, fmt, ##__VA_ARGS__);                       \ | ||||
|       |                              ^~~ | ||||
| ./include/linux/dev_printk.h:144:56: note: in expansion of macro 'dev_fmt' | ||||
|   144 |         dev_printk_index_wrap(_dev_err, KERN_ERR, dev, dev_fmt(fmt), ##__VA_ARGS__) | ||||
|       |                                                        ^~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211/net/cfg80211.h:8828:9: note: in expansion of macro 'dev_err' | ||||
|  8828 |         dev_err(&(wiphy)->dev, format, ##args) | ||||
|       |         ^~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:338:17: note: in expansion of macro 'wiphy_err' | ||||
|   338 |                 wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n", | ||||
|       |                 ^~~~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:338:67: note: format string is defined here | ||||
|   338 |                 wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n", | ||||
|       |                                                                  ~^ | ||||
|       |                                                                   | | ||||
|       |                                                                   int | ||||
|       |                                                                  %ld | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:338:38: error: format '%d' expects argument of type 'int', but argument 4 has type 'long unsigned int' [-Werror=format=] | ||||
|   338 |                 wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n", | ||||
|       |                                      ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||
| ./include/linux/dev_printk.h:110:30: note: in definition of macro 'dev_printk_index_wrap' | ||||
|   110 |                 _p_func(dev, fmt, ##__VA_ARGS__);                       \ | ||||
|       |                              ^~~ | ||||
| ./include/linux/dev_printk.h:144:56: note: in expansion of macro 'dev_fmt' | ||||
|   144 |         dev_printk_index_wrap(_dev_err, KERN_ERR, dev, dev_fmt(fmt), ##__VA_ARGS__) | ||||
|       |                                                        ^~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211/net/cfg80211.h:8828:9: note: in expansion of macro 'dev_err' | ||||
|  8828 |         dev_err(&(wiphy)->dev, format, ##args) | ||||
|       |         ^~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:338:17: note: in expansion of macro 'wiphy_err' | ||||
|   338 |                 wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n", | ||||
|       |                 ^~~~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.c:338:71: note: format string is defined here | ||||
|   338 |                 wiphy_err(hw->wiphy, "driver data is not enough: %d (%d)\n", | ||||
|       |                                                                      ~^ | ||||
|       |                                                                       | | ||||
|       |                                                                       int | ||||
|       |                                                                      %ld | ||||
|   CC [M]  /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/debugfs.o | ||||
| In file included from ./include/linux/device.h:15, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/device.h:3, | ||||
|                  from ./include/linux/dma-mapping.h:7, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/dma-mapping.h:3, | ||||
|                  from ./include/linux/skbuff.h:31, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/skbuff.h:3, | ||||
|                  from ./include/linux/if_ether.h:19, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/if_ether.h:3, | ||||
|                  from ./include/linux/etherdevice.h:20, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211-backport/linux/etherdevice.h:3, | ||||
|                  from /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/pcie.c:19: | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/pcie.c: In function 'pcie_bf_mimo_ctrl_decode': | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/pcie.c:1325:37: error: cast from pointer to integer of different size [-Werror=pointer-to-int-cast] | ||||
|  1325 |                           filename, (unsigned int)fp_data); | ||||
|       |                                     ^ | ||||
| ./include/linux/dev_printk.h:110:37: note: in definition of macro 'dev_printk_index_wrap' | ||||
|   110 |                 _p_func(dev, fmt, ##__VA_ARGS__);                       \ | ||||
|       |                                     ^~~~~~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/staging_dir/target-aarch64_cortex-a53_musl/usr/include/mac80211/net/cfg80211.h:8828:9: note: in expansion of macro 'dev_err' | ||||
|  8828 |         dev_err(&(wiphy)->dev, format, ##args) | ||||
|       |         ^~~~~~~ | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/pcie.c:1324:17: note: in expansion of macro 'wiphy_err' | ||||
|  1324 |                 wiphy_err(priv->hw->wiphy, "Error opening %s! %x\n", | ||||
|       |                 ^~~~~~~~~ | ||||
| cc1: all warnings being treated as errors | ||||
| make[4]: *** [scripts/Makefile.build:289: /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/tx_ndp.o] Error 1 | ||||
| make[4]: *** Waiting for unfinished jobs.... | ||||
| cc1: all warnings being treated as errors | ||||
| make[4]: *** [scripts/Makefile.build:289: /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/hif/pcie/pcie.o] Error 1 | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/debugfs.c: In function 'mwl_debugfs_regrdwr_read': | ||||
| /home/ansuel/openwrt-ansuel/openwrt/build_dir/target-aarch64_cortex-a53_musl/linux-ipq807x_generic/mwlwifi-2023-04-29-6a436714/debugfs.c:1335:43: error: format '%d' expects argument of type 'int', but argument 4 has type 'ssize_t' {aka 'long int'} [-Werror=format=] | ||||
|  1335 |                                  "error: %d(%u 0x%08x 0x%08x)\n", | ||||
|       |                                          ~^ | ||||
|       |                                           | | ||||
|       |                                           int | ||||
|       |                                          %ld | ||||
|  1336 |                                  ret, priv->reg_type, priv->reg_offset, | ||||
|       |                                  ~~~ | ||||
|       |                                  | | ||||
|       |                                  ssize_t {aka long int} | ||||
| cc1: all warnings being treated as errors | ||||
|  | ||||
| Signed-off-by: Christian Marangi <ansuelsmth@gmail.com> | ||||
| --- | ||||
|  debugfs.c              | 2 +- | ||||
|  hif/fwcmd.c            | 2 +- | ||||
|  hif/pcie/8964/tx_ndp.c | 2 +- | ||||
|  hif/pcie/pcie.c        | 4 ++-- | ||||
|  4 files changed, 5 insertions(+), 5 deletions(-) | ||||
|  | ||||
| --- a/debugfs.c | ||||
| +++ b/debugfs.c | ||||
| @@ -1342,7 +1342,7 @@ done: | ||||
|  				 priv->reg_value); | ||||
|  	else | ||||
|  		len += scnprintf(p + len, size - len, | ||||
| -				 "error: %d(%u 0x%08x 0x%08x)\n", | ||||
| +				 "error: %zd(%u 0x%08x 0x%08x)\n", | ||||
|  				 ret, priv->reg_type, priv->reg_offset, | ||||
|  				 priv->reg_value); | ||||
|   | ||||
| --- a/hif/fwcmd.c | ||||
| +++ b/hif/fwcmd.c | ||||
| @@ -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->flags = pcmd->cmd_data.coredump.flags; | ||||
|  	memcpy(buff, | ||||
| -	       (const void *)((u32)pcmd + | ||||
| +	       (const void *)((uintptr_t)pcmd + | ||||
|  	       sizeof(struct hostcmd_cmd_get_fw_core_dump) - | ||||
|  	       sizeof(struct hostcmd_cmd_get_fw_core_dump_)), | ||||
|  	       MAX_CORE_DUMP_BUFFER); | ||||
| --- a/hif/pcie/8964/tx_ndp.c | ||||
| +++ 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 | ||||
| +++ b/hif/pcie/pcie.c | ||||
| @@ -1466,8 +1466,8 @@ static void pcie_bf_mimo_ctrl_decode(struct mwl_priv *priv, | ||||
|  			       &fp_data->f_pos); | ||||
|  		filp_close(fp_data, current->files); | ||||
|  	} else { | ||||
| -		wiphy_err(priv->hw->wiphy, "Error opening %s! %x\n", | ||||
| -			  filename, (unsigned int)fp_data); | ||||
| +		wiphy_err(priv->hw->wiphy, "Error opening %s! %ld\n", | ||||
| +			  filename, PTR_ERR(fp_data)); | ||||
|  	} | ||||
|   | ||||
|  #if LINUX_VERSION_CODE < KERNEL_VERSION(5,10,0) | ||||
| @@ -0,0 +1,31 @@ | ||||
| From 8e809b241695252e397bf0d7fc5f36e115c38831 Mon Sep 17 00:00:00 2001 | ||||
| From: Robert Marko <robert.marko@sartura.hr> | ||||
| Date: Fri, 5 Mar 2021 11:47:59 +0100 | ||||
| Subject: [PATCH] mwlwifi: fix PCIe DT node null pointer dereference | ||||
|  | ||||
| pci_bus_to_OF_node() used to get the PCI bus DT node | ||||
| returns node if found or NULL if none is found. | ||||
|  | ||||
| Since the return of pci_bus_to_OF_node() is not checked in | ||||
| the DT node name print it will cause a null pointer | ||||
| dereference and crash the kernel. | ||||
|  | ||||
| So first check whether the node is not NULL and then print. | ||||
|  | ||||
| Signed-off-by: Robert Marko <robert.marko@sartura.hr> | ||||
| --- | ||||
|  hif/pcie/pcie.c | 3 ++- | ||||
|  1 file changed, 2 insertions(+), 1 deletion(-) | ||||
|  | ||||
| --- a/hif/pcie/pcie.c | ||||
| +++ b/hif/pcie/pcie.c | ||||
| @@ -685,7 +685,8 @@ static struct device_node *pcie_get_devi | ||||
|  	struct device_node *dev_node; | ||||
|   | ||||
|  	dev_node = pci_bus_to_OF_node(pcie_priv->pdev->bus); | ||||
| -	wiphy_info(priv->hw->wiphy, "device node: %s\n", dev_node->full_name); | ||||
| +	if (dev_node) | ||||
| +		wiphy_info(priv->hw->wiphy, "device node: %s\n", dev_node->full_name); | ||||
|   | ||||
|  	return dev_node; | ||||
|  } | ||||
							
								
								
									
										480
									
								
								package/kernel/mwlwifi/patches/005-mac80211_update.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										480
									
								
								package/kernel/mwlwifi/patches/005-mac80211_update.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,480 @@ | ||||
| --- a/core.c | ||||
| +++ b/core.c | ||||
| @@ -718,8 +718,8 @@ static void mwl_chnl_switch_event(struct | ||||
|  		vif = container_of((void *)mwl_vif, struct ieee80211_vif, | ||||
|  				   drv_priv); | ||||
|   | ||||
| -		if (vif->csa_active) | ||||
| -			ieee80211_csa_finish(vif); | ||||
| +		if (vif->bss_conf.csa_active) | ||||
| +			ieee80211_csa_finish(vif, 0); | ||||
|  	} | ||||
|  	spin_unlock_bh(&priv->vif_lock); | ||||
|   | ||||
| --- a/debugfs.c | ||||
| +++ b/debugfs.c | ||||
| @@ -498,9 +498,9 @@ static ssize_t mwl_debugfs_vif_read(stru | ||||
|  		switch (vif->type) { | ||||
|  		case NL80211_IFTYPE_AP: | ||||
|  			len += scnprintf(p + len, size - len, "type: ap\n"); | ||||
| -			memcpy(ssid, vif->bss_conf.ssid, | ||||
| -			       vif->bss_conf.ssid_len); | ||||
| -			ssid[vif->bss_conf.ssid_len] = 0; | ||||
| +			memcpy(ssid, vif->cfg.ssid, | ||||
| +			       vif->cfg.ssid_len); | ||||
| +			ssid[vif->cfg.ssid_len] = 0; | ||||
|  			len += scnprintf(p + len, size - len, | ||||
|  					 "ssid: %s\n", ssid); | ||||
|  			len += scnprintf(p + len, size - len, | ||||
| @@ -522,8 +522,8 @@ static ssize_t mwl_debugfs_vif_read(stru | ||||
|  					 "type: unknown\n"); | ||||
|  			break; | ||||
|  		} | ||||
| -		if (vif->chanctx_conf) { | ||||
| -			chan_def = &vif->chanctx_conf->def; | ||||
| +		if (vif->bss_conf.chanctx_conf) { | ||||
| +			chan_def = &vif->bss_conf.chanctx_conf->def; | ||||
|  			len += scnprintf(p + len, size - len, | ||||
|  					 "channel: %d: width: %d\n", | ||||
|  					 chan_def->chan->hw_value, | ||||
| @@ -596,18 +596,18 @@ static ssize_t mwl_debugfs_sta_read(stru | ||||
|  			sta_info->wds ? "true" : "false", | ||||
|  			sta_info->ba_hist.enable ? "enable" : "disable", | ||||
|  			sta_info->is_amsdu_allowed ? sta_info->amsdu_ctrl.cap : 0 , | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.cap : 0, | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.ampdu_factor : 0, | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.ampdu_density : 0, | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[0] : 0, | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[1] : 0, | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[2] : 0, | ||||
| -			sta->ht_cap.ht_supported ? sta->ht_cap.mcs.rx_mask[3] : 0, | ||||
| -			sta->vht_cap.vht_supported ? sta->vht_cap.cap : 0, | ||||
| -			sta->vht_cap.vht_supported ? sta->vht_cap.vht_mcs.rx_mcs_map : 0, | ||||
| -			sta->vht_cap.vht_supported ? sta->vht_cap.vht_mcs.tx_mcs_map : 0, | ||||
| -			sta->bandwidth, | ||||
| -			sta->rx_nss, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.cap : 0, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.ampdu_factor : 0, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.ampdu_density : 0, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[0] : 0, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[1] : 0, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[2] : 0, | ||||
| +			sta->deflink.ht_cap.ht_supported ? sta->deflink.ht_cap.mcs.rx_mask[3] : 0, | ||||
| +			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, | ||||
| +			sta->deflink.vht_cap.vht_supported ? sta->deflink.vht_cap.vht_mcs.tx_mcs_map : 0, | ||||
| +			sta->deflink.bandwidth, | ||||
| +			sta->deflink.rx_nss, | ||||
|  			sta->tdls, | ||||
|  			sta->tdls_initiator, | ||||
|  			sta->wme, | ||||
| --- a/hif/fwcmd.c | ||||
| +++ b/hif/fwcmd.c | ||||
| @@ -633,11 +633,15 @@ einval: | ||||
|  } | ||||
|   | ||||
|  static int mwl_fwcmd_set_ap_beacon(struct mwl_priv *priv, | ||||
| -				   struct mwl_vif *mwl_vif, | ||||
| -				   struct ieee80211_bss_conf *bss_conf) | ||||
| +				   struct ieee80211_vif *vif) | ||||
|  { | ||||
|  	struct hostcmd_cmd_ap_beacon *pcmd; | ||||
|  	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; | ||||
|   | ||||
|  	/* 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; | ||||
|   | ||||
|  	ether_addr_copy(pcmd->start_cmd.sta_mac_addr, mwl_vif->bssid); | ||||
| -	memcpy(pcmd->start_cmd.ssid, bss_conf->ssid, bss_conf->ssid_len); | ||||
| +	memcpy(pcmd->start_cmd.ssid, vif->cfg.ssid, vif->cfg.ssid_len); | ||||
|  	if (priv->chip_type == MWL8997) | ||||
|  		ether_addr_copy(pcmd->start_cmd.bssid, mwl_vif->bssid); | ||||
|  	pcmd->start_cmd.bss_type = 1; | ||||
| @@ -674,7 +678,7 @@ static int mwl_fwcmd_set_ap_beacon(struc | ||||
|  	phy_ds_param_set = &pcmd->start_cmd.phy_param_set.ds_param_set; | ||||
|  	phy_ds_param_set->elem_id = WLAN_EID_DS_PARAMS; | ||||
|  	phy_ds_param_set->len = sizeof(phy_ds_param_set->current_chnl); | ||||
| -	phy_ds_param_set->current_chnl = bss_conf->chandef.chan->hw_value; | ||||
| +	phy_ds_param_set->current_chnl = bss_conf->chanreq.oper.chan->hw_value; | ||||
|   | ||||
|  	pcmd->start_cmd.probe_delay = cpu_to_le16(10); | ||||
|  	pcmd->start_cmd.cap_info = cpu_to_le16(mwl_vif->beacon_info.cap_info); | ||||
| @@ -768,9 +772,9 @@ static int mwl_fwcmd_set_country_code(st | ||||
|  	bool enable = false; | ||||
|   | ||||
|  	if (b_inf->ie_country_ptr) { | ||||
| -		if (bss_conf->chandef.chan->band == NL80211_BAND_2GHZ) | ||||
| +		if (bss_conf->chanreq.oper.chan->band == NL80211_BAND_2GHZ) | ||||
|  			a_band = false; | ||||
| -		else if (bss_conf->chandef.chan->band == NL80211_BAND_5GHZ) | ||||
| +		else if (bss_conf->chanreq.oper.chan->band == NL80211_BAND_5GHZ) | ||||
|  			a_band = true; | ||||
|  		else | ||||
|  			return -EINVAL; | ||||
| @@ -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)) | ||||
|  		goto err; | ||||
|   | ||||
| -	if (mwl_fwcmd_set_ap_beacon(priv, mwl_vif, &vif->bss_conf)) | ||||
| +	if (mwl_fwcmd_set_ap_beacon(priv, vif)) | ||||
|  		goto err; | ||||
|   | ||||
|  	if (b_inf->cap_info & WLAN_CAPABILITY_SPECTRUM_MGMT) | ||||
| @@ -2152,38 +2156,38 @@ int mwl_fwcmd_set_new_stn_add(struct iee | ||||
|  	ether_addr_copy(pcmd->mac_addr, sta->addr); | ||||
|   | ||||
|  	if (hw->conf.chandef.chan->band == NL80211_BAND_2GHZ) | ||||
| -		rates = sta->supp_rates[NL80211_BAND_2GHZ]; | ||||
| +		rates = sta->deflink.supp_rates[NL80211_BAND_2GHZ]; | ||||
|  	else | ||||
| -		rates = sta->supp_rates[NL80211_BAND_5GHZ] << 5; | ||||
| +		rates = sta->deflink.supp_rates[NL80211_BAND_5GHZ] << 5; | ||||
|  	pcmd->peer_info.legacy_rate_bitmap = cpu_to_le32(rates); | ||||
|   | ||||
| -	if (sta->ht_cap.ht_supported) { | ||||
| +	if (sta->deflink.ht_cap.ht_supported) { | ||||
|  		int i; | ||||
|   | ||||
|  		for (i = 0; i < 4; i++) { | ||||
| -			if (i < sta->rx_nss) { | ||||
| +			if (i < sta->deflink.rx_nss) { | ||||
|  				pcmd->peer_info.ht_rates[i] = | ||||
| -					sta->ht_cap.mcs.rx_mask[i]; | ||||
| +					sta->deflink.ht_cap.mcs.rx_mask[i]; | ||||
|  			} else { | ||||
|  				pcmd->peer_info.ht_rates[i] = 0; | ||||
|  			} | ||||
|  		} | ||||
| -		pcmd->peer_info.ht_cap_info = cpu_to_le16(sta->ht_cap.cap); | ||||
| +		pcmd->peer_info.ht_cap_info = cpu_to_le16(sta->deflink.ht_cap.cap); | ||||
|  		pcmd->peer_info.mac_ht_param_info = | ||||
| -			(sta->ht_cap.ampdu_factor & 3) | | ||||
| -			((sta->ht_cap.ampdu_density & 7) << 2); | ||||
| +			(sta->deflink.ht_cap.ampdu_factor & 3) | | ||||
| +			((sta->deflink.ht_cap.ampdu_density & 7) << 2); | ||||
|  	} | ||||
|   | ||||
| -	if (sta->vht_cap.vht_supported) { | ||||
| +	if (sta->deflink.vht_cap.vht_supported) { | ||||
|  		u32 rx_mcs_map_mask = 0; | ||||
|   | ||||
| -		rx_mcs_map_mask = ((0x0000FFFF) >> (sta->rx_nss * 2)) | ||||
| -			<< (sta->rx_nss * 2); | ||||
| +		rx_mcs_map_mask = ((0x0000FFFF) >> (sta->deflink.rx_nss * 2)) | ||||
| +			<< (sta->deflink.rx_nss * 2); | ||||
|  		pcmd->peer_info.vht_max_rx_mcs = | ||||
|  			cpu_to_le32((*((u32 *) | ||||
| -			&sta->vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask); | ||||
| -		pcmd->peer_info.vht_cap = cpu_to_le32(sta->vht_cap.cap); | ||||
| -		pcmd->peer_info.vht_rx_channel_width = sta->bandwidth; | ||||
| +			&sta->deflink.vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask); | ||||
| +		pcmd->peer_info.vht_cap = cpu_to_le32(sta->deflink.vht_cap.cap); | ||||
| +		pcmd->peer_info.vht_rx_channel_width = sta->deflink.bandwidth; | ||||
|  	} | ||||
|   | ||||
|  	pcmd->is_qos_sta = sta->wme; | ||||
| @@ -2239,38 +2243,38 @@ int mwl_fwcmd_set_new_stn_add_sc4(struct | ||||
|  	ether_addr_copy(pcmd->mac_addr, sta->addr); | ||||
|   | ||||
|  	if (hw->conf.chandef.chan->band == NL80211_BAND_2GHZ) | ||||
| -		rates = sta->supp_rates[NL80211_BAND_2GHZ]; | ||||
| +		rates = sta->deflink.supp_rates[NL80211_BAND_2GHZ]; | ||||
|  	else | ||||
| -		rates = sta->supp_rates[NL80211_BAND_5GHZ] << 5; | ||||
| +		rates = sta->deflink.supp_rates[NL80211_BAND_5GHZ] << 5; | ||||
|  	pcmd->peer_info.legacy_rate_bitmap = cpu_to_le32(rates); | ||||
|   | ||||
| -	if (sta->ht_cap.ht_supported) { | ||||
| +	if (sta->deflink.ht_cap.ht_supported) { | ||||
|  		int i; | ||||
|   | ||||
|  		for (i = 0; i < 4; i++) { | ||||
| -			if (i < sta->rx_nss) { | ||||
| +			if (i < sta->deflink.rx_nss) { | ||||
|  				pcmd->peer_info.ht_rates[i] = | ||||
| -					sta->ht_cap.mcs.rx_mask[i]; | ||||
| +					sta->deflink.ht_cap.mcs.rx_mask[i]; | ||||
|  			} else { | ||||
|  				pcmd->peer_info.ht_rates[i] = 0; | ||||
|  			} | ||||
|  		} | ||||
| -		pcmd->peer_info.ht_cap_info = cpu_to_le16(sta->ht_cap.cap); | ||||
| +		pcmd->peer_info.ht_cap_info = cpu_to_le16(sta->deflink.ht_cap.cap); | ||||
|  		pcmd->peer_info.mac_ht_param_info = | ||||
| -			(sta->ht_cap.ampdu_factor & 3) | | ||||
| -			((sta->ht_cap.ampdu_density & 7) << 2); | ||||
| +			(sta->deflink.ht_cap.ampdu_factor & 3) | | ||||
| +			((sta->deflink.ht_cap.ampdu_density & 7) << 2); | ||||
|  	} | ||||
|   | ||||
| -	if (sta->vht_cap.vht_supported) { | ||||
| +	if (sta->deflink.vht_cap.vht_supported) { | ||||
|  		u32 rx_mcs_map_mask = 0; | ||||
|   | ||||
| -		rx_mcs_map_mask = ((0x0000FFFF) >> (sta->rx_nss * 2)) | ||||
| -			<< (sta->rx_nss * 2); | ||||
| +		rx_mcs_map_mask = ((0x0000FFFF) >> (sta->deflink.rx_nss * 2)) | ||||
| +			<< (sta->deflink.rx_nss * 2); | ||||
|  		pcmd->peer_info.vht_max_rx_mcs = | ||||
|  			cpu_to_le32((*((u32 *) | ||||
| -			&sta->vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask); | ||||
| -		pcmd->peer_info.vht_cap = cpu_to_le32(sta->vht_cap.cap); | ||||
| -		pcmd->peer_info.vht_rx_channel_width = sta->bandwidth; | ||||
| +			&sta->deflink.vht_cap.vht_mcs.rx_mcs_map)) | rx_mcs_map_mask); | ||||
| +		pcmd->peer_info.vht_cap = cpu_to_le32(sta->deflink.vht_cap.cap); | ||||
| +		pcmd->peer_info.vht_rx_channel_width = sta->deflink.bandwidth; | ||||
|  	} | ||||
|   | ||||
|  	pcmd->is_qos_sta = sta->wme; | ||||
| @@ -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.queue_id = stream->idx; | ||||
|  	pcmd->ba_info.create_params.param_info = | ||||
| -		(stream->sta->ht_cap.ampdu_factor & | ||||
| +		(stream->sta->deflink.ht_cap.ampdu_factor & | ||||
|  		 IEEE80211_HT_AMPDU_PARM_FACTOR) | | ||||
| -		((stream->sta->ht_cap.ampdu_density << 2) & | ||||
| +		((stream->sta->deflink.ht_cap.ampdu_density << 2) & | ||||
|  		 IEEE80211_HT_AMPDU_PARM_DENSITY); | ||||
|  	if (direction == BA_FLAG_DIRECTION_UP) { | ||||
|  		pcmd->ba_info.create_params.reset_seq_no = 0; | ||||
| @@ -2799,9 +2803,9 @@ int mwl_fwcmd_create_ba(struct ieee80211 | ||||
|  		pcmd->ba_info.create_params.current_seq = cpu_to_le16(0); | ||||
|  	} | ||||
|  	if (priv->chip_type == MWL8964 && | ||||
| -	    stream->sta->vht_cap.vht_supported) { | ||||
| +	    stream->sta->deflink.vht_cap.vht_supported) { | ||||
|  		pcmd->ba_info.create_params.vht_rx_factor = | ||||
| -			cpu_to_le32((stream->sta->vht_cap.cap  & | ||||
| +			cpu_to_le32((stream->sta->deflink.vht_cap.cap  & | ||||
|  			IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK) >> | ||||
|  			IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_SHIFT); | ||||
|  	} | ||||
| --- a/hif/pcie/8864/tx.c | ||||
| +++ b/hif/pcie/8864/tx.c | ||||
| @@ -490,7 +490,7 @@ static void pcie_non_pfu_tx_done(struct | ||||
|  				} else | ||||
|  					memmove(dma_data->data - hdrlen, &dma_data->wh, hdrlen); | ||||
|  				skb_pull(done_skb, sizeof(*dma_data) - hdrlen); | ||||
| -				ieee80211_tx_status(priv->hw, done_skb); | ||||
| +				ieee80211_tx_status_skb(priv->hw, done_skb); | ||||
|  				dev_kfree_skb_any(done_skb); | ||||
|  				done_skb = NULL; | ||||
|  			} | ||||
| @@ -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; | ||||
| @@ -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/tx_ndp.c | ||||
| +++ b/hif/pcie/8964/tx_ndp.c | ||||
| @@ -287,7 +287,7 @@ static inline int pcie_tx_skb_ndp(struct | ||||
|  		skb_get(tx_skb); | ||||
|  		pcie_tx_prepare_info(priv, tx_ctrl->rate, tx_info); | ||||
|  		tx_ctrl->flags |= TX_CTRL_TYPE_DATA; | ||||
| -		ieee80211_tx_status(priv->hw, tx_skb); | ||||
| +		ieee80211_tx_status_skb(priv->hw, tx_skb); | ||||
|  	} | ||||
|   | ||||
|  	if (++tx_send_head_new >= MAX_NUM_TX_DESC) | ||||
| @@ -488,7 +488,7 @@ void pcie_tx_done_ndp(struct ieee80211_h | ||||
|  		} | ||||
|   | ||||
|  		pcie_tx_prepare_info(priv, 0, tx_info); | ||||
| -		ieee80211_tx_status(hw, skb); | ||||
| +		ieee80211_tx_status_skb(hw, skb); | ||||
|   | ||||
|  bypass_ack: | ||||
|  		if (++tx_done_tail >= MAX_TX_RING_DONE_SIZE) | ||||
| @@ -601,13 +601,13 @@ void pcie_tx_xmit_ndp(struct ieee80211_h | ||||
|  			ack_skb = skb_copy(skb, GFP_ATOMIC); | ||||
|  			ack_info = IEEE80211_SKB_CB(ack_skb); | ||||
|  			pcie_tx_prepare_info(priv, 0, ack_info); | ||||
| -			ieee80211_tx_status(hw, ack_skb); | ||||
| +			ieee80211_tx_status_skb(hw, ack_skb); | ||||
|  		} | ||||
|   | ||||
|  		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++) { | ||||
| @@ -444,7 +444,7 @@ static void pcie_pfu_tx_done(struct mwl_ | ||||
|  				} else | ||||
|  					memmove(dma_data->data - hdrlen, &dma_data->wh, hdrlen); | ||||
|  				skb_pull(done_skb, sizeof(*pfu_dma) - hdrlen); | ||||
| -				ieee80211_tx_status(priv->hw, done_skb); | ||||
| +				ieee80211_tx_status_skb(priv->hw, done_skb); | ||||
|  			} | ||||
|  		} | ||||
|  next: | ||||
| @@ -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; | ||||
| @@ -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 | ||||
| +} | ||||
| --- a/mac80211.c | ||||
| +++ b/mac80211.c | ||||
| @@ -368,15 +368,15 @@ static void mwl_mac80211_bss_info_change | ||||
|  		} | ||||
|  	} | ||||
|   | ||||
| -	if ((changed & BSS_CHANGED_ASSOC) && vif->bss_conf.assoc) | ||||
| +	if ((changed & BSS_CHANGED_ASSOC) && vif->cfg.assoc) | ||||
|  		mwl_fwcmd_set_aid(hw, vif, (u8 *)vif->bss_conf.bssid, | ||||
| -				  vif->bss_conf.aid); | ||||
| +				  vif->cfg.aid); | ||||
|  } | ||||
|   | ||||
|  static void mwl_mac80211_bss_info_changed_ap(struct ieee80211_hw *hw, | ||||
|  					     struct ieee80211_vif *vif, | ||||
|  					     struct ieee80211_bss_conf *info, | ||||
| -					     u32 changed) | ||||
| +					     u64 changed) | ||||
|  { | ||||
|  	struct mwl_priv *priv = hw->priv; | ||||
|  	struct mwl_vif *mwl_vif; | ||||
| @@ -426,8 +426,8 @@ static void mwl_mac80211_bss_info_change | ||||
|  	if (changed & (BSS_CHANGED_BEACON_INT | BSS_CHANGED_BEACON)) { | ||||
|  		struct sk_buff *skb; | ||||
|   | ||||
| -		if ((info->ssid[0] != '\0') && | ||||
| -		    (info->ssid_len != 0) && | ||||
| +		if ((vif->cfg.ssid[0] != '\0') && | ||||
| +		    (vif->cfg.ssid_len != 0) && | ||||
|  		    (!info->hidden_ssid)) { | ||||
|  			if (mwl_vif->broadcast_ssid != true) { | ||||
|  				mwl_fwcmd_broadcast_ssid_enable(hw, vif, true); | ||||
| @@ -441,7 +441,7 @@ static void mwl_mac80211_bss_info_change | ||||
|  		} | ||||
|   | ||||
|  		if (!mwl_vif->set_beacon) { | ||||
| -			skb = ieee80211_beacon_get(hw, vif); | ||||
| +			skb = ieee80211_beacon_get(hw, vif, 0); | ||||
|   | ||||
|  			if (skb) { | ||||
|  				mwl_fwcmd_set_beacon(hw, vif, skb->data, skb->len); | ||||
| @@ -458,7 +458,7 @@ static void mwl_mac80211_bss_info_change | ||||
|  static void mwl_mac80211_bss_info_changed(struct ieee80211_hw *hw, | ||||
|  					  struct ieee80211_vif *vif, | ||||
|  					  struct ieee80211_bss_conf *info, | ||||
| -					  u32 changed) | ||||
| +					  u64 changed) | ||||
|  { | ||||
|  	switch (vif->type) { | ||||
|  	case NL80211_IFTYPE_AP: | ||||
| @@ -583,10 +583,10 @@ static int mwl_mac80211_sta_add(struct i | ||||
|  	if (vif->type == NL80211_IFTYPE_MESH_POINT) | ||||
|  		sta_info->is_mesh_node = true; | ||||
|   | ||||
| -	if (sta->ht_cap.ht_supported) { | ||||
| +	if (sta->deflink.ht_cap.ht_supported) { | ||||
|  		sta_info->is_ampdu_allowed = true; | ||||
|  		sta_info->is_amsdu_allowed = false; | ||||
| -		if (sta->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.amsdu_allow_size = SYSADPT_AMSDU_8K_MAX_SIZE; | ||||
|  		} | ||||
| @@ -670,7 +670,7 @@ static int mwl_mac80211_sta_remove(struc | ||||
|   | ||||
|  static int mwl_mac80211_conf_tx(struct ieee80211_hw *hw, | ||||
|  				struct ieee80211_vif *vif, | ||||
| -				u16 queue, | ||||
| +				unsigned int link_id, u16 queue, | ||||
|  				const struct ieee80211_tx_queue_params *params) | ||||
|  { | ||||
|  	struct mwl_priv *priv = hw->priv; | ||||
| @@ -934,4 +934,5 @@ const struct ieee80211_ops mwl_mac80211_ | ||||
|  	.pre_channel_switch = mwl_mac80211_chnl_switch, | ||||
|  	.sw_scan_start      = mwl_mac80211_sw_scan_start, | ||||
|  	.sw_scan_complete   = mwl_mac80211_sw_scan_complete, | ||||
| +	.wake_tx_queue	    = ieee80211_handle_wake_tx_queue, | ||||
|  }; | ||||
| --- a/utils.c | ||||
| +++ b/utils.c | ||||
| @@ -173,9 +173,9 @@ u32 utils_get_init_tx_rate(struct mwl_pr | ||||
|  	u32 tx_rate; | ||||
|  	u16 format, nss, bw, rate_mcs; | ||||
|   | ||||
| -	if (sta->vht_cap.vht_supported) | ||||
| +	if (sta->deflink.vht_cap.vht_supported) | ||||
|  		format = TX_RATE_FORMAT_11AC; | ||||
| -	else if (sta->ht_cap.ht_supported) | ||||
| +	else if (sta->deflink.ht_cap.ht_supported) | ||||
|  		format = TX_RATE_FORMAT_11N; | ||||
|  	else | ||||
|  		format = TX_RATE_FORMAT_LEGACY; | ||||
| @@ -192,11 +192,11 @@ u32 utils_get_init_tx_rate(struct mwl_pr | ||||
|  		nss = 3; | ||||
|  		break; | ||||
|  	default: | ||||
| -		nss = sta->rx_nss; | ||||
| +		nss = sta->deflink.rx_nss; | ||||
|  		break; | ||||
|  	} | ||||
| -	if (nss > sta->rx_nss) | ||||
| -		nss = sta->rx_nss; | ||||
| +	if (nss > sta->deflink.rx_nss) | ||||
| +		nss = sta->deflink.rx_nss; | ||||
|   | ||||
|  	switch (conf->chandef.width) { | ||||
|  	case NL80211_CHAN_WIDTH_20_NOHT: | ||||
| @@ -213,11 +213,11 @@ u32 utils_get_init_tx_rate(struct mwl_pr | ||||
|  		bw = TX_RATE_BANDWIDTH_160; | ||||
|  		break; | ||||
|  	default: | ||||
| -		bw = sta->bandwidth; | ||||
| +		bw = sta->deflink.bandwidth; | ||||
|  		break; | ||||
|  	} | ||||
| -	if (bw > sta->bandwidth) | ||||
| -		bw = sta->bandwidth; | ||||
| +	if (bw > sta->deflink.bandwidth) | ||||
| +		bw = sta->deflink.bandwidth; | ||||
|   | ||||
|  	switch (format) { | ||||
|  	case TX_RATE_FORMAT_LEGACY: | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico