2022-03-01 03:12:45 -05:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
2022-07-15 00:52:44 -04:00
|
|
|
#include "esp_attr.h"
|
2022-03-01 03:12:45 -05:00
|
|
|
#include "esp_private/regi2c_ctrl.h"
|
2022-07-15 00:52:44 -04:00
|
|
|
#include "esp_private/adc_private.h"
|
2022-03-01 03:12:45 -05:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is used to override the hooks provided by the PHY lib for some system features.
|
|
|
|
* Call phy_override() so that this file will be linked.
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool s_wifi_adc_xpd_flag;
|
|
|
|
|
|
|
|
void include_esp_phy_override(void)
|
|
|
|
{
|
|
|
|
/* When this empty function is called, all functions below will be linked. */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Coordinate ADC power with other modules. */
|
|
|
|
// It seems that it is only required on ESP32, but we still compile it for all chips, in case it is
|
|
|
|
// called by PHY unexpectedly.
|
|
|
|
void set_xpd_sar(bool en)
|
|
|
|
{
|
|
|
|
if (s_wifi_adc_xpd_flag == en) {
|
|
|
|
/* ignore repeated calls to set_xpd_sar when the state is already correct */
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
s_wifi_adc_xpd_flag = en;
|
|
|
|
if (en) {
|
|
|
|
adc_power_acquire();
|
|
|
|
} else {
|
|
|
|
adc_power_release();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//add spinlock protection
|
2022-04-13 00:15:38 -04:00
|
|
|
IRAM_ATTR void phy_i2c_enter_critical(void)
|
2022-03-01 03:12:45 -05:00
|
|
|
{
|
|
|
|
regi2c_enter_critical();
|
|
|
|
}
|
|
|
|
|
2022-04-13 00:15:38 -04:00
|
|
|
IRAM_ATTR void phy_i2c_exit_critical(void)
|
2022-03-01 03:12:45 -05:00
|
|
|
{
|
|
|
|
regi2c_exit_critical();
|
|
|
|
}
|