mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-25 03:22:43 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			229 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			229 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // Copyright 2018-2018 Espressif Systems (Shanghai) PTE LTD
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| #ifndef __ESP_COEXIST_INTERNAL_H__
 | |
| #define __ESP_COEXIST_INTERNAL_H__
 | |
| 
 | |
| #include <stdbool.h>
 | |
| #include "esp_coexist_adapter.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| typedef enum {
 | |
|     COEX_PREFER_WIFI = 0,
 | |
|     COEX_PREFER_BT,
 | |
|     COEX_PREFER_BALANCE,
 | |
|     COEX_PREFER_NUM,
 | |
| } coex_prefer_t;
 | |
| 
 | |
| typedef void (* coex_func_cb_t)(uint32_t event, int sched_cnt);
 | |
| 
 | |
| /**
 | |
|  * @brief Pre-Init software coexist
 | |
|  *        extern function for internal use.
 | |
|  *
 | |
|  * @return Init ok or failed.
 | |
|  */
 | |
| esp_err_t coex_pre_init(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Init software coexist
 | |
|  *        extern function for internal use.
 | |
|  *
 | |
|  * @return Init ok or failed.
 | |
|  */
 | |
| esp_err_t coex_init(void);
 | |
| 
 | |
| /**
 | |
|  * @brief De-init software coexist
 | |
|  *        extern function for internal use.
 | |
|  */
 | |
| void coex_deinit(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Enable software coexist
 | |
|  *        extern function for internal use.
 | |
|  *
 | |
|  * @return Enable ok or failed.
 | |
|  */
 | |
| esp_err_t coex_enable(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Disable software coexist
 | |
|  *        extern function for internal use.
 | |
|  */
 | |
| void coex_disable(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Get software coexist version string
 | |
|  *        extern function for internal use.
 | |
|  * @return : version string
 | |
|  */
 | |
| const char *coex_version_get(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Coexist performance preference set from libbt.a
 | |
|  *        extern function for internal use.
 | |
|  *
 | |
|  *  @param prefer : the prefer enumeration value
 | |
|  *  @return : ESP_OK - success, other - failed
 | |
|  */
 | |
| esp_err_t coex_preference_set(coex_prefer_t prefer);
 | |
| 
 | |
| /**
 | |
|  * @brief Get software coexist status.
 | |
|  * @return : software coexist status
 | |
|  */
 | |
| uint32_t coex_status_get(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Set software coexist condition.
 | |
|  * @return : software coexist condition
 | |
|  */
 | |
| void coex_condition_set(uint32_t type, bool dissatisfy);
 | |
| 
 | |
| /**
 | |
|  * @brief WiFi requests coexistence.
 | |
|  *
 | |
|  *  @param event : WiFi event
 | |
|  *  @param latency : WiFi will request coexistence after latency
 | |
|  *  @param duration : duration for WiFi to request coexistence
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_wifi_request(uint32_t event, uint32_t latency, uint32_t duration);
 | |
| 
 | |
| /**
 | |
|  * @brief WiFi release coexistence.
 | |
|  *
 | |
|  *  @param event : WiFi event
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_wifi_release(uint32_t event);
 | |
| 
 | |
| /**
 | |
|  * @brief Set WiFi channel to coexistence module.
 | |
|  *
 | |
|  *  @param primary : WiFi primary channel
 | |
|  *  @param secondary : WiFi secondary channel
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_wifi_channel_set(uint8_t primary, uint8_t secondary);
 | |
| 
 | |
| /**
 | |
|  * @brief Get coexistence event duration.
 | |
|  *
 | |
|  *  @param event : Coexistence event
 | |
|  *  @param duration: Coexistence event duration
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_event_duration_get(uint32_t event, uint32_t *duration);
 | |
| 
 | |
| #if SOC_COEX_HW_PTI
 | |
| /**
 | |
|  * @brief Get coexistence event priority.
 | |
|  *
 | |
|  *  @param event : Coexistence event
 | |
|  *  @param pti: Coexistence event priority
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_pti_get(uint32_t event, uint8_t *pti);
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * @brief Clear coexistence status.
 | |
|  *
 | |
|  *  @param type : Coexistence status type
 | |
|  *  @param status: Coexistence status
 | |
|  */
 | |
| void coex_schm_status_bit_clear(uint32_t type, uint32_t status);
 | |
| 
 | |
| /**
 | |
|  * @brief Set coexistence status.
 | |
|  *
 | |
|  *  @param type : Coexistence status type
 | |
|  *  @param status: Coexistence status
 | |
|  */
 | |
| void coex_schm_status_bit_set(uint32_t type, uint32_t status);
 | |
| 
 | |
| /**
 | |
|  * @brief Set coexistence scheme interval.
 | |
|  *
 | |
|  *  @param interval : Coexistence scheme interval
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_schm_interval_set(uint32_t interval);
 | |
| 
 | |
| /**
 | |
|  * @brief Get coexistence scheme interval.
 | |
|  *
 | |
|  *  @return : Coexistence scheme interval
 | |
|  */
 | |
| uint32_t coex_schm_interval_get(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Get current coexistence scheme period.
 | |
|  *
 | |
|  *  @return : Coexistence scheme period
 | |
|  */
 | |
| uint8_t coex_schm_curr_period_get(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Get current coexistence scheme phase.
 | |
|  *
 | |
|  *  @return : Coexistence scheme phase
 | |
|  */
 | |
| void * coex_schm_curr_phase_get(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Set current coexistence scheme phase index.
 | |
|  *
 | |
|  *  @param interval : Coexistence scheme phase index
 | |
|  *  @return : 0 - success, other - failed
 | |
|  */
 | |
| int coex_schm_curr_phase_idx_set(int idx);
 | |
| 
 | |
| /**
 | |
|  * @brief Get current coexistence scheme phase index.
 | |
|  *
 | |
|  *  @return : Coexistence scheme phase index
 | |
|  */
 | |
| int coex_schm_curr_phase_idx_get(void);
 | |
| 
 | |
| /**
 | |
|  * @brief Register coexistence adapter functions.
 | |
|  *
 | |
|  *  @param funcs : coexistence adapter functions
 | |
|  *  @return : ESP_OK - success, other - failed
 | |
|  */
 | |
| esp_err_t esp_coex_adapter_register(coex_adapter_funcs_t *funcs);
 | |
| 
 | |
| /**
 | |
|   * @brief     Check the MD5 values of the coexistence adapter header files in IDF and WiFi library
 | |
|   *
 | |
|   * @attention 1. It is used for internal CI version check
 | |
|   *
 | |
|   * @return
 | |
|   *     - ESP_OK : succeed
 | |
|   *     - ESP_WIFI_INVALID_ARG : MD5 check fail
 | |
|   */
 | |
| esp_err_t esp_coex_adapter_funcs_md5_check(const char *md5);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* __ESP_COEXIST_INTERNAL_H__ */
 | 
