mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
e7fbaf3815
- removed the __attribute__((naked)) from ISRs - removed ISR_ENTER() and ISR_EXIT() macros Rationale: Cortex-Mx MCUs save registers R0-R4 automatically on calling ISRs. The naked attribute tells the compiler not to save any other registers. This is fine, as long as the code in the ISR is not nested. If nested, it will use also R4 and R5, which will then lead to currupted registers on exit of the ISR. Removing the naked will fix this.
44 lines
1.0 KiB
C
44 lines
1.0 KiB
C
/*
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @addtogroup cpu_cortex-m3
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Basic definitions for the Cortex-M3 common module
|
|
*
|
|
* When ever you want to do something hardware related, that is accessing MCUs registers directly,
|
|
* just include this file. It will then make sure that the MCU specific headers are included.
|
|
*
|
|
* @author Stefan Pfeiffer <stefan.pfeiffer@fu-berlin.de>
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef __CORTEXM_COMMON_H
|
|
#define __CORTEXM_COMMON_H
|
|
|
|
#include "cpu-conf.h"
|
|
|
|
/**
|
|
* For downwards compatibility with old RIOT code.
|
|
* TODO: remove once core was adjusted
|
|
*/
|
|
#include "irq.h"
|
|
#define eINT enableIRQ
|
|
#define dINT disableIRQ
|
|
|
|
/**
|
|
* @brief Initialization of the CPU
|
|
*/
|
|
void cpu_init(void);
|
|
|
|
|
|
#endif /* __CORTEXM_COMMON_H */
|
|
/** @} */
|