Jeroen Domburg ffeffcd315 Merge branch 'feature/crosscore_int' into 'master' před 9 roky
..
include ffeffcd315 Merge branch 'feature/crosscore_int' into 'master' před 9 roky
FreeRTOS-openocd.c 4d8ad3c877 Fix int wdt iram, fix some fallout of moving panic stuff to esp32 před 9 roky
Kconfig ffeffcd315 Merge branch 'feature/crosscore_int' into 'master' před 9 roky
component.mk 3b1c3dab4b Name component makefiles component.mk instead of Makefile před 9 roky
croutine.c fc53bb6ed5 Add UNTESTED_FUNCTION() call to untested functions, make Kconfig option to enable that to map to assert() před 9 roky
event_groups.c 8db85d71b2 Fix UNTESTED_FUNCTION includes, remove unnecessary mux initialization in event groups před 9 roky
heap_regions.c b21d2dfa6b FreeRTOS: temporary solution for memory canaries and memory debug před 9 roky
heap_regions_debug.c b21d2dfa6b FreeRTOS: temporary solution for memory canaries and memory debug před 9 roky
license.txt bd6ea4393c Initial public version před 9 roky
list.c bd6ea4393c Initial public version před 9 roky
port.c ffeffcd315 Merge branch 'feature/crosscore_int' into 'master' před 9 roky
portasm.S d00ef1607e Some more optimizations, mostly in involuntary task switches. Doesn not really help here, but might in other cases. před 9 roky
queue.c 8ee1a05914 Merge branch 'master' into feature/freertos_static_buffers před 9 roky
readme_smp.txt 29c2e58c75 'Merge branch 'thread_local_storage_delete_callbacks' into 'master' před 9 roky
readme_xtensa.txt bd6ea4393c Initial public version před 9 roky
ringbuf.c a9502dffd3 Add ringbuf.c. This works like a FreeRTOS queue, but allows for variable-length items which in some cases is more memory efficient than a queue. před 9 roky
stdint.readme bd6ea4393c Initial public version před 9 roky
tasks.c ffeffcd315 Merge branch 'feature/crosscore_int' into 'master' před 9 roky
timers.c 925fbb587e Add static initializers for muxes, add mutex init to vPortCPUAcquireMutex před 9 roky
xtensa_context.S bd6ea4393c Initial public version před 9 roky
xtensa_init.c bd6ea4393c Initial public version před 9 roky
xtensa_intr.c bd6ea4393c Initial public version před 9 roky
xtensa_intr_asm.S bd6ea4393c Initial public version před 9 roky
xtensa_overlay_os_hook.c bd6ea4393c Initial public version před 9 roky
xtensa_vectors.S 38c6256db9 Merge branch 'feature/wdts' into 'master' před 9 roky

readme_smp.txt

This version of FreeRTOS has been modified by Espressif to be SMP-aware. The
API is similar to the original FreeRTOS API, with the following changes:

- The xTaskCreate() function now creates tasks that will run on the first
core only, for backwards compatibility. To schedule tasks on another core,
use xTaskCreatePinnedToCore(), which will accept a core ID as the last
argument. If this is the constant tskNO_AFFINITY, the task will be dynamically
scheduled on whichever core has time.

- vTaskSuspendAll/vTaskResumeAll in non-SMP FreeRTOS will suspend the scheduler
so no other tasks than the current one will run. In this SMP version, it will
only suspend the scheduler ON THE CURRENT CORE. That is, tasks scheduled to
run on the other core(s) or without a specific CPU affinity, will still be
able to run.

- Enabling and disabling interrupts will only affect the current core.
Disabling the interrupts will not disallow other tasks to run as
it would on a single-core system: the other core still will keep on
executing all it's own. Use a mux, queue or semaphore to protect your
structures instead.

- While each core has individual interrupts, the handlers are shared. This
means that when you set a handler for an interrupt, it will get triggered if
the interrupt is triggered on both CPU0 as well as on CPU1. This is something
we may change in future FreeRTOS-esp32 releases.

- This FreeRTOS version has the task local storage backported from the 8.2.x
versions. It, however, has an addition: you can also set a callback when you
set the pointer. This callback will be called by the idle task, with the
pointer as an argument, when the thread is destroyed. This depends on the idle
task getting CPU time; when a thread is hogging the CPU without yielding,
the idle thread won't be called and the delete callback won't be called either.