Jeroen Domburg 2d393f0530 Change inline assembly bits from macros to inline functions преди 9 години
..
include 2d393f0530 Change inline assembly bits from macros to inline functions преди 9 години
FreeRTOS-openocd.c a44c45e63e Add files I forgot (FreeRTOS-openocd.c and panic.h) преди 9 години
Kconfig 1bae606ccc FreeRTOS KConfig: Limit tick rate to 1000Hz преди 9 години
component.mk 3b1c3dab4b Name component makefiles component.mk instead of Makefile преди 9 години
croutine.c fc53bb6ed5 Add UNTESTED_FUNCTION() call to untested functions, make Kconfig option to enable that to map to assert() преди 9 години
event_groups.c 8db85d71b2 Fix UNTESTED_FUNCTION includes, remove unnecessary mux initialization in event groups преди 9 години
gdbstub.c 41d397cf3f Only modify headers in soc/ . преди 9 години
gdbstub.h bd6ea4393c Initial public version преди 9 години
heap_regions.c b21d2dfa6b FreeRTOS: temporary solution for memory canaries and memory debug преди 9 години
heap_regions_debug.c b21d2dfa6b FreeRTOS: temporary solution for memory canaries and memory debug преди 9 години
license.txt bd6ea4393c Initial public version преди 9 години
list.c bd6ea4393c Initial public version преди 9 години
panic.c 0403d43b19 Optimize xPortGetCoreID to 2-instruction inline assembly. преди 9 години
port.c 2d393f0530 Change inline assembly bits from macros to inline functions преди 9 години
portasm.S d00ef1607e Some more optimizations, mostly in involuntary task switches. Doesn not really help here, but might in other cases. преди 9 години
queue.c a59897d656 Merge branch 'master' into feature/freertos_untested_feature_assert преди 9 години
readme_smp.txt 29c2e58c75 'Merge branch 'thread_local_storage_delete_callbacks' into 'master' преди 9 години
readme_xtensa.txt bd6ea4393c Initial public version преди 9 години
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. преди 9 години
stdint.readme bd6ea4393c Initial public version преди 9 години
tasks.c df31bb8dfc Rename include, use spaces instead of tabs преди 9 години
timers.c 925fbb587e Add static initializers for muxes, add mutex init to vPortCPUAcquireMutex преди 9 години
xtensa_context.S bd6ea4393c Initial public version преди 9 години
xtensa_init.c bd6ea4393c Initial public version преди 9 години
xtensa_intr.c bd6ea4393c Initial public version преди 9 години
xtensa_intr_asm.S bd6ea4393c Initial public version преди 9 години
xtensa_overlay_os_hook.c bd6ea4393c Initial public version преди 9 години
xtensa_vectors.S d00ef1607e Some more optimizations, mostly in involuntary task switches. Doesn not really help here, but might in other cases. преди 9 години
xtensa_vectors.S-new bd6ea4393c Initial public version преди 9 години
xtensa_vectors.S-old bd6ea4393c Initial public version преди 9 години

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.