mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 06:32:45 +01:00
125 lines
3.2 KiB
C
125 lines
3.2 KiB
C
/*
|
|
* Copyright (C) 2022 Gunar Schorcht
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @defgroup cpu_esp32_conf ESP32 compile configurations
|
|
* @ingroup cpu_esp32
|
|
* @ingroup config
|
|
* @brief Compile-time configuration macros for ESP32x SoCs
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Compile compile-time configurations that are common for all ESP32x SoCs
|
|
*
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
*/
|
|
|
|
#ifndef CPU_CONF_H
|
|
#define CPU_CONF_H
|
|
|
|
#if !defined(__ASSEMBLER__)
|
|
#include <stdint.h>
|
|
#endif
|
|
|
|
/**
|
|
* @name Stack size configuration
|
|
* @{
|
|
*/
|
|
/** Extra thread stack size required if newlib-nano is not used */
|
|
#ifdef MODULE_NEWLIB_NANO
|
|
#define THREAD_EXTRA_STACKSIZE (0)
|
|
#else
|
|
#define THREAD_EXTRA_STACKSIZE (512)
|
|
#endif
|
|
|
|
/** Extra thread stack size if `printf` is used */
|
|
#define THREAD_EXTRA_STACKSIZE_PRINTF (1536)
|
|
|
|
#ifndef THREAD_STACKSIZE_DEFAULT
|
|
/** Default thread stack size */
|
|
#define THREAD_STACKSIZE_DEFAULT (2048)
|
|
#endif
|
|
|
|
#ifndef THREAD_STACKSIZE_IDLE
|
|
/** Stack size for the idle thread */
|
|
#define THREAD_STACKSIZE_IDLE (2048)
|
|
#endif
|
|
|
|
#ifndef ESP_WIFI_STACKSIZE
|
|
/** Stack size for the WiFi thread */
|
|
#define ESP_WIFI_STACKSIZE (THREAD_STACKSIZE_DEFAULT + THREAD_EXTRA_STACKSIZE)
|
|
#endif
|
|
/** @} */
|
|
|
|
/** Buffer size used for printf functions (maximum length of formatted output). */
|
|
#define PRINTF_BUFSIZ 256
|
|
|
|
/**
|
|
* @brief Attribute for memory sections required by SRAM PUF
|
|
*/
|
|
#define PUF_SRAM_ATTRIBUTES __attribute__((used, section(".noinit")))
|
|
|
|
/**
|
|
* @brief Support of unaligned access
|
|
*
|
|
* All ESP32x SoCs allow unaligned read/write access to the RAM as well as
|
|
* unaligned read access to the constant data in the flash, which is accessible
|
|
* via the data bus and mapped by the MMU into the data address space of
|
|
* the CPU.
|
|
*/
|
|
#define CPU_HAS_UNALIGNED_ACCESS 1
|
|
|
|
/**
|
|
* @name Flash page configuration
|
|
* @{
|
|
*/
|
|
#if !DOXYGEN && !defined(__ASSEMBLER__)
|
|
/* start address of flash pages in CPU address space as determined by the linker */
|
|
extern uint8_t _fp_mem_start;
|
|
#endif
|
|
|
|
#define FLASHPAGE_SIZE (4096U) /**< Size of pages (flash sectors) in bytes */
|
|
#define FLASHPAGE_WRITE_BLOCK_SIZE (4U) /**< Minimum write block size */
|
|
#define FLASHPAGE_WRITE_BLOCK_ALIGNMENT (4U) /**< Write block alignment */
|
|
|
|
/**
|
|
* @brief Number of pages
|
|
*/
|
|
#define FLASHPAGE_NUMOF (CONFIG_ESP_FLASHPAGE_CAPACITY / FLASHPAGE_SIZE)
|
|
|
|
/**
|
|
* @brief CPU base address for flash page access as determined by the linker
|
|
*/
|
|
#define CPU_FLASH_BASE ((uint32_t)&_fp_mem_start)
|
|
|
|
/** @} */
|
|
|
|
/* include ESP32x SoC specific compile time configurations */
|
|
#if defined(CPU_FAM_ESP32)
|
|
#include "cpu_conf_esp32.h"
|
|
#elif defined(CPU_FAM_ESP32C3)
|
|
#include "cpu_conf_esp32c3.h"
|
|
#elif defined(CPU_FAM_ESP32S2)
|
|
#include "cpu_conf_esp32s2.h"
|
|
#elif defined(CPU_FAM_ESP32S3)
|
|
#include "cpu_conf_esp32s3.h"
|
|
#else
|
|
#error "ESP32x family implementation missing"
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* CPU_CONF_H */
|
|
/** @} */
|