当前位置: 首页 > news >正文

网站开发视频播放网站大墨免费空间申请

网站开发视频播放网站,大墨免费空间申请,深圳做二维码网站建设,wordpress手机验证免插件Verilog 最常用的 2 种数据类型就是线网#xff08;wire#xff09;与寄存器#xff08;reg#xff09;#xff0c;其余类型可以理解为这两种数据类型的扩展或辅助。 线网#xff08;wire#xff09; wire 类型表示硬件单元之间的物理连线#xff0c;由其连接的器件输…Verilog 最常用的 2 种数据类型就是线网wire与寄存器reg其余类型可以理解为这两种数据类型的扩展或辅助。 线网wire wire 类型表示硬件单元之间的物理连线由其连接的器件输出端连续驱动。如果没有驱动元件连接到 wire 型变量缺省值一般为 Z。举例如下 实例 wire   interrupt ; wire   flag1, flag2 ; wire   gnd 1b0 ; 线网型还有其他数据类型包括 wandworwritriandtriortrireg 等。这些数据类型用的频率不是很高这里不做介绍。 寄存器reg 寄存器reg用来表示存储单元它会保持数据原有的值直到被改写。声明举例如下 实例 reg    clk_temp; reg    flag1, flag2 ; 例如在 always 块中寄存器可能被综合成边沿触发器在组合逻辑中可能被综合成 wire 型变量。寄存器不需要驱动源也不一定需要时钟信号。在仿真时寄存器的值可在任意时刻通过赋值操作进行改写。例如 实例 reg rstn ; initial beginrstn 1b0 ;#100 ;rstn 1b1 ; end 向量 当位宽大于 1 时wire 或 reg 即可声明为向量的形式。例如 实例 reg [3:0]      counter ;    //声明4bit位宽的寄存器counter wire [32-1:0]  gpio_data;   //声明32bit位宽的线型变量gpio_data wire [8:2]     addr ;       //声明7bit位宽的线型变量addr位宽范围为8:2 reg [0:31]     data ;       //声明32bit位宽的寄存器变量data, 最高有效位为0 对于上面的向量我们可以指定某一位或若干相邻位作为其他逻辑使用。例如 实例 wire [9:0]     data_low data[0:9] ; addr_temp[3:2] addr[8:7] 1b1 ; Verilog 支持可变的向量域选择例如 实例 reg [31:0]     data1 ; reg [7:0]      byte1 [3:0]; integer j ; always* beginfor (j0; j3;jj1) beginbyte1[j] data1[(j1)*8-1 : j*8]; //把data1[7:0]…data1[31:24]依次赋值给byte1[0][7:0]…byte[3][7:0]end end Verillog 还支持指定 bit 位后固定位宽的向量域选择访问。 [bit: width] : 从起始 bit 位开始递增位宽为 width。[bit-: width] : 从起始 bit 位开始递减位宽为 width。 实例 //下面 2 种赋值是等效的 A data1[31-: 8] ; A data1[31:24] ;//下面 2 种赋值是等效的 B data1[0 : 8] ; B data1[0:7] ; 对信号重新进行组合成新的向量时需要借助大括号。例如 实例 wire [31:0]    temp1, temp2 ; assign temp1 {byte1[0][7:0], data1[31:8]};  //数据拼接 assign temp2 {32{1b0}};  //赋值32位的数值0 整数实数时间寄存器变量 整数实数时间等数据类型实际也属于寄存器类型。 整数integer 整数类型用关键字 integer 来声明。声明时不用指明位宽位宽和编译器有关一般为32 bit。reg 型变量为无符号数而 integer 型变量为有符号数。例如 实例 reg [31:0]      data1 ; reg [3:0]       byte1 [7:0]; //数组变量后续介绍 integer j ;  //整型变量用来辅助生成数字电路 always* beginfor (j0; j3;jj1) beginbyte1[j] data1[(j1)*8-1 : j*8]; //把data1[7:0]…data1[31:24]依次赋值给byte1[0][7:0]…byte[3][7:0]end end 此例中integer 信号 j 作为辅助信号将 data1 的数据依次赋值给数组 byte1。综合后实际电路里并没有 j 这个信号j 只是辅助生成相应的硬件电路。 实数real 实数用关键字 real 来声明可用十进制或科学计数法来表示。实数声明不能带有范围默认值为 0。如果将一个实数赋值给一个整数则只有实数的整数部分会赋值给整数。例如 实例 real        data1 ; integer     temp ; initial begindata1 2e3 ;data1 3.75 ; endinitial begintemp data1 ; //temp 值的大小为3 end 时间time Verilog 使用特殊的时间寄存器 time 型变量对仿真时间进行保存。其宽度一般为 64 bit通过调用系统函数 $time 获取当前仿真时间。例如 实例 time       current_time ; initial begin#100 ;current_time $time ; //current_time 的大小为 100 end 数组 在 Verilog 中允许声明 reg, wire, integer, time, real 及其向量类型的数组。 数组维数没有限制。线网数组也可以用于连接实例模块的端口。数组中的每个元素都可以作为一个标量或者向量以同样的方式来使用形如数组名[下标]。对于多维数组来讲用户需要说明其每一维的索引。例如 实例 integer          flag [7:0] ; //8个整数组成的数组 reg  [3:0]       counter [3:0] ; //由4个4bit计数器组成的数组 wire [7:0]       addr_bus [3:0] ; //由4个8bit wire型变量组成的数组 wire             data_bit[7:0][5:0] ; //声明1bit wire型变量的二维数组 reg [31:0]       data_4d[11:0][3:0][3:0][255:0] ; //声明4维的32bit数据变量数组 下面显示了对数组元素的赋值操作 实例 flag [1]   32d0 ; //将flag数组中第二个元素赋值为32bit的0值 counter[3] 4hF ;  //将数组counter中第4个元素的值赋值为4bit 十六进制数F等效于counter[3][3:0] 4hF即可省略宽度; assign addr_bus[0]         8b0 ; //将数组addr_bus中第一个元素的值赋值为0 assign data_bit[0][1]     1b1;  //将数组data_bit的第1行第2列的元素赋值为1这里不能省略第二个访问标号即 assign data_bit[0] 1b1; 是非法的。 data_4d[0][0][0][0][15:0] 15d3 ;  //将数组data_4d中标号为[0][0][0][0]的寄存器单元的15~0bit赋值为3 虽然数组与向量的访问方式在一定程度上类似但不要将向量和数组混淆。向量是一个单独的元件位宽为 n数组由多个元件组成其中每个元件的位宽为 n 或 1。它们在结构的定义上就有所区别。 存储器 存储器变量就是一种寄存器数组可用来描述 RAM 或 ROM 的行为。例如 实例 reg               membit[0:255] ;  //256bit的1bit存储器 reg  [7:0]        mem[0:1023] ;    //1Kbyte存储器位宽8bit mem[511] 8b0 ;                  //令第512个8bit的存储单元值为0 参数 参数用来表示常量用关键字 parameter 声明只能赋值一次。例如 实例 parameter      data_width 10d32 ; parameter      i1, j2, k3 ; parameter      mem_size data_width * 10 ; 但是通过实例化的方式可以更改参数在模块中的值。此部分以后会介绍。 局部参数用 localparam 来声明其作用和用法与 parameter 相同区别在于它的值不能被改变。所以当参数只在本模块中调用时可用 localparam 来说明。 字符串 字符串保存在 reg 类型的变量中每个字符占用一个字节8bit。因此寄存器变量的宽度应该足够大以保证不会溢出。 字符串不能多行书写即字符串中不能包含回车符。如果寄存器变量的宽度大于字符串的大小则使用 0 来填充左边的空余位如果寄存器变量的宽度小于字符串大小则会截去字符串左边多余的数据。例如为存储字符串 run.runoob.com, 需要 14*8bit 的存储单元 实例 reg [0: 14*8-1]       str ; initial beginstr run.runoob.com; end 有一些特殊字符在显示字符串中有特殊意义例如换行符制表符等。如果需要在字符串中显示这些特殊的字符则需要在前面加前缀转义字符 \ 。例如下表所示 转义字符显示字符\n换行\t制表符%%%\\\\ooo1到3个8进制数字字符 其实在 SystemVerilog主要用于 Verilog 仿真的编程语言语言中已经可以直接用关键字 string 来表示字符串变量类型这为 Verilog 的仿真带来了极大的便利。有兴趣的学者可以简单学习下 SystemVerilog。 希望你也学会了更多编程源码模板请来二当家的素材网https://www.erdangjiade.com
http://www.pierceye.com/news/975482/

相关文章:

  • c语言网站建设禅城网站开发
  • 宁波品牌网站制作哪家好太平阳电脑网网站模板
  • seo网站外链工具看设计比较好的网站
  • 济南道驰网站建设有限公司怎么样某网站网站的设计与实现
  • 服装印花图案设计网站设计一个网站要多久
  • ai怎么做自己的网站getpage wordpress使用详解
  • 龙岩做网站推广龙岗网站 建设深圳信科
  • 沈阳网站建设 网络服务广告公司首页
  • 旅游网站建设导航栏中国哪里正在大开发大建设
  • 哪能建设网站建设网站需要哪些流程图
  • 网站YYQQ建设o2o型网站
  • 给客户做网站 赚钱吗赣州省住房和城乡建设厅网站
  • 营销优化型网站怎么做手机app网页制作
  • 上海网站建设服wordpress友情链接排序
  • 沈阳市和平区网站建设编程课适合多大孩子学
  • 东阳网站优化懒人图库
  • 马关县网站建设专注营销型网站建设
  • 微信公众号公众平台太原seo关键词优化
  • 沈阳网站建设方案二级网站怎样被百度收录
  • 厦门数字引擎 怎么打不开网站youku网站开发技术
  • 中小企业网站建设论文郑州网站服务公司
  • 工信部网站备案验证码文化传媒网站封面
  • 境外做网站网站百度代运营
  • 南京学校网站建设策划手机网站默认全屏
  • 东莞公司网站策划万网买网站
  • 建筑网站视频大全做外汇网站卖判刑多少年
  • 手机网站菜单网页怎么做东莞网站优化方案
  • 公众号免费素材网站wordpress无法开始安装
  • 建设银行互联网网站首页网站备案 视频
  • 免费优化网站建设做app和网站哪个比较好用