2016-07-06 11:28:51 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core module: interrupt handler
|
|
|
|
//
|
|
|
|
// Central point of the library. Controls the interrupt handler and
|
|
|
|
// defines a few functions to configure callbacks for some interrupts.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#ifndef _GINT_H
|
|
|
|
#define _GINT_H 1
|
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
#define GINT_VERSION 0x01000000
|
|
|
|
#define GINT_VERSION_STR "01.00"
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
2016-07-06 11:28:51 +02:00
|
|
|
// Interrupt handler control.
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_getVBR()
|
|
|
|
Returns the current vbr address.
|
|
|
|
*/
|
|
|
|
unsigned int gint_getVBR(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_systemVBR()
|
|
|
|
Returns the vbr address used by the system (saved when execution
|
|
|
|
starts).
|
|
|
|
*/
|
|
|
|
unsigned int gint_systemVBR(void);
|
|
|
|
|
2016-11-05 22:00:23 +01:00
|
|
|
/*
|
|
|
|
gint_setDefaultHandler()
|
|
|
|
In case gint receives an interrupt it doesn't recognize, it can fall
|
|
|
|
back to a user-provided interrupt handler. Set it to NULL to disable
|
|
|
|
this feature.
|
|
|
|
Be aware that the event code passed to the default handler will either
|
|
|
|
be INTEVT2 (SH7705) or INTEVT (SH7305), but its value for each
|
|
|
|
interrupt source is completely platform-dependent. Remember to handle
|
|
|
|
both platforms for increased portability, if possible.
|
|
|
|
*/
|
|
|
|
void gint_setDefaultHandler(void (*default_handler)(int event_code));
|
|
|
|
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
|
2016-07-25 22:38:47 +02:00
|
|
|
//---
|
|
|
|
// Register access.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
enum Register
|
|
|
|
Represents common registers. Used as identifiers to retrieve their
|
|
|
|
values using gint_register().
|
|
|
|
*/
|
|
|
|
enum Register
|
|
|
|
{
|
|
|
|
Register_EXPEVT,
|
|
|
|
Register_MMUCR,
|
|
|
|
Register_TEA,
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_register()
|
|
|
|
Returns the address of a common register. All common registers exist
|
|
|
|
on both platforms but they may hold different values for the same
|
|
|
|
information (f.i. EXPEVT may not return the same value for a given
|
|
|
|
exception on both 7705 and 7305).
|
|
|
|
*/
|
|
|
|
volatile void *gint_reg(enum Register reg);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_strerror()
|
|
|
|
Returns a string that describe the error set in EXPEVT in case of
|
|
|
|
general exception of TLB miss exception. This string is platform-
|
|
|
|
independent.
|
|
|
|
Some exception codes represent different errors when invoked inside the
|
|
|
|
general exception handler and the TLB error handler. Parameter 'is_tlb'
|
|
|
|
should be set to zero for general exception meanings, and anything non-
|
|
|
|
zero for TLB error meanings.
|
|
|
|
*/
|
|
|
|
const char *gint_strerror(int is_tlb);
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
// Internal API.
|
|
|
|
// Referenced here for documentation purposes only.
|
|
|
|
// Do NOT call these functions, you'll most probably screw up the whole
|
|
|
|
// interrupt handling system.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_setVBR()
|
2016-07-06 11:28:51 +02:00
|
|
|
Sets the vbr address and calls the configuration function while
|
|
|
|
interrupts are disabled.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void gint_setVBR(unsigned int new_vbr_address, void (*setup)(void));
|
|
|
|
|
2016-11-05 22:00:23 +01:00
|
|
|
/*
|
|
|
|
gint_callDefaultHandler()
|
|
|
|
Calls the user-provided default interrupt handler.
|
|
|
|
*/
|
|
|
|
void gint_callDefaultHandler(int event_code);
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
/*
|
|
|
|
gint_init()
|
|
|
|
Initializes gint. Loads the interrupt handler into the memory and sets
|
|
|
|
the new vbr address.
|
|
|
|
*/
|
|
|
|
void gint_init(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_quit()
|
|
|
|
Stops gint. Restores the system's configuration and vbr address.
|
|
|
|
*/
|
|
|
|
void gint_quit(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_setup()
|
|
|
|
Configures interrupt priorities and some parameters to allow gint to
|
|
|
|
take control of the interrupt flow.
|
|
|
|
*/
|
|
|
|
void gint_setup_7705(void);
|
|
|
|
void gint_setup_7305(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_stop()
|
|
|
|
Un-configures the interrupt flow to give back the interrupt control to
|
|
|
|
the system.
|
|
|
|
*/
|
|
|
|
void gint_stop_7705(void);
|
|
|
|
void gint_stop_7305(void);
|
|
|
|
|
2016-07-25 22:38:47 +02:00
|
|
|
/*
|
|
|
|
gint_reg()
|
|
|
|
gint_strerror()
|
|
|
|
See "Register access" section.
|
|
|
|
*/
|
|
|
|
volatile void *gint_reg_7705(enum Register reg);
|
|
|
|
volatile void *gint_reg_7305(enum Register reg);
|
|
|
|
const char *gint_strerror_7705(int is_tlb);
|
2016-07-28 18:12:07 +02:00
|
|
|
const char *gint_strerror_7305(void);
|
2016-07-25 09:04:22 +02:00
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Exception handling.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_exc()
|
|
|
|
Handles exceptions.
|
|
|
|
*/
|
|
|
|
void gint_exc(void) __attribute__((section(".gint.exc.entry"),
|
|
|
|
interrupt_handler));
|
|
|
|
void gint_exc_7705(void) __attribute__((section(".gint.exc")));
|
|
|
|
void gint_exc_7305(void) __attribute__((section(".gint.exc")));
|
|
|
|
|
|
|
|
/*
|
|
|
|
gint_tlb()
|
|
|
|
Handles TLB misses.
|
|
|
|
*/
|
|
|
|
void gint_tlb(void) __attribute__((section(".gint.tlb.entry"),
|
|
|
|
interrupt_handler));
|
|
|
|
void gint_tlb_7705(void) __attribute__((section(".gint.tlb")));
|
|
|
|
void gint_tlb_7305(void) __attribute__((section(".gint.tlb")));
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
/*
|
2016-07-25 09:04:22 +02:00
|
|
|
gint_int()
|
2016-05-05 11:49:05 +02:00
|
|
|
Handles interrupts.
|
|
|
|
*/
|
2016-07-25 09:04:22 +02:00
|
|
|
void gint_int(void) __attribute__((section(".gint.int.entry"),
|
2016-07-06 11:28:51 +02:00
|
|
|
interrupt_handler));
|
2016-07-25 09:04:22 +02:00
|
|
|
void gint_int_7705(void) __attribute__((section(".gint.int")));
|
|
|
|
void gint_int_7305(void) __attribute__((section(".gint.int")));
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
2016-07-25 09:04:22 +02:00
|
|
|
// Internal platform-independent definitions.
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
|
|
|
|
#define GINT_INTP_WDT 4
|
2016-05-05 18:19:10 +02:00
|
|
|
#define GINT_INTP_RTC 12
|
|
|
|
|
|
|
|
#define GINT_INTP_GRAY 15
|
2016-05-05 11:49:05 +02:00
|
|
|
#define GINT_INTP_KEY 8
|
2016-05-05 18:19:10 +02:00
|
|
|
#define GINT_INTP_TIMER 10
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _GINT_H
|