kopia lustrzana https://github.com/espressif/esp-idf
Merge branch 'bugfix/watchpoint_on_shared_stacl' into 'master'
shared_stack: fixed watchpoint placement on shared stack See merge request espressif/esp-idf!7522pull/4752/head
commit
f9bc4fc08b
|
@ -15,6 +15,7 @@
|
|||
|
||||
#include "freertos/FreeRTOS.h"
|
||||
#include "freertos/semphr.h"
|
||||
#include "freertos/task.h"
|
||||
#include "esp_debug_helpers.h"
|
||||
#include "esp_log.h"
|
||||
|
||||
|
@ -42,6 +43,10 @@ extern "C" {
|
|||
expression; \
|
||||
} \
|
||||
esp_switch_stack_exit(&backup); \
|
||||
StaticTask_t *current = (StaticTask_t *)xTaskGetCurrentTaskHandle(); \
|
||||
/* pxDummy6 is the stack base of current thread defined in TCB_t */ \
|
||||
/* place the watchpoint on current task stack after function execution*/ \
|
||||
vPortSetStackWatchpoint(current->pxDummy6); \
|
||||
xSemaphoreGive(lock); \
|
||||
})
|
||||
|
||||
|
|
|
@ -386,6 +386,7 @@ extern void esp_vApplicationTickHook( void );
|
|||
|
||||
void _xt_coproc_release(volatile void * coproc_sa_base);
|
||||
void vApplicationSleep( TickType_t xExpectedIdleTime );
|
||||
void vPortSetStackWatchpoint( void* pxStackStart );
|
||||
|
||||
#define portSUPPRESS_TICKS_AND_SLEEP( idleTime ) vApplicationSleep( idleTime )
|
||||
|
||||
|
|
|
@ -19,7 +19,8 @@
|
|||
StackType_t * esp_switch_stack_setup(StackType_t *stack, size_t stack_size)
|
||||
{
|
||||
#if CONFIG_FREERTOS_WATCHPOINT_END_OF_STACK
|
||||
int watchpoint_place = (((int)stack + 31) & ~31);
|
||||
esp_clear_watchpoint(1);
|
||||
uint32_t watchpoint_place = ((uint32_t)stack + 32) & 0x1f ;
|
||||
#endif
|
||||
StackType_t *top_of_stack = (StackType_t *)&stack[0] +
|
||||
((stack_size * sizeof(StackType_t)) / sizeof(StackType_t));
|
||||
|
@ -35,7 +36,7 @@ StackType_t * esp_switch_stack_setup(StackType_t *stack, size_t stack_size)
|
|||
frame->a1 = (UBaseType_t)top_of_stack;
|
||||
|
||||
#if CONFIG_FREERTOS_WATCHPOINT_END_OF_STACK
|
||||
esp_set_watchpoint(2, (char*)watchpoint_place, 32, ESP_WATCHPOINT_STORE);
|
||||
esp_set_watchpoint(1, (uint8_t *)watchpoint_place, 32, ESP_WATCHPOINT_STORE);
|
||||
#endif
|
||||
|
||||
return top_of_stack;
|
||||
|
|
|
@ -47,15 +47,10 @@ esp_switch_stack_exit:
|
|||
#ifndef __XTENSA_CALL0_ABI__
|
||||
entry sp, 0x10
|
||||
|
||||
#if CONFIG_FREERTOS_WATCHPOINT_END_OF_STACK
|
||||
movi a6, 2
|
||||
movi a4, esp_clear_watchpoint
|
||||
callx4 a4 /* clear the watchpoint before releasing stack */
|
||||
#endif
|
||||
|
||||
l32i a4, a2, 0 /* recover the original task stack */
|
||||
mov a1, a4 /* put it on sp register again */
|
||||
retw
|
||||
|
||||
#else
|
||||
#error "this code is written for Window ABI"
|
||||
#endif
|
||||
|
|
Ładowanie…
Reference in New Issue