/* * Copyright (C) 2014 Freie Universität Berlin, Hinnerk van Bruinehsen * 2017 RWTH Aachen, Josua Arndt * 2018 Matthew Blue * 2023 Hugues Larrive * * 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. */ /** * @ingroup cpu_atmega_common * @{ * * @file * @brief Implementation specific CPU configuration options * * @author Hauke Petersen * @author Hinnerk van Bruinehsen * @author Josua Arndt * @author Steffen Robertz * @author Matthew Blue * @author Hugues Larrive */ #ifndef CPU_CONF_H #define CPU_CONF_H #include "atmega_regs_common.h" #ifdef __cplusplus extern "C" { #endif #ifndef THREAD_EXTRA_STACKSIZE_PRINTF #define THREAD_EXTRA_STACKSIZE_PRINTF (64) #endif /** * @name Kernel configuration * * Since printf seems to get memory allocated by the * linker/avr-libc the stack size tested successfully * even with pretty small stacks. * @{ */ #ifndef THREAD_STACKSIZE_DEFAULT #define THREAD_STACKSIZE_DEFAULT (128) #endif /* keep THREAD_STACKSIZE_IDLE > THREAD_EXTRA_STACKSIZE_PRINTF * to avoid not printing of debug in interrupts */ #ifndef THREAD_STACKSIZE_IDLE #if MODULE_XTIMER || MODULE_ZTIMER || MODULE_ZTIMER64 /* For AVR no ISR stack is used, hence an IRQ will victimize the stack of * whatever thread happens to be running with the IRQ kicks in. If more than * trivial stuff is needed to be done in ISRs (e.g. when soft timers are used), * the idle stack will overflow. */ #define THREAD_STACKSIZE_IDLE (192) #else #define THREAD_STACKSIZE_IDLE (96) #endif #endif /** @} */ /** * @brief Attribute for memory sections required by SRAM PUF */ #define PUF_SRAM_ATTRIBUTES __attribute__((used, section(".noinit"))) /** * @brief Declare the heap_stats function as available */ #define HAVE_HEAP_STATS /** * @brief This arch uses the inlined IRQ API. */ #define IRQ_API_INLINED (1) #ifndef DOXYGEN #define HAS_FLASH_UTILS_ARCH 1 #endif #ifdef __cplusplus } #endif #endif /* CPU_CONF_H */ /** @} */