2018-09-05 02:39:50 +02:00
|
|
|
/*
|
2019-09-05 13:35:58 +02:00
|
|
|
* Copyright (C) 2019 Gunar Schorcht
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2019-12-08 18:38:02 +01:00
|
|
|
* @ingroup cpu_esp_common
|
2018-09-05 02:39:50 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Implementation of the kernel's architecture dependent thread interface
|
|
|
|
*
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "board.h"
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "irq.h"
|
|
|
|
#include "log.h"
|
|
|
|
#include "thread.h"
|
|
|
|
#include "sched.h"
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#include "esp_common.h"
|
|
|
|
#include "irq_arch.h"
|
|
|
|
#include "syscalls.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
#include "tools.h"
|
2019-09-05 13:35:58 +02:00
|
|
|
|
|
|
|
#include "esp_attr.h"
|
|
|
|
#include "rom/ets_sys.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2020-10-22 01:07:14 +02:00
|
|
|
#define ENABLE_DEBUG 0
|
|
|
|
#include "debug.h"
|
|
|
|
|
2019-12-08 18:38:02 +01:00
|
|
|
void thread_stack_print(void)
|
2018-09-05 02:39:50 +02:00
|
|
|
{
|
|
|
|
/* Print the current stack to stdout. */
|
|
|
|
|
2022-06-25 12:46:09 +02:00
|
|
|
#if defined(DEVELHELP)
|
2020-08-17 10:51:10 +02:00
|
|
|
thread_t* task = thread_get_active();
|
2018-09-05 02:39:50 +02:00
|
|
|
if (task) {
|
|
|
|
char* stack_top = task->stack_start + task->stack_size;
|
|
|
|
int size = stack_top - task->sp;
|
|
|
|
printf("Printing current stack of thread %" PRIkernel_pid "\n", thread_getpid());
|
|
|
|
esp_hexdump((void*)(task->sp), size >> 2, 'w', 8);
|
|
|
|
}
|
2022-06-25 12:46:09 +02:00
|
|
|
#else
|
2018-09-05 02:39:50 +02:00
|
|
|
NOT_SUPPORTED();
|
2022-06-25 12:46:09 +02:00
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
|
2019-12-08 18:38:02 +01:00
|
|
|
void thread_print_stack(void)
|
2018-09-05 02:39:50 +02:00
|
|
|
{
|
|
|
|
/* Prints human readable, ps-like thread information for debugging purposes. */
|
|
|
|
NOT_YET_IMPLEMENTED();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#ifdef DEVELHELP
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
extern uint8_t port_IntStack;
|
|
|
|
extern uint8_t port_IntStackTop;
|
|
|
|
|
|
|
|
void thread_isr_stack_init(void)
|
|
|
|
{
|
|
|
|
/* code from thread.c, please see the copyright notice there */
|
2024-02-16 20:38:25 +01:00
|
|
|
#ifndef CPU_ESP8266
|
2019-09-05 13:35:58 +02:00
|
|
|
#define sp (&port_IntStackTop)
|
2024-02-16 20:38:25 +01:00
|
|
|
#else /* !CPU_ESP8266 */
|
2019-09-05 13:35:58 +02:00
|
|
|
register uint32_t *sp __asm__ ("a1");
|
2024-02-16 20:38:25 +01:00
|
|
|
#endif /* !CPU_ESP8266 */
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2020-11-18 10:19:23 +01:00
|
|
|
/* assign each int of the stack the value of it's address. We can safely
|
|
|
|
* cast, as stack is aligned. Use an intermediate cast to uintptr_t to
|
|
|
|
* silence -Wcast-align false positive */
|
|
|
|
uintptr_t *stackmax = (uintptr_t *)(uintptr_t)sp;
|
|
|
|
uintptr_t *stackp = (uintptr_t *)(uintptr_t)&port_IntStack;
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2021-11-25 10:47:33 +01:00
|
|
|
/* cppcheck-suppress comparePointers */
|
2018-09-05 02:39:50 +02:00
|
|
|
while (stackp < stackmax) {
|
|
|
|
*stackp = (uintptr_t) stackp;
|
|
|
|
stackp++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int thread_isr_stack_usage(void)
|
|
|
|
{
|
2024-05-31 10:59:14 +02:00
|
|
|
size_t stack_size = (uintptr_t)&port_IntStackTop - (uintptr_t)&port_IntStack;
|
|
|
|
return stack_size -
|
|
|
|
measure_stack_free_internal((char *)&port_IntStack, stack_size);
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void *thread_isr_stack_pointer(void)
|
|
|
|
{
|
|
|
|
/* Get the current ISR stack pointer. */
|
|
|
|
return &port_IntStackTop;
|
|
|
|
}
|
|
|
|
|
|
|
|
void *thread_isr_stack_start(void)
|
|
|
|
{
|
|
|
|
/* Get the start of the ISR stack. */
|
|
|
|
return &port_IntStack;
|
|
|
|
}
|
|
|
|
|
|
|
|
void thread_isr_stack_print(void)
|
|
|
|
{
|
2022-06-25 12:46:09 +02:00
|
|
|
printf("Printing current ISR stack\n");
|
2021-11-03 21:53:34 +01:00
|
|
|
/* cppcheck-suppress comparePointers
|
|
|
|
* (reason: comes from ESP-SDK, so should be valid) */
|
2018-09-05 02:39:50 +02:00
|
|
|
esp_hexdump(&port_IntStack, &port_IntStackTop-&port_IntStack, 'w', 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
#else /* DEVELHELP */
|
|
|
|
|
|
|
|
void thread_isr_stack_init(void) {}
|
|
|
|
|
|
|
|
#endif /* DEVELHELP */
|