

















































| <ul> <li>The always statement creates</li> <li>always @ sensitivity LHS = expression; <ul> <li>@ sensitivity controls when</li> <li>LHS can only be reg type</li> <li>expression can contain either wire or reg type mixed with operators</li> </ul> </li> <li>Logic <ul> <li>reg c, b; wire a;</li> <li>always @(a, b) c = ~(a &amp; b);</li> <li>always @* c = ~(a &amp; b);</li> </ul> </li> <li>Storage <ul> <li>reg Q; wire clk;</li> <li>always @(posedge clk) Q &lt;= D;</li> </ul> </li> </ul> | Synthesis: Always Statement                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <ul> <li>Interviewed with the second term of term</li></ul> |















































|  | Example: Counter                                                                                                                                                               |
|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | module counter (clk, clr, load, in, count);<br>parameter width=8;<br>input clk, clr, load;<br>input [width-1 : 0] in;<br>output [width-1 : 0] count;<br>reg [width-1 : 0] tmp; |
|  | <pre>always @(posedge clk or negedge clr) begin if (!clr) tmp = 0; else if (load) tmp = in; else tmp = tmp + 1; end assign count = tmp; endmodule</pre>                        |















|   | Priority Encode                                                                                                                                                                                                                            | ers 🗖 |
|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
|   | <pre>// // Priority encoders // // Allen Tanner // module prior_enc(x,y,z, a,b,c,d,e,f); output reg x,y,z; input a,b,c,d,e,f;</pre>                                                                                                        |       |
| ŀ | <pre>always@(a,b,c,d,e,f,g)     begin         {x,y,z} = 3'b0;         if ((a==1) &amp;&amp; (b==1))z = 1;         if ((c==1) &amp;&amp; (d==1))y = 1;         if ((e==1) &amp;&amp; (f==1))x = 1;         end endmodule // prior_enc</pre> | aif z |
|   |                                                                                                                                                                                                                                            | eY    |
|   |                                                                                                                                                                                                                                            | g x   |































|  | Get off my Cas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | e 🗖                                                                                                                                                                                                                                  |
|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | <pre>// Case tests // Allen Tanner // reg sel; initial begin    \$display("We've only just begun"); #1 \$display("\n Driving 0"); sel = 0; #1 \$display("\n Driving 1"); sel = 1; #1 \$display("\n Driving x");</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | We've only just begun<br>Driving 0<br>CASEZa : Logic 0 on sel<br>CASEZ : Logic 0 on sel<br>CASEZ : Logic 0 on sel<br>CASE : Logic 0 on sel<br>Driving 1<br>CASE : Logic 1 on sel<br>CASEZ : Logic 1 on sel<br>CASEZ : Logic 1 on sel |
|  | <pre>sel = 1<sup>2</sup>bx;<br/>#1 \$display ("\n Driving z");<br/>sel = 1<sup>2</sup>bz;<br/>#1 \$finish;<br/>end<br/>always @ (sel)<br/>case (sel)<br/>1<sup>2</sup>b0 : \$display("CASE : Logic 0 on a<br/>1<sup>2</sup>b1 : \$display("CASE : Logic 1 on a<br/>1<sup>2</sup>bx : \$display("CASE : Logic x on a<br/>1<sup>2</sup>bx : \$display("CASE : Logi</pre> | Driving x<br>CASEZa : Logic x on sel<br>CASEZ : Logic x on sel<br>CASEX : Logic 0 on sel<br>CASE : Logic x on sel<br>Driving z<br>CASE : Logic z on sel<br>CASEX : Logic 0 on sel<br>CASEX : Logic 0 on sel                          |
|  | <pre>always @ (sel) casex (sel) 1'b0 : \$display("CASEX : Logic 0 on a 1'b1 : \$display("CASEX : Logic 1 on a 1'bx : \$display("CASEX : Logic x on a 1'bz : \$display("CASEX : Logic x on a 1'bz : \$display("CASEX : Logic z on a endcase</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | <pre>CASEZa : Logic 1 on sel<br/>L20 "testfixture.new": \$fi<br/>sel");<br/>sel");<br/>sel");</pre>                                                                                                                                  |
|  | always @ (sel)<br>casez (sel)<br>1'b0 : \$display("CASEZ : Logic 0 on 1<br>1'b1 : \$display("CASEZ : Logic 1 op<br>1'bx : \$display("CASEZ : Logic 0 on 1<br>1'bz : \$display("CASEZ : Logic 0 on 1<br>endcase<br>always @ (sel)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Order Matters                                                                                                                                                                                                                        |
|  | <pre>l'bl : \$display("CASEZa : Logic 1 on :<br/>1'b0 : \$display("CASEZa : Logic 0 on :<br/>1'bc : \$display("CASEZa : Logic x on :<br/>1'bz : \$display("CASEZa : Logic z on :<br/>endcase</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <pre>sel");<br/>sel");<br/>sel");<br/>sel");</pre>                                                                                                                                                                                   |

| Get off my                                                                                                                                                                                                                                                                                                                                                                                | Case 🗖                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>// Case tests // Allen Tanner Link // reg [15:0]opcode; initial begin    \$display("We've only just begun"); #1 \$display(" Driving add"); opcode = 16'b1000_1000_1010_1111; #1 \$display (" Driving subtract"); opcode = 16'b0100_0100_1010_1111; #1 \$display (" Driving mutiply"); opcode = 16'b0010_0010_1010_1111; #1 \$finish; and</pre>                                       | We've only just begun<br>Driving add<br>CASEZ. Opcode: add<br>CASEX. Opcode: add<br>Driving subtract<br>CASEX. Opcode: subtract<br>CASEZ. Opcode: subtract<br>Driving mutiply<br>CASEZ. Opcode: multiply<br>CASEX. Opcode: multiply |
| <pre>always @ (opcode)<br/>casex (opcode)<br/>16'blx2?_xxxx_xxxx_xxxx : \$display("CAS<br/>16'bxlxx_xxxx_xxxx_xxxx : \$display("CAS<br/>endcase<br/>always @ (opcode)<br/>casez (opcode)<br/>16'bl???_zzzz_zzzz_zzzz : \$display("CAS<br/>16'b???_zzzz_zzzz_zzz : \$display("CAS<br/>16'b???_zzzz_zzzz_zzz : \$display("CAS<br/>16'b????_zzzz_zzzz_zzz : \$display("CAS<br/>endcase</pre> | L18 "testfixture.new": \$fir<br>SEX. Opcode: add");<br>SEX. Opcode: subtract");<br>SEX. Opcode: multiply");<br>SEZ. Opcode: add");<br>SEZ. Opcode: subtract");<br>SEZ. Opcode: multiply");                                          |

















![](_page_41_Figure_1.jpeg)

![](_page_42_Figure_0.jpeg)

![](_page_42_Figure_1.jpeg)

![](_page_43_Figure_0.jpeg)

|  |  | Textbook FSM                                                                                                                                                          |
|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | // Verilog HDL for "Ax", "see4" "behavioral"<br>// Four in a row detector - Allen Tanner                                                                              |
|  |  | <pre>module see4 (clk, clr, insig, saw4);<br/>input clk, clr, insig;<br/>output saw4;</pre>                                                                           |
|  |  | <pre>// define state encodings as parameters     parameter [2:0] s0 = 3'b000, s1 = 3'b001, s2 = 3'b010, s3 = 3'b011, s4 = 3'b100;</pre>                               |
|  |  | <pre>// define reg vars for state register and next_state logic<br/>reg [2:0] state, next_state;</pre>                                                                |
|  |  | //define state register (with asynchronous active-low clear)<br>always @(posedge clk or negedge clr)<br>                                                              |
|  |  | <pre>if (clr==0) state = s0;<br/>else state = next_state;<br/>end</pre>                                                                                               |
|  |  | // define combinational logic for next_state<br>always @(insig or state)<br>begin                                                                                     |
|  |  | <pre>case (state)     s0: if (insig) next_state = s1;         else next_state = s0;         s1: if (insig) next_state = s2;</pre>                                     |
|  |  | <pre>else next_state = s0;<br/>s2: if (insig) next_state = s3;<br/>else next_state = s0;</pre>                                                                        |
|  |  | <pre>s3: if (insig) next_state = s4;<br/>else next_state = s0;<br/>s4: if (insig) next_state = s4;<br/>else next state = s0;</pre>                                    |
|  |  | <pre>default: next_state = s0;<br/>endcase<br/>end</pre>                                                                                                              |
|  |  | <pre>// now set the saw4. This could also be done in an always // block but in that case, saw4 would have to be // defined as a reg. assign saw4 = state == s4;</pre> |
|  |  | endmodule                                                                                                                                                             |

![](_page_44_Figure_0.jpeg)

| Documented FSM                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| // Verilog HDL for "Ax", "see4" "behavioral"<br>// Four in a row detector - Allen Tanner                                                                                                                                                                           |
| <pre>module see4 (clk, clr, insig, saw4);<br/>input clk, clr, insig;<br/>output saw4;</pre>                                                                                                                                                                        |
| <pre>parameter [2:0] s0 = 3'b000; // initial state, saw at least 1 zero parameter [2:0] s1 = 3'b001; // saw 1 one parameter [2:0] s2 = 3'b010; // saw 2 ones parameter [2:0] s3 = 3'b011; // saw 3 ones parameter [2:0] s4 = 3'b100; // saw at least, 4 ones</pre> |
| reg [2:0] state, next_state;                                                                                                                                                                                                                                       |
| <pre>always @(posedge clk or posedge clr) // state register<br/>begin<br/>if (clr) state &lt;= s0;<br/>else state &lt;= next_state;<br/>end</pre>                                                                                                                  |
| <pre>always @(insig of state) // next state logic<br/>begin</pre>                                                                                                                                                                                                  |
| <pre>selse next_state = s0;<br/>s1: if (insig) next_state = s4;<br/>else next_state = s0;<br/>s1: if (insig) next_state = s4;<br/>else next_state = s0;<br/>s4: if (insig) next_state = s4;<br/>else next_state = s0;</pre>                                        |
| default: next_state = s0;<br>endcase<br>end                                                                                                                                                                                                                        |
| assign saw4 = state == s4;                                                                                                                                                                                                                                         |
| endmodule                                                                                                                                                                                                                                                          |

![](_page_45_Figure_0.jpeg)

![](_page_45_Figure_1.jpeg)

![](_page_46_Figure_0.jpeg)

| FSM 🗖                                                                                                                                                                                                                                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>// Verilog HDL for "Ax", "see4" "behavioral" // Four in a row detector - Allen Tanner</pre>                                                                                                                                                                   |
| <pre>module see4 (clk, clr, insig, saw4);<br/>input clk, clr, insig;<br/>output saw4;</pre>                                                                                                                                                                        |
| <pre>parameter [2:0] s0 = 3'b000; // initial state, saw at least 1 zero parameter [2:0] s1 = 3'b001; // saw 1 one parameter [2:0] s2 = 3'b010; // saw 2 ones parameter [2:0] s3 = 3'b011; // saw 3 ones parameter [2:0] s4 = 3'b100; // saw at least, 4 ones</pre> |
| reg [2:0] state;<br>wire [2:0] next_state;                                                                                                                                                                                                                         |
| assign next_state = {3{(state == s0) && !insig}} & s0<br>{3{(state == s0) && insig}} & s1<br>{3{(state == s1) && !insig}} & s0<br>{3{(state == s1) && insig}} & s2<br>{3{(state == s2) && !insig}} & s0                                                            |
| <pre>{3{(state == s2) &amp;&amp; insig}} &amp; s3 {3{(state == s3) &amp;&amp; !insig}} &amp; s0 {3{(state == s3) &amp;&amp; insig}} &amp; s4 {3{(state == s4) &amp;&amp; insig}} &amp; s0 {3{(state == s4) &amp;&amp; !insig}} &amp; s4</pre>                      |
| <pre>always @(posedge clk or posedge clr) // state register<br/>begin</pre>                                                                                                                                                                                        |
| assign saw4 = state == s4;<br>endmodule                                                                                                                                                                                                                            |

![](_page_47_Figure_0.jpeg)

| One-Hot FSM                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| // Verilog HDL for "Ax", "see4" "behavioral"<br>// Four in a row detector - Allen Tanner                                                                                                                                     |
| <pre>module see4 (clk, clr, insig, saw4);<br/>input clk, clr, insig;<br/>output saw4;</pre>                                                                                                                                  |
| reg s0; // initial state, saw at least 1 zero<br>reg s1; // saw 1 one<br>reg s2; // saw 2 ones<br>reg s4; // saw at least, 4 ones                                                                                            |
| <pre>always @(posedge clk or posedge clr) // state register<br/>begin<br/>if (clr)<br/>begin<br/>s0 &lt;= 1'b1;<br/>s1 &lt;= 1'b0;<br/>s3 &lt;= 1'b0;<br/>s3 &lt;= 1'b0;<br/>s4 &lt;= 1'b0;<br/>end<br/>else<br/>begin</pre> |
| assign saw $4 = s4;$                                                                                                                                                                                                         |
| endmodule                                                                                                                                                                                                                    |

| Or                     | ne-Ho                        | ot FSM    | Cou         | nting | ) 🗖                                                                                 |
|------------------------|------------------------------|-----------|-------------|-------|-------------------------------------------------------------------------------------|
| Baseline - 5 400       | 00005                        | TimeA - 0 |             |       |                                                                                     |
| Cursor-Baseline = -789 | ,000ps<br>Cursor ▼<br>0<br>1 |           | 2.000,000ps |       | Bas<br>TimeB = 5,610,40<br>[4,000,000ps 5,000,0<br>10000000000000000000000000000000 |
|                        | 1<br>0<br>0<br>0<br>0<br>0   |           |             |       |                                                                                     |
|                        |                              |           |             |       |                                                                                     |
|                        |                              |           |             |       |                                                                                     |

| Oops 🗖                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module see4 ( clk, clr, insig, saw4 );<br/>input clk, clr, insig;<br/>output saw4;<br/>wire s0, s1, s2, N2, N3, N4, N5, n9, n10, n11, n14, n15, n16, n17, n18,</pre>                                                                                                                                                                                                                                                                                                                  |
| <pre>DFF s1_reg ( .D(N2), .CLK(clk), .nCLR(n15), .Q(s1));<br/>DFF s1_reg ( .D(N2), .CLK(clk), .nCLR(n15), .Q(s1));<br/>DFF s4_reg ( .D(N5), .CLK(clk), .nCLR(n15), .Q(saw4), .QB(n9));<br/>DFF s3_reg ( .D(N4), .CLK(clk), .nCLR(n15), .QB(n10));<br/>TIELO U20 ( .Y(n11));<br/>INV U21 ( .A(clr), .Y(n15));<br/>AOI U22 ( .A(n16), .B(n17), .C(insig), .Y(n14));<br/>NOR2 U23 ( .A(s2), .B(s1), .Y(n17));<br/>NOR2 U24 ( .A(s0), .B(n18), .Y(n16));<br/>INV U25 ( .A(n19), .Y(N5));</pre> |
| <pre>NAND2 U27 ( .A(n9), .B(n10), .Y(n12));<br/>NAND2 U27 ( .A(n9), .B(n10), .Y(n12));<br/>INV U28 ( .A(n20), .Y(N4) );<br/>NAND2 U29 ( .A(insig), .B(s2), .Y(n20));<br/>INV U30 ( .A(n21), .Y(N3));<br/>NAND2 U31 ( .A(insig), .B(s1), .Y(n21));<br/>INV U32 ( .A(n22), .Y(N2));<br/>NAND2 U33 ( .A(insig), .B(s0), .Y(n22));<br/>endmodule</pre>                                                                                                                                         |

![](_page_49_Figure_0.jpeg)

| That's better                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>module see4 ( clk, clr, insig, saw4 );<br/>input clk, clr, insig;<br/>output saw4;<br/>wire ns0, N0, N1, N2, N4, N5, n1, n9, n10, n11, n12, n13, n14, n15;<br/>DFF s4_reg ( .D(N5), .CLK(clk), .nCLR(n1), .Q(saw4), .QB(n9) );<br/>DFF s3_reg ( .D(N2), .CLK(clk), .nCLR(n1), .QB(n12) );<br/>DFF s2_reg ( .D(N1), .CLK(clk), .nCLR(n1), .QB(n10) );<br/>DFF s1_reg ( .D(N0), .CLK(clk), .nCLR(n1), .QB(n11) );<br/>DFF ns0_reg ( .D(N4), .CLK(clk), .nCLR(n1), .Q(ns0) );<br/>INV U12 ( .A(clr), .Y(n1) );<br/>AOI U13 ( .A(n9), .B(n12), .C(n13), .Y(N5) );<br/>OAI U14 ( .A(n14), .B(n15), .C(n13), .Y(N4) );<br/>NAND2 U15 ( .A(ns0), .B(n12), .Y(n15) );<br/>NAND3 U16 ( .A(n10), .B(n9), .C(n11), .Y(n14) );<br/>NOR2 U17 ( .A(n13), .B(n11), .Y(N1) );<br/>NOR2 U19 ( .A(ns0), .B(n13), .Y(N0) );<br/>INV U20 ( .A(insig), .Y(n13) );<br/>endmodule</pre> |

![](_page_50_Figure_0.jpeg)

| Synchronous Clear                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>nodule see4 ( clk, clr, insig, saw4 );<br/>input clk, clr, insig;<br/>output saw4;<br/>wire N9, N10, N11, N12, N13, n2, n18, n19, n20, n21, n22, n23, n24, n25,</pre> |
| NAND2 055 ( .A(finsig), .B(h21), .Y(h27) );<br>INV U34 ( .A(clr), .Y(h21) );<br>endmodule                                                                                  |

![](_page_51_Figure_0.jpeg)

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ROM vs. Verilog                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| name rom<br>32 character<br>16 32 6<br>00 ;<br>00 ;<br>28 ; H<br>25 ; E<br>22 ; I<br>27 ; 0<br>37 ; W<br>2F ; 0<br>32 ; R<br>2C ; I<br>24 ; D<br>00 ;<br>00 | <pre>module mywords(addr, char);<br/>imput [4:0] addr;<br/>output reg [5:0] char;<br/>always @(addr)<br/>begin<br/>case(addr)<br/>'h00 : char = 'h00 ; //<br/>'h01 : char = 'h00 ; //<br/>'h02 : char = 'h25 ; // E<br/>'h04 : char = 'h25 ; // E<br/>'h04 : char = 'h25 ; // E<br/>'h04 : char = 'h27 ; // U<br/>'h05 : char = 'h27 ; // U<br/>'h08 : char = 'h27 ; // W<br/>'h08 : char = 'h27 ; // W<br/>'h08 : char = 'h22 ; // R<br/>'h08 : char = 'h24 ; // D<br/>'h08 : char = 'h00 ; //<br/>'h08 : char = 'h00 ; //</pre> |
| 00 ;<br>33 ; S<br>25 ; E<br>34 ; T<br>2D ; M<br>2D ; M<br>2D ; M<br>25 ; E<br>26 ; F<br>32 ; R<br>26 ; F<br>32 ; R<br>25 ; E<br>26 ; F<br>32 ; R<br>25 ; E<br>26 ; F<br>32 ; F<br>32 ; R<br>25 ; E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <pre>'hl0 : char = 'h00 ; //<br/>'hl1 : char = 'h00 ; //<br/>'hl2 : char = 'h03 ; // S<br/>'hl3 : char = 'h25 ; // E<br/>'hl4 : char = 'h34 ; // T<br/>'hl5 : char = 'h20 ; // M<br/>'hl6 : char = 'h20 ; // M<br/>'hl7 : char = 'h25 ; // E<br/>'hl8 : char = 'h26 ; // F<br/>'hl8 : char = 'h26 ; // F<br/>'hl8 : char = 'h25 ; // E<br/>'hl8 : char = 'h25 ; // E<br/>'hl10 : char = 'h25 ; // E<br/>'h10 : char = 'h00 ; //<br/>'h110 : char = 'h00 ; //<br/>'h110 : char = 'h00 ; //<br/>'h111 : char = 'h00 ; //</pre>                                    |

![](_page_52_Figure_0.jpeg)

![](_page_52_Picture_1.jpeg)

| ROM vs. Verilog |  |
|-----------------|--|
|                 |  |

![](_page_53_Picture_1.jpeg)

| ROM vs. Verilog 🔤                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>assign twist = {8{ nOE0}} &amp; ROW[ 7: 0]<br/>{8{ nOE3}} &amp; ROW[ 7: 0]<br/>{8{ nOE3}} &amp; ROW[ 32: 8]<br/>{8{ nOE24}} &amp; ROW[ 32: 16]<br/>{8{ nOE24}} &amp; ROW[ 31: 24]<br/>{8{ nOE25}} &amp; ROW[ 39: 32]<br/>{8{ nOE40}} &amp; ROW[ 47: 40]<br/>{8{ nOE56}} &amp; ROW[ 65: 56]<br/>{8{ nOE56}} &amp; ROW[ 65: 56]<br/>{8{ nOE56}} &amp; ROW[ 71: 64]<br/>{8{ nOE26}} &amp; ROW[ 72: 64]<br/>{8{ nOE26}} &amp; ROW[ 72: 96]<br/>{8{ nOE56}} &amp; ROW[ 73: 96]<br/>{8{ nOE56}} &amp; ROW[ 71: 26]<br/>{8{ nOE56}} &amp; ROW[ 71: 26]<br/>{8{ nOE56}} &amp; ROW[ 75: 88]<br/>{8{ nOE56}} &amp; ROW[ 71: 26]<br/>{8{ nOE56}} &amp; ROW[</pre> |
| <pre>  {8(moEl20}) &amp; Row[127:120]; assign T = {twist[0],twist[1],twist[2],twist[3],twist[4],twist[5],twist[6],twist[7]}; endmodule // charl0</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| ROM vs. Verilog |  |
|-----------------|--|
|                 |  |
|                 |  |