搜索
bottom↓
回复: 9

NIOS II中断响应时间实测,使用FPGA内嵌SingalTapII逻辑分析仪,响应外部中断用了1600个

[复制链接]

出0入0汤圆

发表于 2010-3-27 11:44:53 | 显示全部楼层 |阅读模式
NIOS 软核 E模式,50MHz时钟,嵌入signaltapII 逻辑分析仪,PIO沿中断,Quartus9.1, NIOS II 9.1 IDE。
测试代码非常简单,只包含一个中断服务程序pio_interrupt(void* context, alt_u32 id)和一个main()。
USB Blaster下载代码后(包含singaltapII编译),启动逻辑分析仪,设置触发条件为按键的下降沿。在中断服务程序中直接将BUTTON_PIO直接输出到LED_PIO。
singaltapII 显示的波形为实际的逻辑波形。
观察的结果是,NIOS II 的中断相应时间是33uS,相当于1600多个时钟周期,比AVR8位单片机还慢,不知道其他人有没有作过类似的测试。
逻辑分析仪的采样时钟也是50MHz。下面是外部中断测试的原代码,已经验证,很简单,很容易就跑起来。不信大家自己试试。

#include "altera_avalon_pio_regs.h"
#include "sys/alt_irq.h"
#include "system.h"
#include <stdio.h>

static void pio_interrupt(void* context, alt_u32 id);

int main()
{
  printf("NIOS WORKING\n");                              //display to make sure NIOS working
  IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,0xf);         //initial LED_PIO
  IOWR_ALTERA_AVALON_PIO_EDGE_CAP(BUTTON_PIO_BASE,0);    //clear any existing event
  IOWR_ALTERA_AVALON_PIO_IRQ_MASK(BUTTON_PIO_BASE,0xf);  //enable pio interrupt
  alt_irq_register(BUTTON_PIO_IRQ, NULL, pio_interrupt); //register isr
  return(0);
}

//isr
static void pio_interrupt(void* context, alt_u32 id)
{
    IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE,
    IORD_ALTERA_AVALON_PIO_DATA(BUTTON_PIO_BASE)
    );                                                   //output BUTTON_PIO to LED_PIO
    IOWR_ALTERA_AVALON_PIO_EDGE_CAP(BUTTON_PIO_BASE,0);  //clear edge
}



SignalTapII逻辑分析仪实测波形 (原文件名:SignalTapII.JPG)


SingalTapII 设置界面 (原文件名:SignalTapIISetup.JPG)

USER_PB[0]的下降沿与LEDG[0]的下降沿之间相差33us(1600多个时钟)

作为对比:ATMEGA128 跑8MHZ时钟, 响应外部中断的时间(external interrupt response time) 没记错的话,实测为3us左右

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

发表于 2010-3-27 14:56:46 | 显示全部楼层
高度关注后文。

出0入0汤圆

发表于 2010-3-27 15:16:25 | 显示全部楼层
关注

出0入0汤圆

 楼主| 发表于 2010-3-29 04:37:30 | 显示全部楼层
最新测试结果:
将NIOS II CPU 从/E 模式 升级为 /S 模式, 外部中断相应时间从33u降为11us,( 1600时钟周期降为600时钟周期),性能提升3倍!但仍然不够理想。

出0入0汤圆

发表于 2010-3-29 04:46:00 | 显示全部楼层
/f呢?

出0入0汤圆

 楼主| 发表于 2010-3-29 05:17:33 | 显示全部楼层
回复【4楼】tear086 .COM 缺氧
-----------------------------------------------------------------------

最新测试结果:
将NIOS II CPU 从/S 模式 升级为 /F 模式, 外部中断相应时间从11u降为6us,( 600时钟周期降为300时钟周期),性能又提升1倍!但仍然不满意。

出0入0汤圆

发表于 2010-3-29 06:22:22 | 显示全部楼层
增大数据和指令的Cache呢?
将DRAM换成SRAM呢?

出0入0汤圆

发表于 2010-3-29 08:37:33 | 显示全部楼层
以前我也做过类似的试验,发现NIOS的速度确实不够快感觉,三种核都试了

出0入0汤圆

发表于 2010-3-29 09:14:23 | 显示全部楼层
这个软核学习还行,实际应用还是有点差距,倒是AVALON总线不错,比较适合FPGA

出0入0汤圆

发表于 2010-4-2 01:18:24 | 显示全部楼层
学习 真的!
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-5-17 14:56

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表