2018-08-01 20:41:36 +02:00
|
|
|
//---
|
|
|
|
// gint:core:gint - Library functions
|
|
|
|
//---
|
|
|
|
|
|
|
|
#include <gint/gint.h>
|
2019-03-06 14:32:51 +01:00
|
|
|
#include <core/std.h>
|
2019-07-04 18:11:43 +02:00
|
|
|
#include <gint/hardware.h>
|
2019-02-21 20:58:38 +01:00
|
|
|
#include <gint/mpu/intc.h>
|
2018-08-01 20:41:36 +02:00
|
|
|
|
|
|
|
/* Interrupt controllers */
|
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
GDATA3 sh7705_intc_t SH7705_INTC = {
|
2018-08-01 20:41:36 +02:00
|
|
|
.IPRS = {
|
|
|
|
(void *)0xfffffee2, (void *)0xfffffee4,
|
|
|
|
(void *)0xa4000016, (void *)0xa4000018, (void *)0xa400001a,
|
|
|
|
(void *)0xa4080000, (void *)0xa4080002, (void *)0xa4080004,
|
|
|
|
},
|
|
|
|
.ICR1 = (void *)0xa4000010,
|
|
|
|
};
|
|
|
|
|
2019-02-21 20:58:38 +01:00
|
|
|
GDATA sh7305_intc_t SH7305_INTC = {
|
2018-08-01 20:41:36 +02:00
|
|
|
.IPRS = (void *)0xa4080000,
|
|
|
|
.MSK = (void *)0xa4080080,
|
|
|
|
.MSKCLR = (void *)0xa40800c0,
|
|
|
|
.USERIMASK = (void *)0xa4700000,
|
|
|
|
};
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Library functions
|
|
|
|
//---
|
|
|
|
|
|
|
|
/* gint_intlevel() - configure the level of interrupts */
|
|
|
|
int gint_intlevel(int intid, int level)
|
|
|
|
{
|
|
|
|
int shift = (~intid & 0x3) << 2;
|
|
|
|
volatile uint16_t *ipr;
|
|
|
|
level &= 0xf;
|
|
|
|
|
2018-08-19 17:11:37 +02:00
|
|
|
ipr = isSH3()
|
2019-02-21 20:58:38 +01:00
|
|
|
? SH7705_INTC.IPRS[intid >> 2] /* SH3-based */
|
|
|
|
: &SH7305_INTC.IPRS[2 * (intid >> 2)]; /* SH4-based */
|
2018-08-01 20:41:36 +02:00
|
|
|
|
|
|
|
int oldlevel = (*ipr >> shift) & 0xf;
|
|
|
|
*ipr = (*ipr & ~(0xf << shift)) | (level << shift);
|
|
|
|
|
|
|
|
return oldlevel;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* gint_inthandler() - configure interrupt handlers */
|
2018-08-19 17:11:37 +02:00
|
|
|
void *gint_inthandler(int event_code, const void *handler, size_t size)
|
2018-08-01 20:41:36 +02:00
|
|
|
{
|
|
|
|
extern char gint_vbr;
|
|
|
|
|
|
|
|
/* Normalize the event code */
|
|
|
|
event_code -= 0x400;
|
|
|
|
event_code &= ~0x1f;
|
|
|
|
|
|
|
|
/* Prevent overriding the entry gate */
|
|
|
|
if(event_code < 0) return NULL;
|
|
|
|
|
|
|
|
void *dest = (void *)&gint_vbr + event_code + 0x620;
|
2018-08-19 17:11:37 +02:00
|
|
|
return memcpy(dest, handler, size);
|
2018-08-01 20:41:36 +02:00
|
|
|
}
|