Merge branch 'bugfix/fix_phy_set_tsens_power_twice_issue' into 'master'

phy: fix phy pwdet and tsens power cannot be set twice issue

Closes IDFGH-10369

See merge request espressif/esp-idf!24153
This commit is contained in:
Jiang Jiang Jian
2023-06-12 19:26:37 +08:00

View File

@@ -18,6 +18,8 @@
*/ */
static bool s_wifi_adc_xpd_flag; static bool s_wifi_adc_xpd_flag;
static bool s_wifi_pwdet_xpd_flag;
static bool s_wifi_tsens_xpd_flag;
void include_esp_phy_override(void) void include_esp_phy_override(void)
{ {
@@ -55,6 +57,12 @@ IRAM_ATTR void phy_i2c_exit_critical(void)
void phy_set_pwdet_power(bool en) void phy_set_pwdet_power(bool en)
{ {
if (s_wifi_pwdet_xpd_flag == en) {
/* ignore repeated calls to phy_set_pwdet_power when the state is already correct */
return;
}
s_wifi_pwdet_xpd_flag = en;
if (en) { if (en) {
sar_periph_ctrl_pwdet_power_acquire(); sar_periph_ctrl_pwdet_power_acquire();
} else { } else {
@@ -64,6 +72,12 @@ void phy_set_pwdet_power(bool en)
void phy_set_tsens_power(bool en) void phy_set_tsens_power(bool en)
{ {
if (s_wifi_tsens_xpd_flag == en) {
/* ignore repeated calls to phy_set_tsens_power when the state is already correct */
return;
}
s_wifi_tsens_xpd_flag = en;
if (en) { if (en) {
temperature_sensor_power_acquire(); temperature_sensor_power_acquire();
} else { } else {