首页 > 其他分享 >initial语句

initial语句

时间:2023-01-16 11:07:51浏览次数:60  
标签:语句 begin end ai initial bi


关键词:initial, always

过程结构语句有 2 种,initial 与 always 语句。它们是行为级建模的 2 种基本语句。

一个模块中可以包含多个 initial 和 always 语句,但 2 种语句不能嵌套使用。

这些语句在模块间并行执行,与其在模块的前后顺序没有关系。

但是 initial 语句或 always 语句内部可以理解为是顺序执行的(非阻塞赋值除外)。

每个 initial 语句或 always 语句都会产生一个独立的控制流,执行时间都是从 0 时刻开始。

initial语句

initial 语句从 0 时刻开始执行,只执行一次,多个 initial 块之间是相互独立的。

如果 initial 块内包含多个语句,需要使用关键字 begin 和 end 组成一个块语句。

如果 initial 块内只要一条语句,关键字 begin 和 end 可使用也可不使用。

initial 理论上来讲是不可综合的,多用于初始化、信号检测等。

对上一节代码稍作修改,进行仿真,代码如下。


实例



`timescale 1ns/1ns

module test ;
reg ai, bi ;

initial begin
ai = 0 ;
#25 ; ai = 1 ;
#35 ; ai = 0 ; //absolute 60ns
#40 ; ai = 1 ; //absolute 100ns
#10 ; ai = 0 ; //absolute 110ns
end

initial begin
bi = 1 ;
#70 ; bi = 0 ; //absolute 70ns
#20 ; bi = 1 ; //absolute 90ns
end

//at proper time stop the simulation
initial begin
forever begin
#100;
//$display("---gyc---%d", $time);
if ($time >= 1000) begin
$finish ;
end
end
end

endmodule

仿真结果如下:

可以看出,2 个 initial 进程语句分别给信号 ai,bi 赋值时,相互间并没有影响。

信号 ai,bi 的值按照赋值顺序依次改变,所以 initial 内部语句也可以看做是顺序执行。

我用的是 vivado ​​21 秒学会 vivado 仿真​

initial语句_fpga开发


标签:语句,begin,end,ai,initial,bi
From: https://blog.51cto.com/u_15202985/6010165

相关文章

  • 循环语句
    目录循环语句while循环简单循环嵌套循环for循环简单循环嵌套循环循环的关键词循环语句while循环简单循环while条件:循环体嵌套循环while条件:while条件:......
  • shell 脚本if语句
    思路:判断/root/test/下是否有14这个文件,如果有.就拷贝到/home目录下例:#!/bin/bashif  [-f/root/test/14]||cp/root/test/14/home  then       echo......
  • for 语句
    for语句是循环语句中的一种。for语句可以使程序在某一个条件下重复执行一段代码。1.基本语法for语句相对于if语句稍微复杂,通常为以下格式:for(初始语句;条件;条件为......
  • JavaScript while 语句
    while语句可以在某个条件表达式为真的前提下,循环执行指定的一段代码,直到那个表达式不为真时结束循环。——MDNwhile语句也是一种循环语句,也称while循环。while循环接......
  • mybatis&mybatis-plus的sql语句
    在springboot项目中,我们会使用到sql语句,要么是使用mybatis-plus底层已经写好的,要么是使用mybatis,来编写对应的sql映射文件.注意:在springboot中,只需要导入mybatis-pl......
  • SQL语句复习
    数据库定义语言(DDL)数据库操作创建数据库createdatabase数据库名为了能够支持中文,我们在创建时可以设定编码格式:CREATEDATABASEIFNOTEXISTS数据库名DEFAULTC......
  • sql语句总结
    1、优秀sql语句:SELECT r.refund_code退单编号, r.order_code订单编号, g.product_full_name_cn商品名称, g.product_variant_code商品编码, CASE WHENlength(g.pro......
  • 存储过程 RETURN语句
     1、RETURN如果没有使用表达式,RETURN命令用于告诉这个函数已经完成执行了,如示例2.如果返回标量类型,那么可以使用任何表达式。 示例1:带有表达式returnCREATEOR......
  • library initialization failed - unable to allocate file descriptor table - out o
    1.报错日志libraryinitializationfailed-unabletoallocatefiledescriptortable-outofmemory/cm-server/aiboxCloud-web/boot/entrypoint.sh:line2:  ......
  • mysql 杀死执行卡死的sql语句(一般是死锁造成的)
    语法killthread_id  查看thread_id 方法showprocesslist,第一列的id就是thread_id,一般需要杀死的线程的command这一列是query   DaemonSleepSleepSleepS......