当前位置:首页 > 工业控制 > 电子设计自动化
[导读]如果传给任务的变量值和任务完成后接收结果的变量已定义,就可以用一条语句启动任务。任务完成以后控制就传回启动过程。如任务内部有定时控制,则启动的时间可以与控制返回的时间不同。任务可以启动其他的任务,其他

如果传给任务的变量值和任务完成后接收结果的变量已定义,就可以用一条语句启动任务。任务完成以后控制就传回启动过程。如任务内部有定时控制,则启动的时间可以与控制返回的时间不同。

任务可以启动其他的任务,其他任务又可以启动别的任务,可以启动的任务数是没有限制的。不管有多少任务启动,只有当所有的启动任务完成以后,控制才能返回。

1.任务定义

定义任务的语法如下:

任务:

1.任务定义

定义任务的语法如下:

任务:

task <任务名>;
      <端口及数据类型声明语句>
      <语句1>
      <语句2>
      ...
      <语句n>
endtask

这些声明语句的语法与模块定义中的对应声明语句的语法是一致的。


2.任务调用及变量传递
调用任务并传递输入/输出变量的声明语句的语法如下:

<任务名>(端口1,端口2,...,端口n);

下面的例子说明怎样定义任务和调用任务。
任务定义如下所示:

task  my_task;
     input a, b;
     inout  c;
     output d, e;
     …
     <语句>                 //执行任务工作相应的语句
     …
     c = foo1;            //赋初始值
     d = foo2;            //对任务的输出变量赋值
     e = foo3;
endtask

任务调用如下所示:

my_task(v,w,x,y,z);

 

任务调用变量(v、w、x、y、z)和任务定义的I/O变量(a、b、c、d、e)之间是一一对应的。当任务启动时,由v、w和x传入的变量赋给了a、b和c。当任务完成后的输出又通过c、d和e赋给了x、y和z。下面用一个具体的例子用来说明怎样在模块的设计中使用任务,使程序容易读懂。

 

module traffic_lights;
      reg  clock, red, amber, green;
      parameter  on=1, off=0, red_tics=350,
      amber_tics=30,green_tics=200;
      initial    red=off;                          //交通灯初始化
      initial    amber=off;
      initial    green=off;

      always begin                                 //交通灯控制时序
           red=on;                                  //开红灯
           light(red,red_tics);                  //调用等待任务
           green=on;                                //开绿灯
           light(green,green_tics);              //等待
           amber=on;                                //开黄灯
           light(amber,amber_tics);              //等待
      end

      task  light(color,tics);                  //定义交通灯开启时间的任务
           output  color;
           input[31:0] tics;
           begin
                repeat(tics) @(posedge clock);  //等待tics个时钟的上升沿
                color=off;                           //关灯
           end
      endtask

      always begin                                //产生时钟脉冲的always块
            #100 clock=0;
            #100 clock=1;
      end
endmodule

 

这个例子描述了一个简单的交通灯的时序控制,并且该交通灯有它自己的时钟产生器。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭