Peripherals
Peripheral Clock Gating
As usual, peripheral clock gating is still handled by driver itself, users don’t need to take care of the peripheral module clock gating.
However, for advanced users who implement their own drivers based on hal
and soc
components, the previous clock gating include path has been changed from driver/periph_ctrl.h
to esp_private/periph_ctrl.h
.
RTC Subsystem Control
RTC control APIs have been moved from driver/rtc_cntl.h
to esp_private/rtc_ctrl.h
.
ADC
ADC oneshot mode driver has been redesigned. New driver is in
esp_adc
component and the include path isesp_adc/adc_oneshot.h
. Legacy driver is still available in the previous include pathdriver/adc.h
. However, by default, includingdriver/adc.h
will bring a build warning like legacy adc driver is deprecated, please migrate to use esp_adc/adc_oneshot.h and esp_adc/adc_continuous.h for oneshot mode and continuous mode drivers respectively. The warning can be suppressed by the Kconfig option CONFIG_ADC_SUPPRESS_DEPRECATE_WARN.ADC continuous mode driver has been moved from
driver
component toesp_adc
component. Include path has been changed fromdriver/adc.h
toesp_adc/adc_continuous.h
. Legacy driver is still available in the previous include pathdriver/adc.h
. Similarly, including it will bring a build warning, and it can be suppressed by the Kconfig option CONFIG_ADC_SUPPRESS_DEPRECATE_WARN.ADC calibration driver has been redesigned. New driver is in
esp_adc
component and the include path isesp_adc/adc_cali.h
andesp_adc/adc_cali_scheme.h
. Legacy driver is still available by includingesp_adc_cal.h
. However, by default, includingesp_adc_cal.h
will bring a build warning like legacy adc calibration driver is deprecated, please migrate to use esp_adc/adc_cali.h and esp_adc/adc_cali_scheme.h. The warning can be suppressed by the Kconfig option CONFIG_ADC_CALI_SUPPRESS_DEPRECATE_WARN.API
adc_power_acquire
andadc_power_release
have been deprecated. These two are used by other drivers to maintain ADC power due to hardware limitation. After this change, ADC power will still be handled by the drivers. However, for users who are interested in this, the include path has been changed fromdriver/adc.h
toesp_private/adc_share_hw_ctrl.h
.Previous
driver/adc2_wifi_private.h
has been moved toesp_private/adc_share_hw_ctrl.h
.Enums
ADC_UNIT_BOTH
,ADC_UNIT_ALTER
andADC_UNIT_MAX
inadc_unit_t
have been removed.Enum
ADC_CHANNEL_MAX
inadc_channel_t
has been removed. Some channels are not supported on some chips, driver will give a dynamic error if an unsupported channels are used.Enum
ADC_ATTEN_MAX
has been removed. Some attenuations are not supported on some chips, driver will give a dynamic error if an unsupported attenuation is used.Enum
ADC_CONV_UNIT_MAX
has been removed. Some convert mode are not supported on some chips, driver will give a dynamic error if an unsupported convert mode is used.API
hall_sensor_read
on ESP32 has been removed. Hall sensor is no more supported on ESP32.API
adc_set_i2s_data_source
andadc_i2s_mode_init
have been deprecated. Related enumadc_i2s_source_t
has been deprecated. Please migrate to useesp_adc/adc_continuous.h
.
GPIO
The previous Kconfig option RTCIO_SUPPORT_RTC_GPIO_DESC has been removed, thus the
rtc_gpio_desc
array is unavailable. Please usertc_io_desc
array instead.GPIO interrupt users callbacks should no longer read the GPIO interrupt status register to get the triggered GPIO’s pin number. Users should use the callback argument to determine the GPIO’s pin number instead.
Previously, when a GPIO interrupt occurs, the GPIO’s interrupt status register is cleared after calling the user callbacks. Thus, it was possible for users to read the GPIO’s interrupt status register inside the callback to determine which GPIO was triggered.
However, clearing the interrupt status after the user callbacks can potentially cause edge-triggered interrupts to be lost. For example, if an edge-triggered interrupt (re)triggers while the user callbacks are being called, that interrupt will be cleared without its registered user callback being handled.
Now, the GPIO’s interrupt status register is cleared before invoking the user callbacks. Thus, users can no longer read the GPIO interrupt status register to determine which pin has triggered the interrupt. Instead, users should use the callback argument to pass the pin number.
Timer Group Driver
Timer Group driver has been redesigned into GPTimer, which aims to unify and simplify the usage of general purpose timer. Although it’s recommended to use the the new driver APIs, the legacy driver is still available in the previous include path driver/timer.h
. However, by default, including driver/timer.h
will bring a build warning like legacy timer group driver is deprecated, please migrate to driver/gptimer.h
. The warning can be suppressed by the Kconfig option CONFIG_GPTIMER_SUPPRESS_DEPRECATE_WARN.
The major breaking changes in concept and usage are listed as follows:
Breaking Changes in Concepts
timer_group_t
andtimer_idx_t
which used to identify the hardware timer are removed from user’s code. In the new driver, a timer is represented bygptimer_handle_t
.Definition of timer source clock is moved to
gptimer_clock_source_t
, the previoustimer_src_clk_t
is not used.Definition of timer count direction is moved to
gptimer_count_direction_t
, the previoustimer_count_dir_t
is not used.Only level interrupt is supported,
timer_intr_t
andtimer_intr_mode_t
are not used.Auto-reload is enabled by set the
gptimer_alarm_config_t::auto_reload_on_alarm
flag.timer_autoreload_t
is not used.
Breaking Changes in Usage
Timer initialization is done by creating a timer instance from
gptimer_new_timer()
. Basic configurations like clock source, resolution and direction should be set ingptimer_config_t
. Note that, alarm event specific configurations are not needed during the driver install stage.Alarm event is configured by
gptimer_set_alarm_action()
, with parameters set in thegptimer_alarm_config_t
.Setting and getting count value are done by
gptimer_get_raw_count()
andgptimer_set_raw_count()
. The driver doesn’t help convert the raw value into UTC time-stamp. Instead, the conversion should be done form user’s side as the timer resolution is also known to the user.The driver will install the interrupt service as well if
gptimer_event_callbacks_t::on_alarm
is set to a valid callback function. In the callback, user doesn’t have to deal with the low level registers (like “clear interrupt status”, “re-enable alarm event” and so on). So functions liketimer_group_get_intr_status_in_isr
andtimer_group_get_auto_reload_in_isr
are not used anymore.To update the alarm configurations when alarm event happens, one can call
gptimer_set_alarm_action()
in the interrupt callback, then the alarm will be re-enabled again.Alarm will always be re-enabled by the driver if
gptimer_alarm_config_t::auto_reload_on_alarm
is set to true.
UART
Removed/Deprecated items |
Replacement |
Remarks |
---|---|---|
|
None |
UART interrupt handling is implemented by driver itself. |
|
None |
UART interrupt handling is implemented by driver itself. |
|
Select the clock source. |
|
|
Enable pattern detection interrupt. |
I2C
Removed/Deprecated items |
Replacement |
Remarks |
---|---|---|
|
None |
I2C interrupt handling is implemented by driver itself. |
|
None |
I2C interrupt handling is implemented by driver itself. |
|
None |
It’s not used anywhere in esp-idf. |
SPI
Removed/Deprecated items |
Replacement |
Remarks |
---|---|---|
|
Get SPI real working frequency. |
The internal header file
spi_common_internal.h
has been moved toesp_private/spi_common_internal.h
.
LEDC
Removed/Deprecated items |
Replacement |
Remarks |
---|---|---|
|
Set resolution of the duty cycle. |
Temperature Sensor Driver
Old API header
temp_sensor.h
has been redesigned astemperature_sensor.h
, it is recommended to use the new driver and the old driver is not allowed to be used at the same time.Although it’s recommended to use the new driver APIs, the legacy driver is still available in the previous include path
driver/temp_sensor.h
. However, by default, includingdriver/temp_sensor.h
will bring a build warning like “legacy temperature sensor driver is deprecated, please migrate to driver/temperature_sensor.h”. The warning can be suppressed by enabling the menuconfig option CONFIG_TEMP_SENSOR_SUPPRESS_DEPRECATE_WARN.Configuration contents has been changed. In old version, user need to configure the
clk_div
anddac_offset
. While in new version, user only need to choosetsens_range
The process of using temperature sensor has been changed. In old version, user can use
config->start->read_celsius
to get value. In the new version, user must install the temperature sensor driver firstly, bytemperature_sensor_install
and uninstall it when finished. For more information, you can refer to Temperature Sensor .
LCD
The LCD panel initialization flow is slightly changed. Now the
esp_lcd_panel_init()
won’t turn on the display automatically. User needs to callesp_lcd_panel_disp_on_off()
to manually turn on the display. Note, this is different from turning on backlight. With this breaking change, user can flush a predefined pattern to the screen before turning on the screen. This can help avoid random noise on the screen after a power on reset.esp_lcd_panel_disp_off()
is deprecated, please useesp_lcd_panel_disp_on_off()
instead.dc_as_cmd_phase
is removed. The SPI LCD driver currently doesn’t support a 9bit SPI LCD. Please always use a dedicated GPIO to control the LCD D/C line.The way to register RGB panel event callbacks has been moved from the
esp_lcd_rgb_panel_config_t
into a separate APIesp_lcd_rgb_panel_register_event_callbacks()
. However, the event callback signature is not changed.Previous
relax_on_idle
flag inesp_lcd_rgb_panel_config_t
has been renamed intoesp_lcd_rgb_panel_config_t::refresh_on_demand
, which expresses the same meaning but with a clear name.If the RGB LCD is created with the
refresh_on_demand
flag enabled, the driver won’t start a refresh in theesp_lcd_panel_draw_bitmap()
. Now you have to callesp_lcd_rgb_panel_refresh()
to refresh the screen by yourself.esp_lcd_color_space_t
is deprecated, please uselcd_color_space_t
to describe the color space, and uselcd_color_rgb_endian_t
to describe the data order of RGB color.
Dedicated GPIO Driver
All of the dedicated GPIO related LL functionsn in
cpu_ll.h
have been moved todedic_gpio_cpu_ll.h
and renamed.
Register access macros
Previously, all register access macros could be used as expressions, so the following was allowed:
uint32_t val = REG_SET_BITS(reg, mask);
In IDF v5.0, register access macros which write or read-modify-write the register can no longer be used as expressions, and can only be used as statements. This applies to the following macros: REG_WRITE
, REG_SET_BIT
, REG_CLR_BIT
, REG_SET_BITS
, REG_SET_FIELD
, WRITE_PERI_REG
, CLEAR_PERI_REG_MASK
, SET_PERI_REG_MASK
, SET_PERI_REG_BITS
.
To store the value which would have been written into the register, split the operation as follows:
uint32_t new_val = REG_READ(reg) | mask;
REG_WRITE(reg, new_val);
To get the value of the register after modification (which may be different from the value written), add an explicit read:
REG_SET_BITS(reg, mask);
uint32_t new_val = REG_READ(reg);