40130064 发表于 2010-5-25 15:53:48

麻烦高手指点下NIOS多中断问题谢谢

/*******************************************************
* 功    能:初始化PIO,申请中断
/*******************************************************/
voidPIO_init(void)
{

IOWR_ALTERA_AVALON_PIO_DIRECTION(LED_PIO_BASE, LEDCON); //LED_PIO为输出
IOWR_ALTERA_AVALON_PIO_DIRECTION(KEY_PIO_BASE, 0x00); //KEY_PIO为输出
IOWR_ALTERA_AVALON_PIO_IRQ_MASK(KEY_PIO_BASE, KEYCON); //开启KEY的中断
IOWR_ALTERA_AVALON_PIO_EDGE_CAP(KEY_PIO_BASE, 0x00);//清边沿捕获寄存器
alt_irq_register(KEY_PIO_IRQ, NULL, Isr_KeyDown);//注册中断服务子程序
}
//初始化UART,申请中断
void Uart_init(void)
{
    IOWR_ALTERA_AVALON_UART_CONTROL(RS232_BASE, 0x80);//接收中断使能
    IOWR_ALTERA_AVALON_UART_STATUS(RS232_BASE, 0x00);//清状态标志
    IOWR_ALTERA_AVALON_UART_RXDATA(RS232_BASE, 0x00);//清接收寄存器
    alt_irq_register(RS232_IRQ,NULL,Uart_ISR);//注册中断服务子程序

}

/*******************************************************
* PIO中断服务子程序
/*******************************************************/
void Isr_KeyDown(void* context, alt_u32 id)
{
   
   IOWR_ALTERA_AVALON_PIO_EDGE_CAP(KEY_PIO_BASE, 0);    // 清中断捕获寄存器
   done++;   // 中断事件发生时done加一
}

/*******************************************************/
//串口接收中断服务程序
/*******************************************************/

void Uart_ISR(void * context,alt_u32 id)
{
    sd=IORD_ALTERA_AVALON_UART_RXDATA(RS232_BASE);
      if(sd==0X68)
      {
            ids=ids+1;
   
                if(ids>=6)
                  {   
                     if ((sd==0X16))
                     {
                     ids=0;
                     rev=0x99;//取数标志         
                     }
                     else
                     {
                      ids=0;
                      }   
                  }               
      }
      
}

一个串口中断 2个PIO引脚外部中断 这四个函数怎么写.主要是那个中断号和中断服务程序不懂
alt_irq_register(KEY_PIO_IRQ, NULL, Isr_KeyDown);//注册中断服务子程序
KEY_PIO_IRQ 这个写什么值?

40130064 发表于 2010-5-25 17:16:25

回复【楼主位】40130064
-----------------------------------------------------------------------

上啊 就是要两个中断的例子
页: [1]
查看完整版本: 麻烦高手指点下NIOS多中断问题谢谢