18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
28c2ecf20Sopenharmony_ci/* Copyright(c) 2009-2012  Realtek Corporation.*/
38c2ecf20Sopenharmony_ci
48c2ecf20Sopenharmony_ci#ifndef __RTL8723E_HW_H__
58c2ecf20Sopenharmony_ci#define __RTL8723E_HW_H__
68c2ecf20Sopenharmony_ci
78c2ecf20Sopenharmony_ci#define CHK_SVID_SMID(_val1, _val2)				\
88c2ecf20Sopenharmony_ci	((rtlefuse->eeprom_svid == (_val1)) &&			\
98c2ecf20Sopenharmony_ci	 (rtlefuse->eeprom_smid == (_val2)))
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_civoid rtl8723e_get_hw_reg(struct ieee80211_hw *hw, u8 variable, u8 *val);
128c2ecf20Sopenharmony_civoid rtl8723e_read_eeprom_info(struct ieee80211_hw *hw);
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_civoid rtl8723e_interrupt_recognized(struct ieee80211_hw *hw,
158c2ecf20Sopenharmony_ci				   struct rtl_int *int_vec);
168c2ecf20Sopenharmony_ciint rtl8723e_hw_init(struct ieee80211_hw *hw);
178c2ecf20Sopenharmony_civoid rtl8723e_card_disable(struct ieee80211_hw *hw);
188c2ecf20Sopenharmony_civoid rtl8723e_enable_interrupt(struct ieee80211_hw *hw);
198c2ecf20Sopenharmony_civoid rtl8723e_disable_interrupt(struct ieee80211_hw *hw);
208c2ecf20Sopenharmony_ciint rtl8723e_set_network_type(struct ieee80211_hw *hw,
218c2ecf20Sopenharmony_ci			      enum nl80211_iftype type);
228c2ecf20Sopenharmony_civoid rtl8723e_set_check_bssid(struct ieee80211_hw *hw, bool check_bssid);
238c2ecf20Sopenharmony_civoid rtl8723e_set_qos(struct ieee80211_hw *hw, int aci);
248c2ecf20Sopenharmony_civoid rtl8723e_set_beacon_related_registers(struct ieee80211_hw *hw);
258c2ecf20Sopenharmony_civoid rtl8723e_set_beacon_interval(struct ieee80211_hw *hw);
268c2ecf20Sopenharmony_civoid rtl8723e_update_interrupt_mask(struct ieee80211_hw *hw,
278c2ecf20Sopenharmony_ci				    u32 add_msr, u32 rm_msr);
288c2ecf20Sopenharmony_civoid rtl8723e_set_hw_reg(struct ieee80211_hw *hw, u8 variable, u8 *val);
298c2ecf20Sopenharmony_civoid rtl8723e_update_hal_rate_tbl(struct ieee80211_hw *hw,
308c2ecf20Sopenharmony_ci				  struct ieee80211_sta *sta, u8 rssi_level,
318c2ecf20Sopenharmony_ci				  bool update_bw);
328c2ecf20Sopenharmony_civoid rtl8723e_update_channel_access_setting(struct ieee80211_hw *hw);
338c2ecf20Sopenharmony_cibool rtl8723e_gpio_radio_on_off_checking(struct ieee80211_hw *hw, u8 *valid);
348c2ecf20Sopenharmony_civoid rtl8723e_enable_hw_security_config(struct ieee80211_hw *hw);
358c2ecf20Sopenharmony_civoid rtl8723e_set_key(struct ieee80211_hw *hw, u32 key_index,
368c2ecf20Sopenharmony_ci		      u8 *p_macaddr, bool is_group, u8 enc_algo,
378c2ecf20Sopenharmony_ci		      bool is_wepkey, bool clear_all);
388c2ecf20Sopenharmony_ci
398c2ecf20Sopenharmony_civoid rtl8723e_read_bt_coexist_info_from_hwpg(struct ieee80211_hw *hw,
408c2ecf20Sopenharmony_ci					     bool autoload_fail, u8 *hwinfo);
418c2ecf20Sopenharmony_civoid rtl8723e_bt_reg_init(struct ieee80211_hw *hw);
428c2ecf20Sopenharmony_civoid rtl8723e_bt_hw_init(struct ieee80211_hw *hw);
438c2ecf20Sopenharmony_civoid rtl8723e_suspend(struct ieee80211_hw *hw);
448c2ecf20Sopenharmony_civoid rtl8723e_resume(struct ieee80211_hw *hw);
458c2ecf20Sopenharmony_ci
468c2ecf20Sopenharmony_ci#endif
47