2019-09-05 13:35:58 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2019-12-27 10:22:29 +01:00
|
|
|
* @ingroup cpu_esp_common
|
2019-09-05 13:35:58 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2019-12-27 10:22:29 +01:00
|
|
|
* @brief Common helper macros for ESP SoCs
|
2019-09-05 13:35:58 +02:00
|
|
|
*
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ESP_COMMON_H
|
|
|
|
#define ESP_COMMON_H
|
|
|
|
|
|
|
|
#ifndef DOXYGEN
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "log.h"
|
|
|
|
#include "esp_common_log.h"
|
2020-04-16 13:50:09 +02:00
|
|
|
#include "macros/xtstr.h"
|
2019-09-05 13:35:58 +02:00
|
|
|
|
|
|
|
#if !defined(ICACHE_FLASH)
|
|
|
|
#ifndef ICACHE_RAM_ATTR
|
|
|
|
/** Places the code with this attribute in the IRAM. */
|
|
|
|
#define ICACHE_RAM_ATTR __attribute__((section(".iram0.text")))
|
|
|
|
#endif
|
|
|
|
#else /* ICACHE_FLASH */
|
|
|
|
#ifndef ICACHE_RAM_ATTR
|
|
|
|
#define ICACHE_RAM_ATTR
|
|
|
|
#endif
|
|
|
|
#endif /* ICACHE_FLASH */
|
|
|
|
|
2020-04-02 22:36:36 +02:00
|
|
|
#ifndef RTC_BSS_ATTR
|
|
|
|
#define RTC_BSS_ATTR __attribute__((section(".rtc.bss")))
|
|
|
|
#endif
|
|
|
|
|
2022-06-23 07:18:48 +02:00
|
|
|
#ifdef MCU_ESP8266
|
2020-04-02 22:36:36 +02:00
|
|
|
#ifndef RTC_DATA_ATTR
|
|
|
|
#define RTC_DATA_ATTR __attribute__((section(".rtc.data")))
|
|
|
|
#endif
|
2022-02-01 21:55:03 +01:00
|
|
|
#endif
|
2020-04-02 22:36:36 +02:00
|
|
|
|
2020-10-02 07:57:00 +02:00
|
|
|
/** Print out a message that function is not yet implemented */
|
2019-09-05 13:35:58 +02:00
|
|
|
#define NOT_YET_IMPLEMENTED() LOG_INFO("%s not yet implemented\n", __func__)
|
|
|
|
/** Print out a message that function is not supported */
|
|
|
|
#define NOT_SUPPORTED() LOG_INFO("%s not supported\n", __func__)
|
|
|
|
|
|
|
|
#if ENABLE_DEBUG
|
|
|
|
/**
|
|
|
|
* @brief Parameter check with return a value.
|
|
|
|
*
|
|
|
|
* If ENABLE_DEBUG is true, the macro checks a condition and returns with a value
|
|
|
|
* if the condition is not fulfilled.
|
|
|
|
* @param cond the condition
|
|
|
|
* @param err the return value in the case the condition is not fulfilled.
|
|
|
|
*/
|
|
|
|
#define CHECK_PARAM_RET(cond,err) if (!(cond)) \
|
|
|
|
{ \
|
|
|
|
DEBUG("%s parameter condition (" #cond ") " \
|
|
|
|
"not fulfilled\n", __func__); \
|
|
|
|
return err; \
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Parameter check without return value.
|
|
|
|
*
|
|
|
|
* If ENABLE_DEBUG is true, the macro checks a condition and returns without a
|
|
|
|
* value if the condition is not fulfilled.
|
|
|
|
* @param cond the condition
|
|
|
|
*/
|
|
|
|
#define CHECK_PARAM(cond) if (!(cond)) \
|
|
|
|
{ \
|
|
|
|
DEBUG("%s parameter condition (" #cond ") " \
|
|
|
|
"not fulfilled\n", __func__); \
|
|
|
|
return; \
|
|
|
|
}
|
|
|
|
|
|
|
|
#else /* ENABLE_DEBUG */
|
|
|
|
|
|
|
|
#define CHECK_PARAM_RET(cond,err) if (!(cond)) return err;
|
|
|
|
#define CHECK_PARAM(cond) if (!(cond)) return;
|
|
|
|
|
|
|
|
#endif /* ENABLE_DEBUG */
|
|
|
|
|
|
|
|
/** gives the minimum of a and b */
|
|
|
|
#ifndef MIN
|
|
|
|
#define MIN(a,b) ((a) < (b) ? (a) : (b))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** gives the maximum of a and b */
|
|
|
|
#ifndef MAX
|
|
|
|
#define MAX(a,b) ((a) > (b) ? (a) : (b))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief function name mappings for source code compatibility with ESP8266 port
|
|
|
|
* @{
|
|
|
|
*/
|
2022-07-18 08:09:08 +02:00
|
|
|
#ifdef CPU_FAM_ESP32
|
2019-09-05 13:35:58 +02:00
|
|
|
#define system_get_cpu_freq ets_get_cpu_frequency
|
|
|
|
#define system_update_cpu_freq ets_update_cpu_frequency
|
2022-07-18 08:09:08 +02:00
|
|
|
#endif /* CPU_FAM_ESP32 */
|
2019-09-05 13:35:58 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/** microseconds per millisecond */
|
|
|
|
#ifndef USEC_PER_MSEC
|
|
|
|
#define USEC_PER_MSEC 1000UL
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef MSEC_PER_SEC
|
|
|
|
#define MSEC_PER_SEC 1000UL
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* DOXYGEN */
|
|
|
|
|
|
|
|
#endif /* ESP_COMMON_H */
|
2021-09-05 20:40:39 +02:00
|
|
|
/** @} */
|