e203 添加中断源 中断源无法使能

2020-05-17 10:50:27
0
109

大家好:

    硬件平台为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; 



用户评论

关注我们

微信扫码登录 点击刷新二维码