芯路恒电子技术论坛

 找回密码
 立即注册

扫一扫,访问微社区

热搜: 活动
查看: 760|回复: 1

NIOS II CPU系统中的systemid和system timestamp功能意义作用介绍

[复制链接]
  • TA的每日心情
    慵懒
    2021-2-24 10:16
  • 268

    主题

    481

    帖子

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    11501
    发表于 2021-1-16 10:10:21 | 显示全部楼层 |阅读模式
    有用户提问,在qsys系统中,systemid加了,下载的时候systemid这一项校验也通过了,但是system timestamp值校验不通过。请问到底是怎么回事。用户还提供了截图,如下图所示:
    systemid.png


    而且他说,如果此时,在run的时候,勾选了忽略不匹配的系统时间戳(lgnore mismatched system timestamp)选项,就能成功run,如果不勾选,就不能run,而且即使是勾选该选项后run,run的结果也异常。
    勾选忽略sysid.jpg
    用户大概率会再次怀疑NIOS II不靠谱。

    先做个总结说明,这并不是NIOS II不靠谱的表现,反而恰恰相反,这是NIOS II CPU为了降低大家使用过程中犯低级错误的概率,而设置的一套强制验证机制。


    这里先对这两项的物理意义做个说明,相信说完大家就都懂问题到底在哪里了。


    首先来说,用户截图的这个只能证明你当前下载的sof里面的NIOS II系统,使用的system id是你设置的ID。
    举个例子,你在D盘根目录下创建了个工程,里面加入了sysid,设置的值为0x12345678,然后调试了一段时间之后,你想加功能,所以你把这个工程拷贝到了E盘工程根目录下,然后在E盘下基于这个工程加入了一个UART串口外设再编译。这个时候,两个系统的sysid都是0x12345678。此时,无论你下载D盘的还是E盘的sof到fpga芯片,在这个界面去调试的时候读到的sysid都是0x12345678,那么你认为这两个工程一样吗?你下载D盘工程的sof,能调试你针对E盘的工程写的uart的程序吗,所以,单就sysid校验正确,并不能确定这个工程就是对的,只要两个工程的sysid设置的相同,这一项就能通过。




    也因如此,NISO还有第二项机制来确保硬件(sof)和软件(elf)的匹配,这个就是system timestamp。在你的sopcinfo文件中,有一个timestamp的参数,如下图所示:
    systemid在sopcinfo文件中.png
    这个参数,每次Quartus工程编译一次,注意,是Quartus工程编译一次,而不是qsys重新生成一次,即使两次编译你没有改任何quartus中任何一个字符,两次编译,这个timestamp的值都会变化一次,都是不一样的。然后,在nios ii eds中,每次你重新编译了quartus工程,都会提示你重新generate bsp,这个重新generate bsp,就会读取你这个新的sopcinfo文件,并在system.h文件中记录这个新的timestamp参数,如下图所示:
    systemh文件中截图.png


    所以说,如果你的系统在校验的时候。timestamp对不上,就一定百分之一亿的确定,你下载的sof和你当前的nios ii 用的bsp对不上。


    所以,以后,加上sysid是个好习惯,通过sysid和timestap两个值来帮你辅助确认你用的两套内容到底是不是绝对对应的。说来惭愧,我本人一直没加systemid的这个习惯,但是因为我经验足够丰富,不会犯这种错误了,所以问题不大。新手建议还是都加上的好。




    补充说明下:前文的system timestamp是系统时间戳的意思,不是在qsys中配置个timer定时器来作为程序时间戳的意思。配置timer为timestamp功能,是用来测量C程序的运行时间用的。而这个system timestamp是用来确保整个工程的软硬件匹配用的。



    以下再附图两张,证明下我前面说的quartus每次编译都会更改那个system timestamp的值的情况。以下两个工程,两次编译时间间隔不超过5秒钟,可以看到,两次的system timestamp值确实是有了变化。
    编译结果1.png        编译结果2.png


    回复

    使用道具 举报

  • TA的每日心情
    开心
    2021-3-22 21:23
  • 0

    主题

    2

    帖子

    11

    积分

    新手入门

    Rank: 1

    积分
    11
    QQ
    发表于 2021-3-22 21:26:08 | 显示全部楼层
    明白了,原来timestamp是这个作用啊      
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|小黑屋|手机版|Archiver|芯路恒电子技术论坛  |鄂ICP备2021003648号

    GMT+8, 2021-4-23 00:48 , Processed in 0.064942 second(s), 11 queries , File On.

    Powered by Discuz! X3.3

    © 2001-2017 Comsenz Inc. Template By 【未来科技】【 www.wekei.cn 】

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