1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/esp8266/irq_arch.c

87 lines
2.0 KiB
C
Raw Normal View History

2018-09-05 02:39:50 +02:00
/*
2019-09-05 13:35:58 +02:00
* Copyright (C) 2019 Gunar Schorcht
2018-09-05 02:39:50 +02:00
*
* 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_esp8266
* @{
*
* @file
* @brief Implementation of the kernels irq interface
*
* @author Gunar Schorcht <gunar@schorcht.net>
*
* @}
*/
2019-09-05 13:35:58 +02:00
#define ENABLE_DEBUG (0)
2018-09-05 02:39:50 +02:00
#include "debug.h"
#include <stdint.h>
#include <stdio.h>
#include "irq.h"
#include "cpu.h"
2019-09-05 13:35:58 +02:00
#include "esp_common.h"
2018-09-05 02:39:50 +02:00
#include "esp/common_macros.h"
#include "esp/xtensa_ops.h"
#include "xtensa/xtensa_context.h"
/**
* @brief Set on entry into and reset on exit from an ISR
*/
volatile uint32_t irq_interrupt_nesting = 0;
/**
* @brief Disable all maskable interrupts
*/
unsigned int IRAM irq_disable(void)
{
uint32_t _saved_interrupt_level;
/* read and set interrupt level (RSIL) */
2019-09-05 13:35:58 +02:00
__asm__ volatile ("rsil %0, " XTSTR(XCHAL_EXCM_LEVEL) : "=a" (_saved_interrupt_level));
2018-09-05 02:39:50 +02:00
DEBUG ("%s %02x(%02x)\n", __func__,
2019-09-05 13:35:58 +02:00
(_saved_interrupt_level & 0xfffffff0) | (XCHAL_EXCM_LEVEL),
2018-09-05 02:39:50 +02:00
_saved_interrupt_level);
return _saved_interrupt_level;
}
/**
* @brief Enable all maskable interrupts
*/
unsigned int IRAM irq_enable(void)
{
uint32_t _saved_interrupt_level;
/* read and set interrupt level (RSIL) */
__asm__ volatile ("rsil %0, 0" : "=a" (_saved_interrupt_level));
2019-09-05 13:35:58 +02:00
DEBUG ("%s %02x (%02x)\n", __func__,
2018-09-05 02:39:50 +02:00
_saved_interrupt_level & 0xfffffff0, _saved_interrupt_level);
return _saved_interrupt_level;
}
/**
* @brief Restore the state of the IRQ flags
*/
void IRAM irq_restore(unsigned int state)
{
/* write interrupt level and sync */
DEBUG ("%s %02x\n", __func__, state);
__asm__ volatile ("wsr %0, ps; rsync" :: "a" (state));
}
/**
* @brief See if the current context is inside an ISR
*/
int IRAM irq_is_in(void)
{
DEBUG("irq_interrupt_nesting = %d\n", irq_interrupt_nesting);
return irq_interrupt_nesting;
}