1*e3ec7017SPing-Ke Shih /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */ 2*e3ec7017SPing-Ke Shih /* Copyright(c) 2019-2020 Realtek Corporation 3*e3ec7017SPing-Ke Shih */ 4*e3ec7017SPing-Ke Shih 5*e3ec7017SPing-Ke Shih #ifndef __RTW89_SAR_H__ 6*e3ec7017SPing-Ke Shih #define __RTW89_SAR_H__ 7*e3ec7017SPing-Ke Shih 8*e3ec7017SPing-Ke Shih #include "core.h" 9*e3ec7017SPing-Ke Shih 10*e3ec7017SPing-Ke Shih #define RTW89_SAR_TXPWR_MAC_MAX S8_MAX 11*e3ec7017SPing-Ke Shih #define RTW89_SAR_TXPWR_MAC_MIN S8_MIN 12*e3ec7017SPing-Ke Shih 13*e3ec7017SPing-Ke Shih struct rtw89_sar_handler { 14*e3ec7017SPing-Ke Shih const char *descr_sar_source; 15*e3ec7017SPing-Ke Shih u8 txpwr_factor_sar; 16*e3ec7017SPing-Ke Shih int (*query_sar_config)(struct rtw89_dev *rtwdev, s32 *cfg); 17*e3ec7017SPing-Ke Shih }; 18*e3ec7017SPing-Ke Shih 19*e3ec7017SPing-Ke Shih extern const struct cfg80211_sar_capa rtw89_sar_capa; 20*e3ec7017SPing-Ke Shih 21*e3ec7017SPing-Ke Shih s8 rtw89_query_sar(struct rtw89_dev *rtwdev); 22*e3ec7017SPing-Ke Shih void rtw89_print_sar(struct seq_file *m, struct rtw89_dev *rtwdev); 23*e3ec7017SPing-Ke Shih int rtw89_ops_set_sar_specs(struct ieee80211_hw *hw, 24*e3ec7017SPing-Ke Shih const struct cfg80211_sar_specs *sar); 25*e3ec7017SPing-Ke Shih 26*e3ec7017SPing-Ke Shih #endif 27