mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-15 17:52:45 +01:00
Kaspar Schleiser
ef099f9d46
They might not be necessary, but GCC warns if they're absent. Thus let's pay the one or two extra instructions for silencing the warnings.
97 lines
2.2 KiB
C
97 lines
2.2 KiB
C
/*
|
|
* Copyright (C) 2014 Freie Universität Berlin
|
|
* 2020 Otto-von-Guericke-Universität Magdeburg
|
|
*
|
|
* 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_msp430_common
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief ISR related functions
|
|
*
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
|
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
|
|
*
|
|
*/
|
|
|
|
#ifndef IRQ_ARCH_H
|
|
#define IRQ_ARCH_H
|
|
|
|
#include "irq.h"
|
|
#include "cpu.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
* gcc warns for missing NOPs before/after interrupt enable/disable.
|
|
* so I added the NOP instructions, even though they might not be necessary
|
|
* due to following AND. // Kaspar
|
|
*/
|
|
|
|
|
|
extern volatile int __irq_is_in;
|
|
|
|
__attribute__((always_inline)) static inline unsigned int irq_disable(void)
|
|
{
|
|
unsigned int state;
|
|
__asm__ volatile(
|
|
"mov.w r2, %[state]" "\n\t"
|
|
"bic %[gie], r2" "\n\t"
|
|
"nop" "\n\t"
|
|
"and %[gie], %[state]" "\n\t"
|
|
: [state] "=r"(state)
|
|
: [gie] "i"(GIE)
|
|
: "memory"
|
|
);
|
|
|
|
return state;
|
|
}
|
|
|
|
__attribute__((always_inline)) static inline unsigned int irq_enable(void)
|
|
{
|
|
unsigned int state;
|
|
__asm__ volatile(
|
|
"mov.w r2, %[state]" "\n\t"
|
|
"nop" "\n\t"
|
|
"bis %[gie], r2" "\n\t"
|
|
"nop" "\n\t"
|
|
"and %[gie], %[state]" "\n\t"
|
|
: [state] "=r"(state)
|
|
: [gie] "i"(GIE)
|
|
: "memory"
|
|
);
|
|
|
|
return state;
|
|
}
|
|
|
|
__attribute__((always_inline)) static inline void irq_restore(unsigned int state)
|
|
{
|
|
__asm__ volatile(
|
|
"bis %[state], r2" "\n\t"
|
|
"nop" "\n\t"
|
|
: /* no outputs */
|
|
: [state] "r"(state)
|
|
: "memory"
|
|
);
|
|
}
|
|
|
|
__attribute__((always_inline)) static inline int irq_is_in(void)
|
|
{
|
|
return __irq_is_in;
|
|
}
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
/** @} */
|
|
#endif /* IRQ_ARCH_H */
|