ToB企服应用市场:ToB评测及商务社交产业平台

标题: 学习笔记:Verilog 语法 [打印本页]

作者: 徐锦洪    时间: 2024-12-17 12:11
标题: 学习笔记:Verilog 语法
  1. wire [1:0]  results ;
  2. assign      results = (a == 1'b0) ? 2'b01 :
  3.             (b==1'b0) ? 2'b10 :
  4.                 2'b11 ;
复制代码
  1. reg [3:0] counter ;  // A definition of counter register
  2. /*
  3. Next are notes with multiple lines.
  4. Codes here cannot be compiled.
  5. */
  6. assign   addr = 12'b0 ;
复制代码
  1. 4'b1011         // 4bit 数值
  2. 32'h3022_c0de   // 32bit 的数值,下划线 _ 是为了增强代码的可读性
  3. counter = 'd100 ; //一般会根据编译器自动分频位宽,常见的为32bit
  4. counter = 100 ; //默认十进制
  5. counter = 32'h64 ;
  6. //负数
  7. -6'd15  
  8. -15
复制代码
  1. 30.123
  2. 6.0
  3. 0.001
  4. 1.2e4         //大小为12000
  5. 1_0001e4      //大小为100010000
  6. 1E-3          //大小为0.001
复制代码
  1. reg [0: 14*8-1]       str ;
  2. initial begin
  3.     str = "www.runoob.com";
  4. end
复制代码
  1. wire   interrupt ;
  2. wire   flag1, flag2 ;
  3. wire   gnd = 1'b0 ;
复制代码
寄存器(reg)用来表现存储单元,它会保持数据原有的值,直到被改写。
  1. reg    clk_temp;
  2. reg    flag1, flag2 ;
复制代码
寄存器的值可在任意时刻通过赋值操作进行改写
  1. reg rstn ;
  2. initial begin
  3.     rstn = 1'b0 ;
  4.     #100 ;
  5.     rstn = 1'b1 ;
  6. end
复制代码
  1. reg [3:0]      counter ;    //声明4bit位宽的寄存器counter
  2. wire [32-1:0]  gpio_data;   //声明32bit位宽的线型变量gpio_data
  3. wire [8:2]     addr ;       //声明7bit位宽的线型变量addr,位宽范围为8:2
  4. reg [0:31]     data ;       //声明32bit位宽的寄存器变量data, 最高有效位为0
复制代码
向量的使用
  1. wire [9:0]     data_low = data[0:9] ;
  2. addr_temp[3:2] = addr[8:7] + 1'b1 ;
复制代码
  1. reg [31:0]     data1 ;
  2. reg [7:0]      byte1 [3:0];
  3. integer j ;
  4. always@* begin
  5.     for (j=0; j<=3;j=j+1) begin
  6.         byte1[j] = data1[(j+1)*8-1 : j*8];
  7.         //把data1[7:0]…data1[31:24]依次赋值给byte1[0][7:0]…byte[3][7:0]
  8.     end
  9. end
复制代码
  1. time       current_time ;
  2. initial begin
  3.        #100 ;
  4.        current_time = $time ; //current_time 的大小为 100
  5. end
复制代码
  1. integer          flag [7:0] ; //8个整数组成的数组
  2. reg  [3:0]       counter [3:0] ; //由4个4bit计数器组成的数组
  3. wire [7:0]       addr_bus [3:0] ; //由4个8bit wire型变量组成的数组
  4. wire             data_bit[7:0][5:0] ; //声明1bit wire型变量的二维数组
  5. reg [31:0]       data_4d[11:0][3:0][3:0][255:0] ; //声明4维的32bit数据变量数组
复制代码
对数组元素的赋值操作:
  1. flag [1]   = 32'd0 ; //将flag数组中第二个元素赋值为32bit的0值
  2. counter[3] = 4'hF ;  //将数组counter中第4个元素的值赋值为4bit 十六进制数F,等效于counter[3][3:0] = 4'hF,即可省略宽度;
  3. assign addr_bus[0]        = 8'b0 ; //将数组addr_bus中第一个元素的值赋值为0
  4. assign data_bit[0][1]     = 1'b1;  //将数组data_bit的第1行第2列的元素赋值为1,这里不能省略第二个访问标号,即 assign data_bit[0] = 1'b1; 是非法的。
  5. data_4d[0][0][0][0][15:0] = 15'd3 ;  //将数组data_4d中标号为[0][0][0][0]的寄存器单元的15~0bit赋值为3
复制代码
  1. reg               membit[0:255] ;  //256bit的1bit存储器
  2. reg  [7:0]        mem[0:1023] ;    //1Kbyte存储器,位宽8bit
  3. mem[511] = 8'b0 ;                  //令第512个8bit的存储单元值为0
复制代码
  1. parameter      data_width = 10'd32 ;
  2. parameter      i=1, j=2, k=3 ;
  3. parameter      mem_size = data_width * 10 ;
复制代码
局部参数用 localparam 来声明,其作用和用法与 parameter 相同,区别在于它的值不能被改变
17. 表达式
表达式由操作符和操作数构成。表达式可以在出现数值的任何地方使用。
  1. a^b ;          //a与b进行异或操作
  2. address[9:0] + 10'b1 ;  //地址累加
  3. flag1 && flag2 ;  //逻辑与操作
复制代码
  1. A = 4'b1010 ;
  2. B = 1'b1 ;
  3. Y1 = {B, A[3:2], A[0], 4'h3 };  //结果为Y1='b1100_0011
  4. Y2 = {4{B}, 3'd4};  //结果为 Y2=7'b111_1100
  5. Y3 = {32{1'b0}};  //结果为 Y3=32h0,常用作寄存器初始化时匹配位宽的赋初值
复制代码

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4