mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
c74ec1c253
cpu/mips32r2_common adds base architecture support for mips32r2 cores it can be built in it own right as a 'CPU', but is dependant on a bootloader (like u-boot) to have bootstrapped the system, this has been tested on a 'malta' FPGA system (BOARD=mips-malta) with various mips32r2 compliant cores (interAptiv, P5600, etc).
43 lines
863 B
C
43 lines
863 B
C
/*
|
|
* Copyright 2016, Imagination Technologies Limited and/or its
|
|
* affiliated group companies.
|
|
* 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.
|
|
*/
|
|
|
|
#include <mips/m32c0.h>
|
|
#include "arch/irq_arch.h"
|
|
|
|
|
|
unsigned int irq_arch_enable(void)
|
|
{
|
|
unsigned int status;
|
|
|
|
__asm__ volatile ("ei %0" : "=r" (status));
|
|
return status;
|
|
}
|
|
|
|
unsigned int irq_arch_disable(void)
|
|
{
|
|
unsigned int status;
|
|
|
|
__asm__ volatile ("di %0" : "=r" (status));
|
|
return status;
|
|
}
|
|
|
|
void irq_arch_restore(unsigned int state)
|
|
{
|
|
if (state & SR_IE) {
|
|
mips32_bs_c0(C0_STATUS, SR_IE);
|
|
}
|
|
else {
|
|
mips32_bc_c0(C0_STATUS, SR_IE);
|
|
}
|
|
}
|
|
|
|
int irq_arch_in(void)
|
|
{
|
|
return (mips32_get_c0(C0_STATUS) & SR_EXL) != 0;
|
|
}
|