2017-02-25 19:02:07 +01:00
|
|
|
#include <internals/gint.h>
|
|
|
|
#include <internals/interrupt_maps.h>
|
2017-04-13 21:59:13 +02:00
|
|
|
#include <internals/modules.h>
|
2017-02-25 19:02:07 +01:00
|
|
|
#include <gint.h>
|
|
|
|
#include <mpu.h>
|
|
|
|
|
|
|
|
gint_info_t gint;
|
2017-04-13 21:59:13 +02:00
|
|
|
static environment_t env;
|
2017-02-25 19:02:07 +01:00
|
|
|
|
|
|
|
//---
|
|
|
|
// Initialization routines
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_init()
|
|
|
|
Initializes gint. Loads the interrupt handler into the memory and sets
|
|
|
|
the new vbr address.
|
|
|
|
*/
|
|
|
|
static void setup(void)
|
|
|
|
{
|
2017-04-13 21:59:13 +02:00
|
|
|
isSH3() ? gint_lock_and_setup_7705()
|
|
|
|
: gint_lock_and_setup_7305();
|
2017-02-25 19:02:07 +01:00
|
|
|
}
|
|
|
|
void gint_init(void)
|
|
|
|
{
|
2017-04-13 21:59:13 +02:00
|
|
|
// Detecting the MPU type. I don't like const-casting but this is still
|
|
|
|
// better than allowing the user to change the variable by mistake.
|
|
|
|
*((mpu_t *)&MPU_CURRENT) = getMPU();
|
|
|
|
// Loading the register addresses of the current platform.
|
|
|
|
mod_init();
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
// Linker script symbols -- gint.
|
|
|
|
extern uint32_t
|
|
|
|
gint_vbr,
|
|
|
|
gint_data,
|
|
|
|
bgint, egint;
|
|
|
|
|
|
|
|
uint32_t *ptr = &bgint;
|
|
|
|
uint32_t *src = &gint_data;
|
|
|
|
|
|
|
|
// Loading the interrupt handler into the memory.
|
|
|
|
while(ptr < &egint) *ptr++ = *src++;
|
|
|
|
|
2017-04-13 21:59:13 +02:00
|
|
|
isSH3() ? gint_save_7705(&env.env_7705)
|
|
|
|
: gint_save_7305(&env.env_7305);
|
|
|
|
|
2017-02-25 19:02:07 +01:00
|
|
|
// Installing gint's default exception/interrupt handlers.
|
|
|
|
for(int i = 0; i < exc_type_max; i++)
|
|
|
|
{
|
|
|
|
gint_handlers[i].function = gint_handlers[i].default_function;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Filling the information structure for the user.
|
|
|
|
gint.vbr = gint_getvbr;
|
|
|
|
gint.system_vbr = gint_getvbr();
|
|
|
|
gint.gint_vbr = (uint32_t)&gint_vbr;
|
|
|
|
|
|
|
|
// Setting the VBR!
|
|
|
|
gint_setvbr(gint.gint_vbr, setup);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Context restoration routines
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_quit()
|
|
|
|
Stops gint. Restores the system's configuration and vbr address.
|
|
|
|
*/
|
|
|
|
static void stop(void)
|
|
|
|
{
|
2017-04-13 21:59:13 +02:00
|
|
|
isSH3() ? gint_restore_and_unlock_7705(&env.env_7705)
|
|
|
|
: gint_restore_and_unlock_7305(&env.env_7305);
|
2017-02-25 19:02:07 +01:00
|
|
|
}
|
|
|
|
void gint_quit(void)
|
|
|
|
{
|
|
|
|
// Restoring the system's VBR.
|
|
|
|
gint_setvbr(gint.system_vbr, stop);
|
|
|
|
}
|