2017-02-09 13:18:44 +01:00
|
|
|
/*
|
|
|
|
* 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>
|
2017-10-20 17:26:10 +02:00
|
|
|
#include "irq.h"
|
2017-02-09 13:18:44 +01:00
|
|
|
|
2017-10-20 17:26:10 +02:00
|
|
|
unsigned int irq_enable(void)
|
2017-02-09 13:18:44 +01:00
|
|
|
{
|
|
|
|
unsigned int status;
|
|
|
|
|
|
|
|
__asm__ volatile ("ei %0" : "=r" (status));
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2017-10-20 17:26:10 +02:00
|
|
|
unsigned int irq_disable(void)
|
2017-02-09 13:18:44 +01:00
|
|
|
{
|
|
|
|
unsigned int status;
|
|
|
|
|
|
|
|
__asm__ volatile ("di %0" : "=r" (status));
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
|
2017-10-20 17:26:10 +02:00
|
|
|
void irq_restore(unsigned int state)
|
2017-02-09 13:18:44 +01:00
|
|
|
{
|
|
|
|
if (state & SR_IE) {
|
|
|
|
mips32_bs_c0(C0_STATUS, SR_IE);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
mips32_bc_c0(C0_STATUS, SR_IE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-12-08 15:53:15 +01:00
|
|
|
bool irq_is_in(void)
|
2017-02-09 13:18:44 +01:00
|
|
|
{
|
2021-12-08 15:53:15 +01:00
|
|
|
return mips32_get_c0(C0_STATUS) & SR_EXL;
|
2017-02-09 13:18:44 +01:00
|
|
|
}
|
2021-06-29 11:40:48 +02:00
|
|
|
|
2021-12-08 15:53:15 +01:00
|
|
|
bool irq_is_enabled(void)
|
|
|
|
{
|
2021-06-29 11:40:48 +02:00
|
|
|
return mips32_get_c0(C0_STATUS) & SR_IE;
|
|
|
|
}
|