mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 19:32:46 +01:00
edb890ff93
Found and fixed the issue for the kinetis-based boards: The kinetis code is using some macros to map some IRQ names, that differ in some versions of vendor headers, to a RIOT wide unique name. The doxygen of this mapping states, that this mapping must be done before any vendor header is included. Unfortunately, the mapping was so far placed in cpu/kinetis/vectors.c, before any other include statement. In some cases, the vendor headers might be included before the mapping macros in vectors.c, leading to the compilation errors down the line. To fix this, the adaption defines are moved into cpu/kinetis/cpu_conf.h, which is the file that actually includes the vendor headers. This way it is ensured, that these adaption macros are always defined before any vendor header is included, and therefore preventing this kind of error for good.
77 lines
1.9 KiB
C
77 lines
1.9 KiB
C
/*
|
|
* Copyright (C) 2017 Eistec AB
|
|
*
|
|
* 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_kinetis
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Implementation specific CPU configuration options
|
|
*
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
|
*/
|
|
|
|
#ifndef CPU_CONF_H
|
|
#define CPU_CONF_H
|
|
|
|
/* This is needed to homogenize the symbolic IRQ names across different versions
|
|
* of the vendor headers. These must be defined before any vendor headers are
|
|
* included */
|
|
#define FTFA_IRQn FTF_IRQn
|
|
#define FTFA_Collision_IRQn Read_Collision_IRQn
|
|
#define FTFE_IRQn FTF_IRQn
|
|
#define FTFE_Collision_IRQn Read_Collision_IRQn
|
|
#define FTFL_IRQn FTF_IRQn
|
|
#define FTFL_Collision_IRQn Read_Collision_IRQn
|
|
#define PMC_IRQn LVD_LVW_IRQn
|
|
#define Watchdog_IRQn WDOG_EWM_IRQn
|
|
#define LVD_LVW_DCDC_IRQn LVD_LVW_IRQn
|
|
|
|
/* Dispatch to a separate file per family */
|
|
#if defined(KINETIS_SERIES_K)
|
|
#include "cpu_conf_kinetis_k.h"
|
|
#elif defined(KINETIS_SERIES_L)
|
|
#include "cpu_conf_kinetis_l.h"
|
|
#elif defined(KINETIS_SERIES_M)
|
|
#include "cpu_conf_kinetis_m.h"
|
|
#elif defined(KINETIS_SERIES_V)
|
|
#include "cpu_conf_kinetis_v.h"
|
|
#elif defined(KINETIS_SERIES_W)
|
|
#include "cpu_conf_kinetis_w.h"
|
|
#elif defined(KINETIS_SERIES_EA)
|
|
#include "cpu_conf_kinetis_ea.h"
|
|
#endif /* defined(KINETIS_SERIES_x) */
|
|
|
|
#ifndef MCU_MEM_MAP_VERSION
|
|
#error Missing vendor header for the chosen CPU_MODEL
|
|
#endif
|
|
#include "cpu_conf_kinetis.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
/**
|
|
* @brief Bit-Band configuration
|
|
* @{
|
|
*/
|
|
#ifdef BITBAND_REG32
|
|
#define CPU_HAS_BITBAND 1
|
|
/* SRAM_L is mapped before the bit-banding region, only SRAM_U can be used for bit-banding */
|
|
#define CPU_HAS_SRAM_BITBAND 0
|
|
#endif
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* CPU_CONF_H */
|
|
/** @} */
|