《SystemVerilog硬件设计及建模第7-8-9章.ppt》由会员分享,可在线阅读,更多相关《SystemVerilog硬件设计及建模第7-8-9章.ppt(84页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、MicroElectronics Center7.1 新操作符递增和递减操作符:+ -赋值操作符:+= -= *= /= %= &= |= = = =设置成员操作符: insideMicroElectronics Center7.1.1 递增递减操作符while (i + LIMIT) begin : loop1 /i最后的值为LIMITendwhile (+ j LIMIT) begin : loop2 /j最后的值为LIMIT - 1end语句操作描述j = i + 后加i的值赋给j,然后i加1j = + i先加i加1, 然后i的值赋给jj = i -后减i的值赋给j,然后i减1j = -
2、 i先减i减1, 然后i的值赋给jMicroElectronics Center7.1.1递增递减操作符竞争问题:+ 和 - 操作符是阻塞赋值,为避免竞争,递增递减操作符只能用于递增递减操作的变量不会被过程块外部语句读取的逻辑建模中!always_ff (posedge clock) if (!resetn) count = 0; else count+; always_ff (posedge clock) case (state) HOLD: if (count = MAX) .always_ff (posedge clock) if (!resetn) count = 0; else co
3、unt = count + 1; always_ff (posedge clock) case (state) HOLD: if (count = MAX) .MicroElectronics Center7.1.2 赋值操作符注意:这些赋值操作符是阻塞赋值,同样有竞争问题!操作符功能描述+=等号左边加上等号右边并赋值-=等号左边减去等号右边并赋值*=等号左边乘以等号右边并赋值/=等号左边除以等号右边并赋值%=等号左边除以等号右边,并将得到的余数赋值&=等号左边与等号右边进行位与操作并赋值|=等号左边与等号右边进行位或操作并赋值=等号左边与等号右边进行位异或操作并赋值=将等号左边逻辑右移右边指
4、定的位数并赋值=将等号左边算术右移右边指定的位数并赋值可综合性: i +; if (- i) sum = i +; 可综合性: b += 5; b = ( a += 5); MicroElectronics Center7.1.2 赋值操作符/example 7-1: package definitions; typedef enum logic 2 : 0 ADD, SUB, MULT, DIV, SL, SR opcode_t; typedef enum logic UNSIGNED, SIGNED operand_type_t; typedef union packed logic 23
5、 : 0 u_data; logic signed 23 : 0 s_data; data_t; typedef struct packed opcode_t opc; operand_type_t op_type; data_t op_a; data_t op_b; instr_t;endpackageMicroElectronics Center7.1.2 赋值操作符import definitions : *;module alu (input instr_t IW; output data_t alu_out); always (IW) begin if (IW.op_type = S
6、IGNED) begin alu_out.s_data = IW.op_a.s_data; unique case (IW.opc) ADD : alu_out.s_data += IW.op_b.s_data; SUB : alu_out.s_data -= IW.op_b.s_data; MULT : alu_out.s_data *= IW.op_b.s_data; DIV : alu_out.s_data /= IW.op_b.s_data; SL : alu_out.s_data = 2; endcase end else . end endmodule /add the omitt
7、ed contentsMicroElectronics Center7.1.3 有无关通配符的相等操作符无通配符逻辑相等:= =(!=),条件相等:= = =(!= =) SystemVerilog增加两个操作符:= =?和!=?,在这种操作符中,右操作数中的逻辑位X或Z被看作通配符,它可以与左操作数中相应位的任何值相匹配!aba= =ba= = =ba= =?ba!=ba!= =ba!=?b00000000真真真假假假00000101假假假真真真010Z0101未知假未知未知真未知010Z010Z未知真真未知假假010X010Z未知假真未知真假010X010X未知真真未知假假逻辑相等遇到Z或
8、X,结果为未知,条件相等按位对0、1、X、Z进行精确匹配,左右两操作数完全相同,则结果为真,反之为假!MicroElectronics Center7.1.3 有无关通配符的相等操作符Verilog中,数字中的逻辑X可以用字符X或x表示,逻辑Z可以用字符z,Z或?表示,如:logic 7 : 0 opcode;.if (opcode = =? 8b11011?) /屏蔽低三位如果两个操作数位数不同,通配相等操作符会在比较前将两向量扩展为相同长度,扩展规则与逻辑相等操作符一样。只有屏蔽位是常数表达式时通配符相等操作符才是可以综合的!即右操作数不能是变量!logic 3 : 0 a, b;logi
9、c y1, y2;assign y1 = (a = = ? 4b1?1);assign y2 = (a = =? b);MicroElectronics Center7.1.4 设置成员操作符insideinside是检测一个变量或值是否是某一值集合中一员的操作符。logic 2 : 0 a;if (a inside 3b001, 3b010, 3b100)/if (a = 3b001) | (a = 3b010) | (a = 3b100)if (data inside bus1, bus2, bus3, bus4) /其它信号集int d_array 0 : 1023;if (13 ins
10、ide d_array) /数组logic 2 : 0 a;if (a inside 3b1?1) /通配符/与使用 =?操作符一样MicroElectronics Center7.2 操作数改进Verilog的赋值转换:reg 63 : 0 a, y, temp;real r;temp = r * 3;y = a + temp;类型强制转换:type(表达式)longint a, y;real r;y = a + longint(r * 3);尺寸强制转换:size(表达式)logic 15 : 0 a, b, c, sum;logic carry;sum = a + 16(5);carry
11、, sum = 17(a + 3);sum = a + 16(b - 2) / c;符号强制转换:signed(表达式)unsigned(表达式)MicroElectronics Center7.3 改进的for循环Verilog的for循环变量必须在循环体外部声明,SystemVerilog则可以在for语句中直接声明,但该循环变量为局部自动变量,如果要在块外或层次化引用,则必须象Verilog那样在块外说明。always_ff (posedge clock) begin for ( bit 4 : 0 i = 0; i = 15, i +) .end.for (int i = 1, byt
12、e j = 0; i * j 128; i +, j += 3)MicroElectronics Center7.4 底部检测的do . while循环 do begin done = 0; OutofBound = 0; out = memaddr; if (addr 255) begin outofBound = 1; out = mem128; end else if (addr = 128) done = 1; addr -= 1;end while( addr = 128 & addr = 255);与Verilog相比,SystemVerilog除有while循环外,还有至少执行一
13、次的循环:do . while,该循环可以简化while循环代码量MicroElectronics Centeralways * begin begin : loop integer i; first_bit = 0; for (i = 0; i = 63; i = i + 1) begin : pass if ( i end_range) disable loop; /跳出循环 if ( datai) begin first_bit = i; disable loop; /跳出循环 end end /for end /loopend /alwaysVerilog采用disalbe实现跳转功能
14、,SystemVerilog新增了Break, continue, return语句实现跳转。disable可以跳转到循环结尾继续下一次循环,也可以直接跳出整个循环,难以理解。7.5 跳转语句MicroElectronics Center/disable在任务所有语句执行完成前提前从任务中返回task add_up_to_mux( input 5 : 0 max, output 63 : 0 result); integer i begin result = 1; if (max = 0) disable add_up_to_mux; for ( i = 1; i = 63; i = i +
15、1) begin result = result + result; if (i = max) disable add_up_to_max; end endendtask7.5 跳转语句MicroElectronics Centercontinue语句:logic 15 : 0 array 0 : 255;always_comb begin for (int i = 0; i = 255; i +) begin : loop if (array i = 0) continue; /下一i transform_function(arrayi); end /forend7.5 跳转语句break语
16、句:always_comb begin first_bit = 0; for (int i = 0; i = 63; i +) begin : loop if (i end_range) break; /跳出循环 if (data i ) begin first_bit = i; break; end end /forendMicroElectronics Centerreturn语句:task add_up_to_max (input 5 : 0 max, output 63 : 0 result); result = 1; if (max = 0) return; /退出任务 for (
17、int i = 1; i = 63; i = i + 1; begin result = result + result; if (i = max) return; endendtask7.5 跳转语句在任务或空函数中,关键字return后面不能有表达式,而在非空函数中return后面一定要有表达式。MicroElectronics Centeralways_ff (posedge clock, posedge reset) begin : FSM_procedure logic breakVar; if (reset) begin : reset_logic end : reset_logi
18、c else begin : FSM_sequencer unique case (SquatState) wait_rx_valid : begin :rx_valid_state Rxready = 1; breakVar = 1; for (int j = 0; j NumRx; j += 1) begin : loop1 for (int i = 0; i NumRx; i += 1) begin : loop2 if Rxvalidi & RoundRobini & breakVar) begin : match AtMcell = RxATMcelli; Rxreadyi = 0;
19、 SquatState = wait_rx_not_valid; breakVar = 0; end : match end : loop2 end : loop1 end : rx_valid_state endcase end : FSM_sequencer end : FSM_procedure7.6 改进的块名MicroElectronics Centeralways_comb begin : decode_block decoder : case (opcode) 2b00 : outer_loop : for (int i = 0; i = 15; i +) inter_loop
20、: for (int j = 0; j = 15; j +) /对其它操作码值的译码 endcaseend : decode_block 7.7 语句标号语句标号用于识别单条语句,有助于记录代码及引用这些代码,提高可读性及有助于调试和代码覆盖率分析,带标号的语句可以被disable语句取消。一个语句块可以有一个块名或标号,但是,不能同时有块名和标号!MicroElectronics Centerunique case ( ) endcasepriority case ( case_expression) endcase7.8 改进的case语句Verilog标准规定case语句必须按照列举顺序
21、来计算条件选项,这意味着case选项之间存在优先级,如果if elseif else中一样。MicroElectronics Centeralways_comb unique case (opcode) 2b00 : y = a + b; 2b01 : y = a b; 2b10 : y = a * b; 2b11 : y = a / b; endcaseend7.8.1 unique case条件判断u只有一个条件选项与条件表达式匹配u必须有一个条件选项与条件表达式匹配u不能有重叠的条件u必须指明所有条件logic 2 : 0 request;always_comb unique casez
22、 (request) 3b1? : sl1_gnt = 1; 3b?1? : sl2_gnt = 1; 3b?1 : sl3_gnt = 1; endcaseendlogic 2 : 0 opcode;always_comb unique case (opcode) 3b000 : y = a + b; 3b001 : y = a b; 3b010 : y = a * b; 3b100 : y = a / b; endcaseend当opcode为其它值时,将报警! casez (select) 3b1? : sl1_gnt = 1; 3b?1? : sl2_gnt = 1; 3b?1 : s
23、l3_gnt = 1; endcase当表达式值与多个条件选项匹配时,不会报警!MicroElectronics Centeralways_comb priority case (1b1) irq0 : irq = 4b0001; irq1 : irq = 4b0010; irq2 : irq = 4b0100; irq3 : irq = 4b1000; endcaseend7.8.2 priority case条件判断u至少有一个条件选项与条件表达式匹配u如果有多个条件选项的值与条件表达式匹配,必须执行第一个匹配分支u必须指明所有条件当表达式的值无条件选项匹配时,将会报警!防止产生锁存器Mi
24、croElectronics Centerlogic 2 : 0 sel;always_comb begin if (sel = 3b001) mux_out = a; else if (sel = 3b010) mux_out = b; else if (sel = 3b100) mux_out = c;end7.9 改进的if else判断语句Verilog中的if else if语句是有优先级顺序的,但这种优先级可能并不是硬件必须的,有可能只是工程师写源代码时任意列出的。MicroElectronics Center7.9 unque if else判断语句u可以并行求值u不能包含重叠的
25、条件u对未指明的条件进行警告logic 2 : 0 sel;always_comb begin unique if (sel = 3b001) mux_out = a; else if (sel = 3b010) mux_out = b; else if (sel = 3b100) mux_out = c;end /有未指明条件logic 2 : 0 sel;always_comb begin unique if (sel 0) mux_out = a; else if (sel 1) mux_out = b; else if (sel 2) mux_out = c;end /有重叠项Micr
26、oElectronics Center7.9 priority if else判断语句u必须按顺序求值u必须指定所有条件priority保证了软件工具之间处理的一致性,仿真器、综合器、等价检查工具和形式验证工具都按同样的方式进行解释。运行过程中,如果判定序列没有任何分支执行,就会警告,从而可以检测出是否会产生锁存逻辑!always_comb begin priority if (irq0) irq = 4b0001; else if (irq1) irq = 4b0010; else if (irq2) irq = 4b0100; else if (irq3) irq = 4b1000;end
27、MicroElectronics Center 使用枚举类型建立有限状态机模型 在FSM case语句中使用枚举类型在FSM case语句中使用always_comb使用枚举类型和两态类型建模复位逻辑第8章 有限状态机建模 SystemVerilog可以使用两态类型、枚举类型和用户自定义类型进行高层次抽象建模应用前面介绍过的always_comb, always_ff, always_latch及枚举类型结合起来,建立有限状态机模型MicroElectronics Centermodule traffic_light (output logic green_light, yellow_ligh
28、t, red_light, input sensor, input 15:0 green_downcnt, yellow_downcnt, input clock, resetN); enum RED, GREEN, YELLOW State, Next; / using enum defaults always_ff (posedge clock, negedge resetN) if (!resetN) State = RED; / reset to red light else State = Next;8.1使用枚举类型建立状态机模型介绍使用枚举类型建立如有限状态机这样的硬件逻辑需要的
29、规则MicroElectronics Center always_comb begin: set_next_state Next = State; / the default for each branch below unique case (State) RED: if (sensor) Next = GREEN; GREEN: if (green_downcnt = 0) Next = YELLOW; YELLOW: if (yellow_downcnt = 0) Next = RED; endcase end: set_next_state always_comb begin: set
30、_outputs green_light, yellow_light, red_light = 3b000; unique case (State) RED: red_light = 1b1; GREEN: green_light = 1b1; YELLOW: yellow_light = 1b1; endcase end: set_outputsendmodule8.1使用枚举类型建立状态机模型u 典型的三过程建模风格u 使用默认的枚举基类intu 例子中只有3个状态,int是32位的两态类型u 两态类型仿真时的默认初始值会掩盖设计问题u 枚举类型默认值可能导致RTL仿真与门级实现不一致Mi
31、croElectronics Centermodule traffic_light (output logic green_light, yellow_light, red_light, input sensor, input 15:0 green_downcnt, yellow_downcnt, input clock, resetN); enum logic 2 : 0 RED = 3b001, / explicit enum definition GREEN = 3b010, YELLOW = 3b100 State, Next; always_ff (posedge clock, ne
32、gedge resetN) if (!resetN) State = RED; / reset to red light else State = Next;8.1.1使用显式枚举类型表示状态编码利用枚举类型的显式基类型和显式值建模MicroElectronics Center always_comb begin: set_next_state Next = State; / the default for each branch below unique case (State) RED: if (sensor) Next = GREEN; GREEN: if (green_downcnt
33、= 0) Next = YELLOW; YELLOW: if (yellow_downcnt = 0) Next = RED; endcase end: set_next_state always_comb begin: set_outputs green_light, yellow_light, red_light = 3b000; unique case (State) RED: red_light = 1b1; GREEN: green_light = 1b1; YELLOW: yellow_light = 1b1; endcase end: set_outputsendmodule8.
34、1.1使用显式枚举类型表示状态编码u 枚举标签值显式指定u 综合编码器将保持显式的枚举标签值,利于综合前后的功能比较u 枚举类型的基类型为四态数据类型,需要正确复位MicroElectronics Centermodule traffic_light (output logic green_light, yellow_light, red_light, input sensor, input 15:0 green_downcnt, yellow_downcnt, input clock, resetN); enum R_BIT = 0, /状态寄存器中RED状态索引 G_BIT = 1, Y_
35、BIT = 2 state_bit; enum logic 2 : 0 RED = 3b001 R_BIT, GREEN = 3b001 G_BIT, YELLOW = 3b001 Y_BIT State, Next; always_ff (posedge clock, negedge resetN) if (!resetN) State = RED; / reset to red light else State = Next;8.1.2使用枚举类型的反向case语句反向case语句:条件表示式和条件选项位置颠倒,对有些综合器,反向case风格的one-hot码状态机会得到更优化的综合结果M
36、icroElectronics Center always_comb begin: set_next_state Next = State; / the default for each branch below unique case (1b1) /反向case语句 StateR_BIT : if (sensor) Next = GREEN; StateG_BIT : if (green_downcnt = 0) Next = YELLOW; StateY_BIT : if (yellow_downcnt = 0) Next = RED; endcase end: set_next_stat
37、e always_comb begin: set_outputs green_light, yellow_light, red_light = 3b000; unique case (1b1) /反向case语句 StateR_BIT : red_light = 1b1; StateG_BIT : green_light = 1b1; StateY_BIT : yellow_light = 1b1; endcase end: set_outputsendmodule8.1.2使用枚举类型的反向case语句为什么用两个枚举类型?!MicroElectronics Center unique 情况
38、指定所有条件选项必须并行求值,而不采用带优先级的编码方式,综合可以优化这些条件选项的译码逻辑 unique case指定条件选项不应该有重叠项,如果条件表达式值满足两个或多个条件选项,仿真时会有警告提示 unique case指定条件选项必须涵盖在仿真中会产生的条件表达式的所有值,如果仿真时,无分支执行,则有警告提示8.1.3枚举类型与unique case语句unique case语句减少了case语句的不确定性,在one-hot码状态机中的状态寄存器在某一时刻只有一位是1,也只有一个条件选项与值为1的条件表达式匹配MicroElectronics Center/ Verilog style
39、 case statement with X defaultreg 2 : 0 State, Next; / 3-bit variablescase (State) 3b001: Next = 3b010; 3b010: Next = 3b100; 3b100: Next = 3b001; default: Next = 3bXXX;endcase8.1.4指定未使用的状态值case条件表达式中可能有一些未使用的值,进行设计时需要进行相应的处理:赋逻辑值X或使用full_case附注采用default选项,综合编译器将认为所有在默认条件内的条件表达式值都是未使用值,综合编译器将进一步优化Mic
40、roElectronics Center/ case statement with enumerated X defaultenum logic 2:0 RED = 3b001, GREEN = 3b010, YELLOW = 3b100, BAD_STATE = 3bxxx State, Next;case (State) RED: Next = GREEN; GREEN: Next = YELLOW; YELLOW: Next = RED; default: Next = BAD_STATE;endcase8.1.4指定未使用的状态值枚举类型变量不能直接赋X值,如果需要赋X值,枚举类型的基
41、类必须是四态类型,且枚举标签必须用显式X值定义事实上,SystemVerilog不再需要BAD_STATE枚举值和default条件选项,将枚举类型和unique case结合起来消除了需要使用X赋值以表明存在未使用的条件表达式值情况MicroElectronics Centerenum R_BIT = 0, / index of RED state in State register G_BIT = 1, / index of GREEN state in State register Y_BIT = 2 state_bit;/ shift a 1 to the bit that repre
42、sents each stateenum logic 2:0 RED = 3b001R_BIT, GREEN = 3b001G_BIT, YELLOW = 3b001Y_BIT State, Next;always_comb begin: set_next_state Next = 3b000; / clear Next - ERROR: ILLEGAL ASSIGNMENT unique case (1b1) / reversed case statement/ WARNING: FOLLOWING ASSIGNMENTS ARE POTENTIAL DESIGN ERRORS StateR
43、_BIT: if (sensor = 1) NextG_BIT = 1b1; StateG_BIT: if (green_downcnt=0) NextY_BIT = 1b1; StateY_BIT: if (yellow_downcnt=0) NextR_BIT = 1b1; endcaseend: set_next_state8.1.5将状态值赋给枚举类型变量枚举类型变量只能被赋其类型集合中的值,不能直接对其赋文本值对状态位个别位赋值,可能导致非法值,应尽量避免!MicroElectronics Centerenum WAITE, LOAD, STORE State, Next;alway
44、s (posedge clock, negedge resetN) if (!resetN) State = WAITE; else State = Next;always (State) case (State) WAITE: Next = LOAD; LOAD: Next = STORE; STORE: Next = WAITE; endcase8.2在FSM中使用两态数据类型对模型仿真时,在时刻0以前,四态数据类型缺省值是X,而两态类型为0,进行复位时,其操作是将变量清0,因此,当复位逻辑有缺陷时,两态数据类型建模将会掩盖这种缺陷!当枚举类型用缺省的基类型时,情况与此相似。该例子将锁定在
45、状态WAIT,不能正确进行RTL仿真!MicroElectronics Center8.2在FSM中使用两态数据类型解决两态数据类型建模状态锁定办法:1.采用四态基类型显式声明枚举变量2.采用always_comb3.将unique case和四态基类型结合使用,可以检测复位是否正确MicroElectronics Center Module prototypes Nested modules Simplified netlists of module instances Netlist aliasing Passing values through module ports Port con
46、nections by reference Enhanced port declarations Parameterized types and polymorphism Variable declarations in blocksChapter 9 Design HierarchyThis chapter presents enhancements to Verilog about design hierarchyMicroElectronics Center/ prototype using Verilog-1995 styleextern module counter (cnt, d,
47、 clock, resetN);/ prototype using Verilog-2001 styleextern module counter #(parameter N = 15) (output logic N:0 cnt, input wire N:0 d, input wire clock, load, resetN);9.1 Module prototypesModule instance in verilog is simple method of creating design hierarchy. but it is difficult to compile a modul
48、e instance, why?module and its ports definition is in different place than module instance!SystemVerilog solves this by module Prototypes:MicroElectronics Center9.1 Module prototypesExtern module declarations can be listed in the same file in which the module is instantiated.The extern module declar
49、ation can be made in any module, at any level of the design hierarchy.The extern module declaration is only visible within the scope in which it is defined.It is not necessary for the extern module declaration to be encountered prior to an instance of the module.MicroElectronics Center9.1.1 Prototyp
50、e and actual definitionSystemVerilog requires that the port list of an extern module declaration exactly match the actual module definition, including the order of the ports and the port sizes.To avoid port declaration redundancy, module definition can use .* shortcut.extern module counter #(paramet