update sep4020: Modify the interrupt interface implementations.
This commit is contained in:
parent
fbc1b05dd8
commit
29a3ae4368
|
@ -34,7 +34,7 @@ struct serial_device uart0 =
|
||||||
/**
|
/**
|
||||||
* This function will handle rtos timer
|
* This function will handle rtos timer
|
||||||
*/
|
*/
|
||||||
void rt_timer_handler(int vector)
|
void rt_timer_handler(int vector, void *param)
|
||||||
{
|
{
|
||||||
rt_uint32_t clear_int;
|
rt_uint32_t clear_int;
|
||||||
rt_tick_increase();
|
rt_tick_increase();
|
||||||
|
@ -47,7 +47,7 @@ void rt_timer_handler(int vector)
|
||||||
/**
|
/**
|
||||||
* This function will handle serial
|
* This function will handle serial
|
||||||
*/
|
*/
|
||||||
void rt_serial_handler(int vector)
|
void rt_serial_handler(int vector, void *param)
|
||||||
{
|
{
|
||||||
//rt_kprintf("in rt_serial_handler\n");
|
//rt_kprintf("in rt_serial_handler\n");
|
||||||
rt_int32_t stat = *(RP)UART0_IIR ;
|
rt_int32_t stat = *(RP)UART0_IIR ;
|
||||||
|
@ -78,16 +78,17 @@ static void rt_hw_board_led_init(void)
|
||||||
|
|
||||||
*(RP)GPIO_PORTE_DATA &= ~0x38; /* low */
|
*(RP)GPIO_PORTE_DATA &= ~0x38; /* low */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This function will init timer4 for system ticks
|
* This function will init timer4 for system ticks
|
||||||
*/
|
*/
|
||||||
void rt_hw_timer_init(void)
|
void rt_hw_timer_init(void)
|
||||||
{
|
{
|
||||||
/*Set timer1*/
|
/*Set timer1*/
|
||||||
*(RP)TIMER_T1LCR = 880000;
|
*(RP)TIMER_T1LCR = 880000;
|
||||||
*(RP)TIMER_T1CR = 0x06;
|
*(RP)TIMER_T1CR = 0x06;
|
||||||
|
|
||||||
rt_hw_interrupt_install(INTSRC_TIMER1, rt_timer_handler, RT_NULL);
|
rt_hw_interrupt_install(INTSRC_TIMER1, rt_timer_handler, RT_NULL, "tick");
|
||||||
rt_hw_interrupt_umask(INTSRC_TIMER1);
|
rt_hw_interrupt_umask(INTSRC_TIMER1);
|
||||||
|
|
||||||
/*Enable timer1*/
|
/*Enable timer1*/
|
||||||
|
@ -119,7 +120,7 @@ void rt_hw_uart_init(void)
|
||||||
/*Disable tx interrupt*/
|
/*Disable tx interrupt*/
|
||||||
*(RP)(UART0_IER) &= ~(0x1<<1);
|
*(RP)(UART0_IER) &= ~(0x1<<1);
|
||||||
|
|
||||||
rt_hw_interrupt_install(INTSRC_UART0, rt_serial_handler, RT_NULL);
|
rt_hw_interrupt_install(INTSRC_UART0, rt_serial_handler, RT_NULL, "UART0");
|
||||||
rt_hw_interrupt_umask(INTSRC_UART0);
|
rt_hw_interrupt_umask(INTSRC_UART0);
|
||||||
/* register uart0 */
|
/* register uart0 */
|
||||||
rt_hw_serial_register(&uart0_device, "uart0",
|
rt_hw_serial_register(&uart0_device, "uart0",
|
||||||
|
|
|
@ -81,7 +81,7 @@ struct rt_dm9161_eth
|
||||||
static struct rt_dm9161_eth dm9161_device;
|
static struct rt_dm9161_eth dm9161_device;
|
||||||
static struct rt_semaphore sem_ack, sem_lock;
|
static struct rt_semaphore sem_ack, sem_lock;
|
||||||
|
|
||||||
void rt_dm9161_isr(int irqno);
|
void rt_dm9161_isr(int irqno, void *param);
|
||||||
|
|
||||||
static void udelay(unsigned long ns)
|
static void udelay(unsigned long ns)
|
||||||
{
|
{
|
||||||
|
@ -201,7 +201,7 @@ static void read_phy(unsigned char phy_addr, unsigned char address, unsigned int
|
||||||
}
|
}
|
||||||
|
|
||||||
/* interrupt service routine */
|
/* interrupt service routine */
|
||||||
void rt_dm9161_isr(int irqno)
|
void rt_dm9161_isr(int irqno, void *param)
|
||||||
{
|
{
|
||||||
unsigned long intstatus;
|
unsigned long intstatus;
|
||||||
rt_uint32_t address;
|
rt_uint32_t address;
|
||||||
|
@ -469,7 +469,7 @@ static rt_err_t rt_dm9161_open(rt_device_t dev, rt_uint16_t oflag)
|
||||||
*(volatile unsigned long*)GPIO_PORTA_INTRCLR |= 0x0080; //清除中断
|
*(volatile unsigned long*)GPIO_PORTA_INTRCLR |= 0x0080; //清除中断
|
||||||
*(volatile unsigned long*)GPIO_PORTA_INTRCLR = 0x0000; //清除中断
|
*(volatile unsigned long*)GPIO_PORTA_INTRCLR = 0x0000; //清除中断
|
||||||
|
|
||||||
rt_hw_interrupt_install(INTSRC_MAC, rt_dm9161_isr, RT_NULL);
|
rt_hw_interrupt_install(INTSRC_MAC, rt_dm9161_isr, RT_NULL, "EMAC");
|
||||||
enable_irq(INTSRC_EXINT7);
|
enable_irq(INTSRC_EXINT7);
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
/* #define RT_THREAD_DEBUG */
|
/* #define RT_THREAD_DEBUG */
|
||||||
|
|
||||||
#define RT_USING_OVERFLOW_CHECK
|
#define RT_USING_OVERFLOW_CHECK
|
||||||
|
#define RT_USING_INTERRUPT_INFO
|
||||||
|
|
||||||
/* Using Hook */
|
/* Using Hook */
|
||||||
#define RT_USING_HOOK
|
#define RT_USING_HOOK
|
||||||
|
|
|
@ -31,14 +31,14 @@ Options 1,0,0 // Target 'RT-Thread_Mini4020'
|
||||||
EnvReg ()
|
EnvReg ()
|
||||||
OrgReg ()
|
OrgReg ()
|
||||||
TgStat=16
|
TgStat=16
|
||||||
OutDir (.\)
|
OutDir (.\build\)
|
||||||
OutName (rtthread-mini4020)
|
OutName (rtthread-mini4020)
|
||||||
GenApp=1
|
GenApp=1
|
||||||
GenLib=0
|
GenLib=0
|
||||||
GenHex=0
|
GenHex=0
|
||||||
Debug=1
|
Debug=1
|
||||||
Browse=0
|
Browse=0
|
||||||
LstDir (.\)
|
LstDir (.\build\)
|
||||||
HexSel=1
|
HexSel=1
|
||||||
MG32K=0
|
MG32K=0
|
||||||
TGMORE=0
|
TGMORE=0
|
||||||
|
|
|
@ -10,9 +10,11 @@
|
||||||
* Change Logs:
|
* Change Logs:
|
||||||
* Date Author Notes
|
* Date Author Notes
|
||||||
* 2006-03-13 Bernard first version
|
* 2006-03-13 Bernard first version
|
||||||
|
* 2013-03-29 aozima Modify the interrupt interface implementations.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <rtthread.h>
|
#include <rtthread.h>
|
||||||
|
#include <rthw.h>
|
||||||
#include <sep4020.h>
|
#include <sep4020.h>
|
||||||
|
|
||||||
#define MAX_HANDLERS 32
|
#define MAX_HANDLERS 32
|
||||||
|
@ -20,7 +22,7 @@
|
||||||
extern rt_uint32_t rt_interrupt_nest;
|
extern rt_uint32_t rt_interrupt_nest;
|
||||||
|
|
||||||
/* exception and interrupt handler table */
|
/* exception and interrupt handler table */
|
||||||
rt_isr_handler_t isr_table[MAX_HANDLERS];
|
struct rt_irq_desc isr_table[MAX_HANDLERS];
|
||||||
rt_uint32_t rt_interrupt_from_thread, rt_interrupt_to_thread;
|
rt_uint32_t rt_interrupt_from_thread, rt_interrupt_to_thread;
|
||||||
rt_uint32_t rt_thread_switch_interrupt_flag;
|
rt_uint32_t rt_thread_switch_interrupt_flag;
|
||||||
|
|
||||||
|
@ -38,44 +40,45 @@ rt_isr_handler_t rt_hw_interrupt_handle(rt_uint32_t vector)
|
||||||
/**
|
/**
|
||||||
* This function will initialize hardware interrupt
|
* This function will initialize hardware interrupt
|
||||||
*/
|
*/
|
||||||
void rt_hw_interrupt_init()
|
void rt_hw_interrupt_init(void)
|
||||||
{
|
{
|
||||||
register rt_uint32_t idx;
|
register rt_uint32_t idx;
|
||||||
|
|
||||||
/*Make sure all intc registers in proper state*/
|
/*Make sure all intc registers in proper state*/
|
||||||
|
|
||||||
/*mask all the irq*/
|
/*mask all the irq*/
|
||||||
*(RP)(INTC_IMR) = 0xFFFFFFFF;
|
*(RP)(INTC_IMR) = 0xFFFFFFFF;
|
||||||
|
|
||||||
/*enable all the irq*/
|
/*enable all the irq*/
|
||||||
*(RP)(INTC_IER) = 0XFFFFFFFF;
|
*(RP)(INTC_IER) = 0XFFFFFFFF;
|
||||||
|
|
||||||
/*Dont use any forced irq*/
|
/*Dont use any forced irq*/
|
||||||
*(RP)(INTC_IFR) = 0x0;
|
*(RP)(INTC_IFR) = 0x0;
|
||||||
|
|
||||||
/*Disable all the fiq*/
|
/*Disable all the fiq*/
|
||||||
*(RP)(INTC_FIER) = 0x0;
|
*(RP)(INTC_FIER) = 0x0;
|
||||||
|
|
||||||
/*Mask all the fiq*/
|
/*Mask all the fiq*/
|
||||||
*(RP)(INTC_FIMR) = 0x0F;
|
*(RP)(INTC_FIMR) = 0x0F;
|
||||||
|
|
||||||
/*Dont use forced fiq*/
|
/*Dont use forced fiq*/
|
||||||
*(RP)(INTC_FIFR) = 0x0;
|
*(RP)(INTC_FIFR) = 0x0;
|
||||||
|
|
||||||
/*Intrrupt priority register*/
|
/*Intrrupt priority register*/
|
||||||
*(RP)(INTC_IPLR) = 0x0;
|
*(RP)(INTC_IPLR) = 0x0;
|
||||||
|
|
||||||
/* init exceptions table */
|
/* init exceptions table */
|
||||||
for(idx=0; idx < MAX_HANDLERS; idx++)
|
rt_memset(isr_table, 0x00, sizeof(isr_table));
|
||||||
{
|
for(idx=0; idx < MAX_HANDLERS; idx++)
|
||||||
isr_table[idx] = (rt_isr_handler_t)rt_hw_interrupt_handle;
|
{
|
||||||
}
|
isr_table[idx].handler = rt_hw_interrupt_handle;
|
||||||
|
}
|
||||||
|
|
||||||
/* init interrupt nest, and context in thread sp */
|
/* init interrupt nest, and context in thread sp */
|
||||||
rt_interrupt_nest = 0;
|
rt_interrupt_nest = 0;
|
||||||
rt_interrupt_from_thread = 0;
|
rt_interrupt_from_thread = 0;
|
||||||
rt_interrupt_to_thread = 0;
|
rt_interrupt_to_thread = 0;
|
||||||
rt_thread_switch_interrupt_flag = 0;
|
rt_thread_switch_interrupt_flag = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -108,15 +111,26 @@ void rt_hw_interrupt_umask(rt_uint32_t vector)
|
||||||
* @param new_handler the interrupt service routine to be installed
|
* @param new_handler the interrupt service routine to be installed
|
||||||
* @param old_handler the old interrupt service routine
|
* @param old_handler the old interrupt service routine
|
||||||
*/
|
*/
|
||||||
void rt_hw_interrupt_install(rt_uint32_t vector, rt_isr_handler_t new_handler, rt_isr_handler_t *old_handler)
|
rt_isr_handler_t rt_hw_interrupt_install(int vector, rt_isr_handler_t handler,
|
||||||
|
void *param, char *name)
|
||||||
{
|
{
|
||||||
if(vector < MAX_HANDLERS)
|
rt_isr_handler_t old_handler = RT_NULL;
|
||||||
{
|
|
||||||
if (*old_handler != RT_NULL)
|
if(vector < MAX_HANDLERS)
|
||||||
*old_handler = isr_table[vector];
|
{
|
||||||
if (new_handler != RT_NULL)
|
old_handler = isr_table[vector].handler;
|
||||||
isr_table[vector] = new_handler;
|
|
||||||
}
|
if (handler != RT_NULL)
|
||||||
|
{
|
||||||
|
#ifdef RT_USING_INTERRUPT_INFO
|
||||||
|
rt_strncpy(isr_table[vector].name, name, RT_NAME_MAX);
|
||||||
|
#endif /* RT_USING_INTERRUPT_INFO */
|
||||||
|
isr_table[vector].handler = handler;
|
||||||
|
isr_table[vector].param = param;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return old_handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*@}*/
|
/*@}*/
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
* 2006-03-13 Bernard first version
|
* 2006-03-13 Bernard first version
|
||||||
* 2006-05-27 Bernard add skyeye support
|
* 2006-05-27 Bernard add skyeye support
|
||||||
* 2007-11-19 Yi.Qiu fix rt_hw_trap_irq function
|
* 2007-11-19 Yi.Qiu fix rt_hw_trap_irq function
|
||||||
|
* 2013-03-29 aozima Modify the interrupt interface implementations.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <rtthread.h>
|
#include <rtthread.h>
|
||||||
|
@ -131,31 +132,38 @@ void rt_hw_trap_resv(struct rt_hw_register *regs)
|
||||||
rt_hw_cpu_shutdown();
|
rt_hw_cpu_shutdown();
|
||||||
}
|
}
|
||||||
|
|
||||||
extern rt_isr_handler_t isr_table[];
|
extern struct rt_irq_desc isr_table[];
|
||||||
|
|
||||||
void rt_hw_trap_irq()
|
void rt_hw_trap_irq(void)
|
||||||
{
|
{
|
||||||
unsigned long intstat;
|
unsigned long intstat;
|
||||||
rt_uint32_t i = 0;
|
rt_uint32_t irq = 0;
|
||||||
rt_isr_handler_t isr_func;
|
rt_isr_handler_t isr_func;
|
||||||
|
void *param;
|
||||||
|
|
||||||
/*Get the final intrrupt source*/
|
/*Get the final intrrupt source*/
|
||||||
intstat = *(RP)(INTC_IFSR);;
|
intstat = *(RP)(INTC_IFSR);;
|
||||||
|
|
||||||
/*Shift to get the intrrupt number*/
|
/*Shift to get the intrrupt number*/
|
||||||
while(intstat != 1)
|
while(intstat != 1)
|
||||||
{
|
{
|
||||||
intstat = intstat >> 1;
|
intstat = intstat >> 1;
|
||||||
i++;
|
irq++;
|
||||||
}
|
}
|
||||||
/* get interrupt service routine */
|
|
||||||
isr_func = isr_table[i];
|
|
||||||
|
|
||||||
/* turn to interrupt service routine */
|
/* get interrupt service routine */
|
||||||
isr_func(i);
|
isr_func = isr_table[irq].isr_handle;
|
||||||
|
param = isr_table[irq].param;
|
||||||
|
|
||||||
|
/* turn to interrupt service routine */
|
||||||
|
isr_func(irq, param);
|
||||||
|
|
||||||
|
#ifdef RT_USING_INTERRUPT_INFO
|
||||||
|
isr_table[irq].counter++;
|
||||||
|
#endif /* RT_USING_INTERRUPT_INFO */
|
||||||
}
|
}
|
||||||
|
|
||||||
void rt_hw_trap_fiq()
|
void rt_hw_trap_fiq(void)
|
||||||
{
|
{
|
||||||
rt_kprintf("fast interrupt request\n");
|
rt_kprintf("fast interrupt request\n");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue