2018-03-17 21:21:26 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 Freie Universität Berlin, Hinnerk van Bruinehsen
|
2018-05-15 02:34:09 +02:00
|
|
|
* 2017 RWTH Aachen, Josua Arndt
|
2018-03-17 21:21:26 +01:00
|
|
|
* 2018 Matthew Blue
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2018-05-15 02:34:09 +02:00
|
|
|
* @ingroup cpu_atmega_common
|
2018-03-17 21:21:26 +01:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Implementation specific CPU configuration options
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
* @author Hinnerk van Bruinehsen <h.v.bruinehsen@fu-berlin.de>
|
2018-05-15 02:34:09 +02:00
|
|
|
* @author Josua Arndt <jarndt@ias.rwth-aachen.de>
|
|
|
|
* @author Steffen Robertz <steffen.robertz@rwth-aachen.de>
|
2018-03-17 21:21:26 +01:00
|
|
|
* @author Matthew Blue <matthew.blue.neuro@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CPU_CONF_H
|
|
|
|
#define CPU_CONF_H
|
|
|
|
|
|
|
|
#include "atmega_regs_common.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2023-05-16 17:12:10 +02:00
|
|
|
#ifndef THREAD_EXTRA_STACKSIZE_PRINTF
|
2023-07-01 20:54:55 +02:00
|
|
|
#define THREAD_EXTRA_STACKSIZE_PRINTF (132)
|
2023-05-16 17:12:10 +02:00
|
|
|
#endif
|
2018-05-15 02:34:09 +02:00
|
|
|
|
2018-03-17 21:21:26 +01:00
|
|
|
/**
|
2018-05-15 02:34:09 +02:00
|
|
|
* @name Kernel configuration
|
2018-03-17 21:21:26 +01:00
|
|
|
*
|
2018-05-15 02:34:09 +02:00
|
|
|
* Since printf seems to get memory allocated by the
|
|
|
|
* linker/avr-libc the stack size tested successfully
|
|
|
|
* even with pretty small stacks.
|
2018-03-17 21:21:26 +01:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#ifndef THREAD_STACKSIZE_DEFAULT
|
2018-05-15 02:34:09 +02:00
|
|
|
#define THREAD_STACKSIZE_DEFAULT (512)
|
2018-03-17 21:21:26 +01:00
|
|
|
#endif
|
|
|
|
|
2018-05-15 02:34:09 +02:00
|
|
|
/* keep THREAD_STACKSIZE_IDLE > THREAD_EXTRA_STACKSIZE_PRINTF
|
|
|
|
* to avoid not printing of debug in interrupts
|
|
|
|
*/
|
2019-01-10 11:07:35 +01:00
|
|
|
#ifndef THREAD_STACKSIZE_IDLE
|
2022-06-27 13:04:01 +02:00
|
|
|
#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.
|
2020-07-27 09:42:07 +02:00
|
|
|
*/
|
|
|
|
#define THREAD_STACKSIZE_IDLE (192)
|
|
|
|
#else
|
2018-03-17 21:21:26 +01:00
|
|
|
#define THREAD_STACKSIZE_IDLE (128)
|
2019-01-10 11:07:35 +01:00
|
|
|
#endif
|
2020-07-27 09:42:07 +02:00
|
|
|
#endif
|
2018-03-17 21:21:26 +01:00
|
|
|
/** @} */
|
|
|
|
|
2018-11-20 09:43:24 +01:00
|
|
|
/**
|
|
|
|
* @brief Attribute for memory sections required by SRAM PUF
|
|
|
|
*/
|
|
|
|
#define PUF_SRAM_ATTRIBUTES __attribute__((used, section(".noinit")))
|
|
|
|
|
2019-02-03 18:59:27 +01:00
|
|
|
/**
|
|
|
|
* @brief Declare the heap_stats function as available
|
|
|
|
*/
|
|
|
|
#define HAVE_HEAP_STATS
|
|
|
|
|
2020-05-15 09:15:16 +02:00
|
|
|
/**
|
|
|
|
* @brief This arch uses the inlined IRQ API.
|
|
|
|
*/
|
|
|
|
#define IRQ_API_INLINED (1)
|
|
|
|
|
2022-05-31 20:51:08 +02:00
|
|
|
#ifndef DOXYGEN
|
|
|
|
#define HAS_FLASH_UTILS_ARCH 1
|
|
|
|
#endif
|
|
|
|
|
2018-03-17 21:21:26 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* CPU_CONF_H */
|
|
|
|
/** @} */
|