laokaiyao f863998e90 driver/i2s: support mclk 4 лет назад
..
adc_hal.h 3ce2d85e9e adc: support adc2 working with WiFi 4 лет назад
adc_types.h 27d9657b6c driver/adc: support adc single sample on s3 4 лет назад
aes_hal.h 51169b0e0c AES/SHA: use GDMA driver instead of LL 5 лет назад
aes_types.h 457ce080ae AES: refactor and add HAL layer 5 лет назад
brownout_hal.h 647dea9395 soc: combine xxx_caps.h into one soc_caps.h 5 лет назад
cpu_hal.h 355dd10257 light sleep: dfs support for esp32c3 5 лет назад
cpu_types.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
dac_hal.h 9afdf54748 hal: added HAL_ASSERT 4 лет назад
dac_types.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
dma_types.h 3176ba11d8 gdma: update DMA soc data for esp32-s3 4 лет назад
ds_hal.h 7eb9ecb4f6 esp_ds: move timeout mechanism to driver layer 4 лет назад
emac_hal.h fe354f1c50 hal/emac_hal: refactord emac_hal 4 лет назад
esp_flash_err.h 5425ef4ee4 hal: extract hal component from soc component 5 лет назад
eth_types.h a6db3a5e77 esp_eth: Change clock mode setting 4 лет назад
gdma_hal.h e6d23a35ec gdma: dynamic alloc DMA channels 5 лет назад
gpio_hal.h cd79f3907d gpio: Disable USB JTAG when setting pins 18 and 19 as GPIOs on ESP32C3 4 лет назад
gpio_types.h 205cd469e9 esp32h2: update driver/hal/soc components to support esp32h2 4 лет назад
i2c_hal.h 2575c0d49f i2c: fix I2C slave clock source selection 4 лет назад
i2c_types.h 82e4a2431a i2c: removed unsupported features on different targets 4 лет назад
i2s_hal.h f863998e90 driver/i2s: support mclk 4 лет назад
i2s_types.h f863998e90 driver/i2s: support mclk 4 лет назад
interrupt_controller_hal.h b23c9142d5 [hal]: cleaned up interrupt mask functions 4 лет назад
interrupt_controller_types.h 5d316ac142 interrupt: added INTC FLEXIBLE capabillity to esp32c3 CPU caps 5 лет назад
lcd_hal.h d0be56b8fe lcd: add LL driver for esp32-s3 4 лет назад
ledc_hal.h b2f390df01 hal: update link to HAL readme.md 5 лет назад
ledc_types.h 48c848a895 driver/ledc: support invert channel output 4 лет назад
mcpwm_hal.h d4fe219c49 mcpwm: refactor driver 4 лет назад
mcpwm_types.h 88c87bfe56 mcpwm: update hal and soc naming 4 лет назад
mpu_hal.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
mpu_types.h 58c3f6a421 hal: explicitly include soc_caps.h 5 лет назад
pcnt_hal.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
pcnt_types.h 58c3f6a421 hal: explicitly include soc_caps.h 5 лет назад
readme.md 5425ef4ee4 hal: extract hal component from soc component 5 лет назад
rmt_hal.h 7b37158ede rmt: distinguish group and channel in HAL layer 5 лет назад
rmt_types.h 8e483e34a8 rmt: restructure rmt_signal_conn_t 4 лет назад
rtc_hal.h 205cd469e9 esp32h2: update driver/hal/soc components to support esp32h2 4 лет назад
rtc_io_hal.h 205cd469e9 esp32h2: update driver/hal/soc components to support esp32h2 4 лет назад
rtc_io_types.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
sdio_slave_hal.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
sdio_slave_ll.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
sdio_slave_types.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
sha_hal.h 51169b0e0c AES/SHA: use GDMA driver instead of LL 5 лет назад
sha_types.h 702e41e1c8 esp32s2: move crypto related functions 4 лет назад
sigmadelta_hal.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
sigmadelta_types.h 17808b3ff8 sigma_delta: add periph signal list and support esp32-s3 5 лет назад
soc_hal.h ff2d9fd96c [freertos] Silence sign-conversion warning 5 лет назад
spi_flash_encrypt_hal.h 0d81edb174 spi_flash: refactoring flash encryption into new api 4 лет назад
spi_flash_hal.h c4f57af6c9 G0: Memory layouts are now part of heap components 4 лет назад
spi_flash_types.h 0d81edb174 spi_flash: refactoring flash encryption into new api 4 лет назад
spi_hal.h a6e14c37b2 SPI: chip select can now be kept active if the bus has been acquired 4 лет назад
spi_slave_hal.h 9b9ea71ff9 spi: remove HSPI macro on esp32c3 and esp32s3 4 лет назад
spi_slave_hd_hal.h 346dea206e spi_slv_hd: add hal_trans_finish comments for clarifying risk 5 лет назад
spi_types.h 85e29dace7 spi_slave_hd: add callback after data is loaded to the DMA for segment mode 4 лет назад
systimer_hal.h ec898b771e systimer: strip hal driver 4 лет назад
systimer_types.h 7c1e1c9e2d systimer: update soc data 4 лет назад
timer_hal.h 1966f00f0b soc: updates caps usage 5 лет назад
timer_types.h e4c8ec6174 timergroup: move interrupt index into peripheral description file 5 лет назад
touch_sensor_hal.h 66fb5a29bb Whitespace: Automated whitespace fixes (large commit) 5 лет назад
touch_sensor_types.h 7c08be5771 hal: Add initial ESP32-C3 support 5 лет назад
twai_hal.h 2f58060921 TWAI: FIFO overrun handling and errata workarounds 4 лет назад
twai_types.h d604bf05af TWAI: Fix incorrect configuration initializers for low speed bit rates 4 лет назад
uart_hal.h 6317f5b481 add uart core reset in uart_module_enable() 4 лет назад
uart_types.h fb8b905539 uart: add uart support on esp32s3 5 лет назад
usb_hal.h 5425ef4ee4 hal: extract hal component from soc component 5 лет назад
usb_types_private.h 46020fe13a usb/hal/soc: initial copy of usbh support from esp32s2 4 лет назад
usbh_hal.h d37451f2c7 USB HCD: Add pipe persistence feature 4 лет назад
usbh_ll.h 46020fe13a usb/hal/soc: initial copy of usbh support from esp32s2 4 лет назад
wdt_hal.h 647dea9395 soc: combine xxx_caps.h into one soc_caps.h 5 лет назад
wdt_types.h 5425ef4ee4 hal: extract hal component from soc component 5 лет назад

readme.md

HAL Layer Readme

The HAL layer is designed to be used by the drivers. We don't guarantee the stability and back-compatibility among versions. The HAL layer may update very frequently with the driver. Please don't use them in the applications or treat them as stable APIs.

The HAL layer consists of two layers: HAL (upper) and Lowlevel(bottom). The HAL layer defines the steps and data required by the peripheral. The lowlevel is a translation layer converting general conceptions to register configurations.

Lowlevel

This layer should be all static inline. The first argument of LL functions is usually a pointer to the beginning address of the peripheral register. Each chip should have its own LL layer. The functions in this layer should be atomic and independent from each other so that the upper layer can change/perform one of the options/operation without touching the others.

HAL

This layer should depend on the operating system as little as possible. It's a wrapping of LL functions, so that the upper layer can combine basic steps into different working ways (polling, non-polling, interrupt, etc.). Without using queues/locks/delay/loop/etc., this layer can be easily port to other os or simulation systems.

To get better performance and better porting ability, contexts are used to hold sustainable data and pass the parameters.

To develop your own driver, it is suggested to copy the HAL layer to your own code and keep them until manual update.