mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-16 03:52:50 +01:00
88 lines
2.0 KiB
C
88 lines
2.0 KiB
C
|
/*
|
||
|
* Copyright (C) 2018 Gunar Schorcht
|
||
|
*
|
||
|
* 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>
|
||
|
*
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#define ENABLE_DEBUG 0
|
||
|
#include "debug.h"
|
||
|
|
||
|
#include <stdint.h>
|
||
|
#include <stdio.h>
|
||
|
|
||
|
#include "irq.h"
|
||
|
#include "cpu.h"
|
||
|
|
||
|
#include "common.h"
|
||
|
#include "esp/common_macros.h"
|
||
|
#include "esp/xtensa_ops.h"
|
||
|
#include "sdk/ets.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) */
|
||
|
__asm__ volatile ("rsil %0, " XTSTR(XCHAL_NUM_INTLEVELS+1) : "=a" (_saved_interrupt_level));
|
||
|
DEBUG ("%s %02x(%02x)\n", __func__,
|
||
|
(_saved_interrupt_level & 0xfffffff0) | (XCHAL_NUM_INTLEVELS+1),
|
||
|
_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));
|
||
|
DEBUG ("%s %02x(%02x)\n", __func__,
|
||
|
_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;
|
||
|
}
|