Ivan Grokhotkov d7928bf1db Merge branch 'feature/esp32c3_apptrace' into 'master' 4 tahun lalu
..
include dc6b950257 doc: Add performance guides for execuion speed, binary size, RAM usage 4 tahun lalu
port d7928bf1db Merge branch 'feature/esp32c3_apptrace' into 'master' 4 tahun lalu
test c112bd8b57 esp_system: move intr_alloc 4 tahun lalu
CMakeLists.txt 6061a547e5 esp_phy: decouple esp_phy component from esp_wifi and bt 4 tahun lalu
Kconfig f2fe0847d5 usb_serial_jtag: add initial support for S3 (including flashing, monitoring, writing, and reading) but console is not avaliable now 4 tahun lalu
README.md 32aa5f7e25 esp_system: add notes on timekeeping 4 tahun lalu
app.lf bbc599493e esp32: move common fragment definitions 4 tahun lalu
component.mk 6061a547e5 esp_phy: decouple esp_phy component from esp_wifi and bt 4 tahun lalu
crosscore_int.c 393bd64a1e esp32: move crosscore int 4 tahun lalu
dbg_stubs.c 6e80811ca2 log: Remove redundant definition of LOG_LOCAL_LEVEL 4 tahun lalu
esp_err.c c16ceafa5c esp_common: move esp_err 5 tahun lalu
esp_system.c a7bac58480 esp32: move system api to esp_system 4 tahun lalu
fpga_overrides.c 349f0cad3e esp_common: other movements 5 tahun lalu
freertos_hooks.c 0e0914476c esp_common: move freertos hooks 5 tahun lalu
int_wdt.c deaad431f4 esp_common: move task, int wdt 5 tahun lalu
linker.lf 9069f70db3 system: add option to enable undefined behavior sanitizer (UBSAN) 4 tahun lalu
panic.c 821869d98d apptrace: Refactors apptrace for better support various tracing HW 4 tahun lalu
sdkconfig.rename 51e66d0f82 esp_common: move configs 5 tahun lalu
stack_check.c 6e80811ca2 log: Remove redundant definition of LOG_LOCAL_LEVEL 4 tahun lalu
startup.c 821869d98d apptrace: Refactors apptrace for better support various tracing HW 4 tahun lalu
system_time.c 5228d9f9ce esp32c3: Apply one-liner/small changes for ESP32-C3 5 tahun lalu
task_wdt.c a90f29fced wdt: Updates 4 tahun lalu
ubsan.c 9069f70db3 system: add option to enable undefined behavior sanitizer (UBSAN) 4 tahun lalu

README.md

System Notes

Timekeeping

The following are the timekeeping mechanisms available and their differences:

  1. System time (esp_system_get_time)

Time with the origin at g_startup_time. The implementation is not handled by esp_system, but it does provide a default implementation using RTC timer. Currently, esp_timer provides system time, since the hardware timers are under the control of that component. However, no matter the underlying timer, the system time provider should maintain the definition of having the origin point at g_startup_time.

  1. esp_timer time (esp_timer_get_time)

This is the time read from an underlying hardware timer, controlled through config. Origin is at the point where the underlying timer starts counting.

  1. newlib time (gettimeofday)

Timekeeping function in standard library. Can be set (settimeofday) or moved forward/backward (adjtime); with the possibility of the changes being made persistent through config. Currently implemented in terms of system time, as the point of origin is fixed. If persistence is enabled, RTC time is also used in conjuction with system time.

  1. RTC time (esp_rtc_get_time_us)

Time read from RTC timer.