1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/cortex-m4_common/include/cpu.h
Joakim Gebart 215ccc1213 core: Introduce atomic counters
- Move generic implementation of atomic_set_return to core/atomic.c
 - Generic implementation of atomic compare and swap in core/atomic.c
 - atomic_cas is used to implement atomic counters in core/include/atomic.h
 - atomic_int_t is an atomic integer type
 - ATOMIC_INIT can be used as an initializer for atomic_int_t
 - ATOMIC_VALUE gets a reference to the value of an atomic integer
2015-05-07 18:52:13 +02:00

60 lines
1.4 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.
*/
/**
* @defgroup cpu_cortexm4_common ARM Cortex-M4 common
* @ingroup cpu
* @brief Common implementations and headers for Cortex-M4 family based micro-controllers
* @{
*
* @file
* @brief Basic definitions for the Cortex-M4 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>
* @author Joakim Gebart <joakim.gebart@eistec.se>
*/
#ifndef __CORTEXM_COMMON_H
#define __CORTEXM_COMMON_H
/**
* @brief Cortex-M4 has architecture specific atomic operations in atomic_arch.c.
*/
#define ARCH_HAS_ATOMIC_INT 1
#include "cpu-conf.h"
/**
* For downwards compatibility with old RIOT code.
* TODO: remove once core was adjusted
*/
#include "irq.h"
#ifdef __cplusplus
extern "C" {
#endif
#define eINT enableIRQ
#define dINT disableIRQ
/**
* @brief Initialization of the CPU
*/
void cpu_init(void);
#ifdef __cplusplus
}
#endif
#endif /* __CORTEXM_COMMON_H */
/** @} */