





















| UAH                                                               | Chapter 5                                 |       | <b>CPE/EE 422/52</b> |  |  |
|-------------------------------------------------------------------|-------------------------------------------|-------|----------------------|--|--|
| 5.2 Derivation of SM Charts -<br>VHDL for Binary Multiplier       |                                           |       |                      |  |  |
| entity Mult is<br>port(CLK,St,K,M: in<br>Load,Sh,Ad,<br>end mult; | n bit;<br>Done: out bit);                 |       |                      |  |  |
| architecture SMbehave<br>signal State, Nextst<br>begin            | of Mult is<br>cate: integer range 0 t     | to 3; |                      |  |  |
| process(St, K, M, St<br>change                                    | ate)                                      | start | if state or inputs   |  |  |
| begin<br>Load <= '0'; Sh <=<br>case State is                      | = '0'; Ad <= '0';                         |       |                      |  |  |
| when 0 => if St<br>Loa<br>Nex                                     | = '1' then<br>ad <= '1';<br>xtstate <= 1; | St    | (state 0)            |  |  |
| else<br>end i                                                     | <pre>Nextstate &lt;= 0; f;</pre>          | St'   |                      |  |  |
|                                                                   |                                           |       | Page 12              |  |  |















| UAH                                                                                           | Chapter 5                                                                                                                               | <b>CPE/EE 422/522</b>             |  |  |  |
|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|--|--|--|
| Electronic Dice Game<br>Behavioral VHDL Model                                                 |                                                                                                                                         |                                   |  |  |  |
| entity DiceGame is<br>port (Rb, Reset, C<br>Sum: in inte<br>Roll, Win, I<br>end DiceGame;     | CLK: in bit;<br>gger range 2 to 12;<br>Lose: out bit);                                                                                  |                                   |  |  |  |
| architecture DiceBeha<br>signal State, Next<br>signal Point: inte<br>signal Sp: bit;<br>begin | ave of DiceGame is<br>state: integer range 0 to 5;<br>eger range 2 to 12;                                                               |                                   |  |  |  |
| process(Rb, Reset<br>begin<br>Sp <= '0'; Roll<br>case State is<br>when 0 => if                | , Sum, State)<br>L <= '0'; Win <= '0'; Lose <=<br>Rb = '1' then Nextstate <= 1                                                          | - '0';<br>; end if;               |  |  |  |
| when 1 =><br>if Rb = '1<br>elsif Sur<br>elsif Sur<br>else Sp o<br>end if;                     | <pre>' then Roll &lt;= '1';<br/>n = 7 or Sum = 11 then Nextst<br/>n = 2 or Sum = 3 or Sum =12 t<br/>&lt;= '1'; Nextstate &lt;= 4;</pre> | ate <= 2;<br>Chen Nextstate <= 3; |  |  |  |
| when 2 => Win<br>if Reset =                                                                   | n <= '1';<br>'1' then Nextstate <= 0; end                                                                                               | l if; Page 20 of 2                |  |  |  |







| UAH                                                                                                                                                                                                                                                       | Chapter 5                                                                                                         | <b>CPE/EE 422/522</b> |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-----------------------|--|--|
| Dice Game Test Module VHDL                                                                                                                                                                                                                                |                                                                                                                   |                       |  |  |
| <pre>when 1 =&gt; Rb<br/>when 2 =&gt; Thu<br/>Trig1 &lt;=<br/>if (Win<br/>Reset<br/>end if;<br/>when 3 =&gt; nu<br/>end case;<br/>process(CLK)<br/>begin<br/>if CLK = '1' then<br/>Tstate &lt;= Then<br/>end if;<br/>end process;<br/>end dicetest;</pre> | <= '0'; Tnext <= 2;<br>ext <= 0;<br>not Trigl; toggle Trig:<br>or Lose) = '1' then<br>c <= '1';<br>ll; Stop state | 1                     |  |  |
|                                                                                                                                                                                                                                                           |                                                                                                                   | Page 24 of            |  |  |

