#include "esp_efuse_utility.h"
#include "soc/efuse_periph.h"
+#include "esp32/clk.h"
#include "esp_log.h"
#include "assert.h"
#include "sdkconfig.h"
}
}
#else
+ // Update Efuse timing configuration
+ uint32_t apb_freq_mhz = esp_clk_apb_freq() / 1000000;
+ uint32_t clk_sel0, clk_sel1, dac_clk_div;
+ if (apb_freq_mhz <= 26) {
+ clk_sel0 = 250;
+ clk_sel1 = 255;
+ dac_clk_div = 52;
+ } else if (apb_freq_mhz <= 40) {
+ clk_sel0 = 160;
+ clk_sel1 = 255;
+ dac_clk_div = 80;
+ } else {
+ clk_sel0 = 80;
+ clk_sel1 = 128;
+ dac_clk_div = 100;
+ }
+ REG_SET_FIELD(EFUSE_DAC_CONF_REG, EFUSE_DAC_CLK_DIV, dac_clk_div);
+ REG_SET_FIELD(EFUSE_CLK_REG, EFUSE_CLK_SEL0, clk_sel0);
+ REG_SET_FIELD(EFUSE_CLK_REG, EFUSE_CLK_SEL1, clk_sel1);
// Permanently update values written to the efuse write registers
REG_WRITE(EFUSE_CONF_REG, EFUSE_CONF_WRITE);
REG_WRITE(EFUSE_CMD_REG, EFUSE_CMD_PGM);