喜欢0次
大家好:
硬件平台为arty a7,我们给E203添加了一个以太网外设,按照顺序把中断源设置为53号,可是发现外设的确产生了中断信号(边沿),可是plic模块的plic_ext_irq并没有被拉高。
担心是由于添加中断的时候plic模块的修改有问题,我们直接把52号中断(IIC),接到了以太网外设的中断信号上,发现plic模块的plic_ext_irq还是没有被拉高。
我们在对应的c程序中读了一下发现,虽然我们调用了中断使能函数,可是读回来的plic对应中断源的中断使能寄存器还是0。不知道是为什么?有人遇到同样的问题吗,PLIC中断源使能无效。
我们最后把button 2对应的中断接口连到了以太网外设上(39号),发现这次就可以使能中断源了?真的好奇怪,现在在阅读plic_man的源码,希望能发现原因吧。最后版本的C和verilog代码。
// platform.h
#define PLIC_INT_EMAC_BASE 39 // TODO: add plic_int_emac_base
#define PLIC_NUM_INTERRUPTS 54 // TODO: change 52 to 54
// main.c
void register_plic_irqs (){
/**************************************************************************
* Set up the PLIC
*
*************************************************************************/
PLIC_init(&g_plic,
PLIC_CTRL_ADDR,
PLIC_NUM_INTERRUPTS,
PLIC_NUM_PRIORITIES);
for (int ii = 0; ii < PLIC_NUM_INTERRUPTS; ii ++){
g_ext_interrupt_handlers[ii] = no_interrupt_handler;
}
g_ext_interrupt_handlers[PLIC_INT_EMAC_BASE] = emac_re_handler;
g_ext_interrupt_handlers[PLIC_INT_DEVICE_BUTTON_1] = button_1_handler;
PLIC_enable_interrupt (&g_plic, PLIC_INT_EMAC_BASE);
PLIC_enable_interrupt (&g_plic, PLIC_INT_DEVICE_BUTTON_1);
PLIC_set_priority(&g_plic, PLIC_INT_EMAC_BASE, 1);
PLIC_set_priority(&g_plic, PLIC_INT_DEVICE_BUTTON_1, 1);
}
// e203_subsys_plic.v
wire plic_irq_i_38 = ip2intc_irpt;