Verilog系列:【13】task和function

在使用Verilog进行设计的过程中,使用task和function在同一个module中多次调用,充分提高了代码的复用性,有效增强设计的可维护性和复用性,可以避免不同模块间代码复制导致的不必要的错误。本文主要探讨task和function的使用以及两者之间的异同点。

1    task

 定义不能出现在过程性语句快中,但是必须在“module-end”结构中。

格式一:

格式二:

task可以没有或者有一个或多个参数,值通过参数传入和传出task。输入输出在任务开始处声明,且输入与输出信号的排列顺序决定了task被调用时传递参数的顺序。在使用task时需要注意以下几点:

  • task一般在过程性语句中被调用,且调用语句中的输入必须与task定义中的一致,输出亦然,参数传递的顺序保持一致;

  • task参数是按照值传递方式进行传递(不是引用),所以在被调用的task执行的过程中,如果该task外部输入参数发生变化是不会影响正在执行的task;

  • 因为task在过程性语句中定义,所以task在调用时传递的参数都是变量类型(reg、integer、real等);

  • 定义task的module中的变量对于task是可见的,即task可引用其所在module中定义的变量,但是这种引用全局变量的做法极度不推荐;

  • task在默认情况下是static,即当多个并行进程调用同一个task时将会有可能导致程序异常(后续进行示例







欢迎大家点赞转发哦~  ,本文原发于微信公众号【硅芯思见】

全部评论
自学过verilog,不过后面没继续学了
点赞 回复 分享
发布于 2022-06-27 20:26

相关推荐

11-05 18:30
门头沟学院 Java
点赞 评论 收藏
分享
ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
你是来当牛马的吧:行了,照片拍完了,让大家都回工位吧
点赞 评论 收藏
分享
1 18 评论
分享
牛客网
牛客企业服务