/* * SPDX-FileCopyrightText: 2015-2025 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 *//* ... */#pragmaonce#include"sdkconfig.h"#include"esp_phy_init.h"#include"soc/soc_caps.h"#ifdef__cplusplusextern"C"{#endif#defineESP_CAL_DATA_CHECK_FAIL1typedefstruct{uint8_tcmd_type;/* the command type of the current phy i2c master command memory config */struct{uint8_tstart,end;/* the start and end index of phy i2c master command memory */uint8_thost_id;/* phy i2c master host id */}{ ... }config;}{ ... }phy_i2c_master_command_attribute_t;/** * @file phy.h * @brief Declarations for functions provided by libphy.a *//* ... *//** * @brief Return ROM function pointer table from PHY library. *//* ... */voidphy_get_romfunc_addr(void);/** * @brief Initialize PHY module and do RF calibration * @param[in] init_data Initialization parameters to be used by the PHY * @param[inout] cal_data As input, calibration data previously obtained. As output, will contain new calibration data. * @param[in] cal_mode RF calibration mode * @return ESP_CAL_DATA_CHECK_FAIL if the calibration data checksum fails or if the calibration data is outdated, other values are reserved for future use *//* ... */intregister_chipv7_phy(constesp_phy_init_data_t*init_data,esp_phy_calibration_data_t*cal_data,esp_phy_calibration_mode_tcal_mode);/** * @brief Get the format version of calibration data used by PHY library. * @return Format version number, OR'ed with BIT(16) if PHY is in WIFI only mode. *//* ... */uint32_tphy_get_rf_cal_version(void);/** * @brief Set RF/BB for only WIFI mode or coexist(WIFI & BT) mode * @param[in] true is for only WIFI mode, false is for coexist mode. default is 0. * @return NULL *//* ... */voidphy_set_wifi_mode_only(boolwifi_only);/** * @brief Set BT the highest priority in coexist mode. * @return NULL *//* ... */voidcoex_bt_high_prio(void);/** * @brief Open PHY and RF. *//* ... */voidphy_wakeup_init(void);/** * @brief Shutdown PHY and RF. *//* ... */voidphy_close_rf(void);#if!CONFIG_IDF_TARGET_ESP32/** * @brief Disable PHY temperature sensor. *//* ... */voidphy_xpd_tsens(void);/* ... */#endif#ifCONFIG_IDF_TARGET_ESP32C3/** * @brief Update internal state of PHY when wifi deinit powers off the wifi power domain. *//* ... */voidphy_init_flag(void);/* ... */#endif#ifSOC_PM_SUPPORT_PMU_MODEM_STATE/** * @brief Get the configuration info of PHY i2c master command memory. * * @param[out] attr the configuration info of PHY i2c master command memory * @param[out] size the count of PHY i2c master command memory configuration *//* ... */voidphy_i2c_master_command_mem_cfg(phy_i2c_master_command_attribute_t*attr,int*size);/* ... */#endif/** * @brief Store and load PHY digital registers. * * @param backup_en if backup_en is true, store PHY digital registers to memory. Otherwise load PHY digital registers from memory * @param mem_addr Memory address to store and load PHY digital registers * * @return memory size *//* ... */uint8_tphy_dig_reg_backup(boolbackup_en,uint32_t*mem_addr);#ifCONFIG_MAC_BB_PD/** * @brief Store and load baseband registers. *//* ... */voidphy_freq_mem_backup(boolbackup_en,uint32_t*mem);/* ... */#endif#ifCONFIG_ESP_PHY_ENABLE_USB/** * @brief Enable or disable USB when phy init. *//* ... */voidphy_bbpll_en_usb(boolen);/* ... */#endif#ifCONFIG_IDF_TARGET_ESP32S2/** * @brief Phy version select for ESP32S2 *//* ... */voidphy_eco_version_sel(uint8_tchip_ver);/* ... */#endif#ifCONFIG_ESP_PHY_IMPROVE_RX_11B/** * @brief Improve Wi-Fi receive 11b pkts when modules with high interference. * * @attention 1.This is a workaround to improve Wi-Fi receive 11b pkts for some modules using AC-DC power supply with high interference. * @attention 2.Enable this will sacrifice Wi-Fi OFDM receive performance.But to guarantee 11b receive performance serves as a bottom line in this case. * * @param enable Enable or disable. *//* ... */voidphy_improve_rx_special(boolenable);/* ... */#endif/** * @brief Enable phy track pll * *//* ... */voidphy_track_pll_init(void);/** * @brief Disable phy track pll * *//* ... */voidphy_track_pll_deinit(void);/** * @brief Set the flag recorded which modem has already enabled phy * *//* ... */voidphy_set_modem_flag(esp_phy_modem_tmodem);/** * @brief Clear the flag to record which modem calls phy disenable *//* ... */voidphy_clr_modem_flag(esp_phy_modem_tmodem);/** * @brief Get the flag recorded which modem has already enabled phy * *//* ... */esp_phy_modem_tphy_get_modem_flag(void);/** * @brief Get the PHY lock, only used in esp_phy, the user should not use this function. * *//* ... */_lock_tphy_get_lock(void);/** * @brief Call this funnction to track pll immediately. * *//* ... */voidphy_track_pll(void);/** * @brief PHY antenna default configuration * *//* ... */voidant_dft_cfg(booldefault_ant);/** * @brief PHY tx antenna config * *//* ... */voidant_tx_cfg(uint8_tant0);/** * @brief PHY rx antenna config * *//* ... */voidant_rx_cfg(boolauto_en,uint8_tant0,uint8_tant1);/** * @brief PHY antenna need update * *//* ... */boolphy_ant_need_update(void);/** * @brief PHY antenna need update * *//* ... */voidphy_ant_clr_update_flag(void);/** * @brief PHY antenna configuration update * *//* ... */voidphy_ant_update(void);#ifSOC_PM_SUPPORT_PMU_MODEM_STATE/** * @brief Get the REGDMA config value of the BBPLL in analog i2c master burst mode * * @return the BBPLL REGDMA configure value of i2c master burst mode *//* ... */uint32_tphy_ana_i2c_master_burst_bbpll_config(void);/** * @brief Get the REGDMA config value of the RF PHY on or off in analog i2c master burst mode * * @param[in] on true for enable RF PHY, false for disable RF PHY. * * @return the RF on or off configure value of i2c master burst mode *//* ... */uint32_tphy_ana_i2c_master_burst_rf_onoff(boolon);/* ... */#endif#ifCONFIG_ESP_WIFI_ENHANCED_LIGHT_SLEEP/** * @brief On sleep->modem->active wakeup process, since RF has been turned on by hardware in * modem state, `sleep_modem_wifi_do_phy_retention` and `phy_wakeup_init` will be skipped * in `esp_phy_enable`, but there are still some configurations that need to be restored * by software, which are packed in this function. *//* ... */voidphy_wakeup_from_modem_state_extra_init(void);/* ... */#endif#ifSOC_PM_MODEM_RETENTION_BY_REGDMA&&CONFIG_MAC_BB_PD/** * @brief PHY module sleep data (includes AGC, TX, NRX, BB, FE, etc..) initialize. *//* ... */voidesp_phy_sleep_data_init(void);/** * @brief PHY module sleep data de-initialize. *//* ... */voidesp_phy_sleep_data_deinit(void);/* ... */#endif#ifdef__cplusplus}{...}#endif
Details
Show: from
Types: Columns:
All items filtered out
All items filtered out
This file uses the notable symbols shown below. Click anywhere in the file to view more details.