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