mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 e3ec7017f6
			
		
	
	
		e3ec7017f6
		
	
	
	
	
		
			
			This driver named rtw89, which is the next generation of rtw88, supports Realtek 8852AE 802.11ax 2x2 chip whose new features are OFDMA, DBCC, Spatial reuse, TWT and BSS coloring; now some of them aren't implemented though. The chip architecture is entirely different from the chips supported by rtw88 like RTL8822CE 802.11ac chip. First of all, register address ranges are totally redefined, so it's impossible to reuse register definition. To communicate with firmware, new H2C/C2H format is proposed. In order to have better utilization, TX DMA flow is changed to two stages DMA. To provide rich RX status information, additional RX PPDU packets are added. Since there are so many differences mentioned above, we decide to propose a new driver. It has many authors, they are listed in alphabetic order: Chin-Yen Lee <timlee@realtek.com> Ping-Ke Shih <pkshih@realtek.com> Po Hao Huang <phhuang@realtek.com> Tzu-En Huang <tehuang@realtek.com> Vincent Fann <vincent_fann@realtek.com> Yan-Hsuan Chuang <tony0620emma@gmail.com> Zong-Zhe Yang <kevin_yang@realtek.com> Tested-by: Aaron Ma <aaron.ma@canonical.com> Tested-by: Brian Norris <briannorris@chromium.org> Signed-off-by: Ping-Ke Shih <pkshih@realtek.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org> Link: https://lore.kernel.org/r/20211008035627.19463-1-pkshih@realtek.com
		
			
				
	
	
		
			78 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
 | |
| /* Copyright(c) 2019-2020  Realtek Corporation
 | |
|  */
 | |
| 
 | |
| #ifndef __RTW89_DEBUG_H__
 | |
| #define __RTW89_DEBUG_H__
 | |
| 
 | |
| #include "core.h"
 | |
| 
 | |
| enum rtw89_debug_mask {
 | |
| 	RTW89_DBG_TXRX = BIT(0),
 | |
| 	RTW89_DBG_RFK = BIT(1),
 | |
| 	RTW89_DBG_RFK_TRACK = BIT(2),
 | |
| 	RTW89_DBG_CFO = BIT(3),
 | |
| 	RTW89_DBG_TSSI = BIT(4),
 | |
| 	RTW89_DBG_TXPWR = BIT(5),
 | |
| 	RTW89_DBG_HCI = BIT(6),
 | |
| 	RTW89_DBG_RA = BIT(7),
 | |
| 	RTW89_DBG_REGD = BIT(8),
 | |
| 	RTW89_DBG_PHY_TRACK = BIT(9),
 | |
| 	RTW89_DBG_DIG = BIT(10),
 | |
| 	RTW89_DBG_SER = BIT(11),
 | |
| 	RTW89_DBG_FW = BIT(12),
 | |
| 	RTW89_DBG_BTC = BIT(13),
 | |
| 	RTW89_DBG_BF = BIT(14),
 | |
| };
 | |
| 
 | |
| enum rtw89_debug_mac_reg_sel {
 | |
| 	RTW89_DBG_SEL_MAC_00,
 | |
| 	RTW89_DBG_SEL_MAC_40,
 | |
| 	RTW89_DBG_SEL_MAC_80,
 | |
| 	RTW89_DBG_SEL_MAC_C0,
 | |
| 	RTW89_DBG_SEL_MAC_E0,
 | |
| 	RTW89_DBG_SEL_BB,
 | |
| 	RTW89_DBG_SEL_IQK,
 | |
| 	RTW89_DBG_SEL_RFC,
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_RTW89_DEBUGFS
 | |
| void rtw89_debugfs_init(struct rtw89_dev *rtwdev);
 | |
| #else
 | |
| static inline void rtw89_debugfs_init(struct rtw89_dev *rtwdev) {}
 | |
| #endif
 | |
| 
 | |
| #define rtw89_info(rtwdev, a...) dev_info((rtwdev)->dev, ##a)
 | |
| #define rtw89_warn(rtwdev, a...) dev_warn((rtwdev)->dev, ##a)
 | |
| #define rtw89_err(rtwdev, a...) dev_err((rtwdev)->dev, ##a)
 | |
| 
 | |
| #ifdef CONFIG_RTW89_DEBUGMSG
 | |
| extern unsigned int rtw89_debug_mask;
 | |
| #define rtw89_debug(rtwdev, a...) __rtw89_debug(rtwdev, ##a)
 | |
| 
 | |
| __printf(3, 4)
 | |
| void __rtw89_debug(struct rtw89_dev *rtwdev,
 | |
| 		   enum rtw89_debug_mask mask,
 | |
| 		   const char *fmt, ...);
 | |
| static inline void rtw89_hex_dump(struct rtw89_dev *rtwdev,
 | |
| 				  enum rtw89_debug_mask mask,
 | |
| 				  const char *prefix_str,
 | |
| 				  const void *buf, size_t len)
 | |
| {
 | |
| 	if (!(rtw89_debug_mask & mask))
 | |
| 		return;
 | |
| 
 | |
| 	print_hex_dump_bytes(prefix_str, DUMP_PREFIX_OFFSET, buf, len);
 | |
| }
 | |
| #else
 | |
| static inline void rtw89_debug(struct rtw89_dev *rtwdev,
 | |
| 			       enum rtw89_debug_mask mask,
 | |
| 			       const char *fmt, ...) {}
 | |
| static inline void rtw89_hex_dump(struct rtw89_dev *rtwdev,
 | |
| 				  enum rtw89_debug_mask mask,
 | |
| 				  const char *prefix_str,
 | |
| 				  const void *buf, size_t len) {}
 | |
| #endif
 | |
| 
 | |
| #endif
 |