Angus Gratton 11fac8637a docs: Resolve doxygen & Sphinx warnings 6 år sedan
..
adc_hal.h f49b192a5e refactor the adc driver 6 år sedan
adc_types.h f49b192a5e refactor the adc driver 6 år sedan
brownout_hal.h caef7ad9f2 esp32, esp32s2beta: move brownout.c to esp_common 6 år sedan
can_hal.h a049e02d96 can: Refactor CAN to use HAL and LowLevel layers 6 år sedan
can_types.h a049e02d96 can: Refactor CAN to use HAL and LowLevel layers 6 år sedan
dac_hal.h 03ac1aaafd dac: refactor driver add hal 6 år sedan
dac_types.h e30cd361a8 global: rename esp32s2beta to esp32s2 6 år sedan
esp_flash_err.h 612db28b6f Fix error code collision and CI check 6 år sedan
gpio_hal.h af4c455417 bugfix(gpio):fix esp32 s2 rtc io issue 6 år sedan
gpio_types.h e30cd361a8 global: rename esp32s2beta to esp32s2 6 år sedan
hal_defs.h 538540ce21 mcpwm: add HAL layer support 6 år sedan
i2c_hal.h aac935ec81 bugfix(i2c): fix I2C driver breaking change issue. 6 år sedan
i2c_types.h 11fac8637a docs: Resolve doxygen & Sphinx warnings 6 år sedan
i2s_hal.h 25c0752682 i2s: fix regression in retrieval of chip revision causing apll test to fail 6 år sedan
i2s_types.h 8c76a3c10d refactor(i2s): add hal i2s driver 6 år sedan
ledc_hal.h 857dec108d feat(ledc): refactor ledc driver 6 år sedan
ledc_types.h c7738f24fc Merge branch 'bugfix/ledc_driver_enums' into 'master' 6 år sedan
mcpwm_hal.h 538540ce21 mcpwm: add HAL layer support 6 år sedan
mcpwm_types.h 538540ce21 mcpwm: add HAL layer support 6 år sedan
pcnt_hal.h b1a72866ca refactor(pcnt): add hal pcnt driver 6 år sedan
pcnt_types.h b1a72866ca refactor(pcnt): add hal pcnt driver 6 år sedan
readme.md 33db6d608e spi_slave: add HAL support 6 år sedan
rmt_hal.h 8fd8695ea1 rmt: add HAL layer 6 år sedan
rmt_types.h 8fd8695ea1 rmt: add HAL layer 6 år sedan
rtc_io_hal.h 0c2bf7c8bc rtcio: add hal for driver 6 år sedan
rtc_io_types.h 0c2bf7c8bc rtcio: add hal for driver 6 år sedan
sdio_slave_hal.h 0ec08ca21b sdio_slave: support HAL layer 6 år sedan
sdio_slave_ll.h 0ec08ca21b sdio_slave: support HAL layer 6 år sedan
sdio_slave_types.h 0ec08ca21b sdio_slave: support HAL layer 6 år sedan
sigmadelta_hal.h e62b831867 refactor(sigmadelta): add hal sigmadelta driver 6 år sedan
sigmadelta_types.h e62b831867 refactor(sigmadelta): add hal sigmadelta driver 6 år sedan
spi_flash_hal.h e6ad330018 ble_mesh_wifi_coexist example: Disable Wi-Fi RX IRAM optimisation 6 år sedan
spi_flash_types.h e6ad330018 ble_mesh_wifi_coexist example: Disable Wi-Fi RX IRAM optimisation 6 år sedan
spi_hal.h 5c9dc44c49 spi: multichip support 6 år sedan
spi_slave_hal.h 5c9dc44c49 spi: multichip support 6 år sedan
spi_types.h e30cd361a8 global: rename esp32s2beta to esp32s2 6 år sedan
timer_hal.h bcfe684951 bugfix(timer): add a macro to control making the XTAL related functions 6 år sedan
timer_types.h bcfe684951 bugfix(timer): add a macro to control making the XTAL related functions 6 år sedan
touch_sensor_hal.h e30cd361a8 global: rename esp32s2beta to esp32s2 6 år sedan
touch_sensor_types.h 11fac8637a docs: Resolve doxygen & Sphinx warnings 6 år sedan
uart_hal.h eec8212237 add simplified API to set UART threshold values for RX FIFO full and TX FIFO empty 6 år sedan
uart_types.h 11fac8637a docs: Resolve doxygen & Sphinx warnings 6 år sedan

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.