Download presentation
Presentation is loading. Please wait.
1
State Machine Design with an HDL
A methodology that works for documenting the design, simulation and verification of the design, and synthesis for FPGA, or a custom ASIC generated using synthesis. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
2
Copyright 2006 - Joanne DeGroat, ECE, OSU
Lecture overview State machine basics HDL methodology State machine example 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
3
Copyright 2006 - Joanne DeGroat, ECE, OSU
State Machine Basics In basic digital designs there are two fundamental ways that state machines are implemented Mealy Machine Outputs are a function of the current state and the inputs 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
4
Copyright 2006 - Joanne DeGroat, ECE, OSU
State Machine Basics Moore Machine Outputs are a function of the current state only 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
5
Copyright 2006 - Joanne DeGroat, ECE, OSU
HDL code Coding a state machine in an HDL Can simply implement an algorithm Documents poorly Cannot be synthesized Can code for a Mealy or Moore machine in a single process Synthesis results are unpredictable Can follow a structured style Documents very well Synthesizes very well and predictable Simulation of the three possibilities is ~ the same 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
6
Copyright 2006 - Joanne DeGroat, ECE, OSU
The coding style The style applies to any HDL – VHDL, Verilog, System C Documents well Easily maintainable – excellent during development as changes are easily made Style maps to physical logic – using this style can predict the number of state elements that should be produced by systhesis All three styles on the last slide simulate equally well, but this style also synthesizes well. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
7
Copyright 2006 - Joanne DeGroat, ECE, OSU
Style guide Use a process to describe the next state logic. Often in the form of a case statement. Will see this in the example. Use a process to representing the latching/loading of the calculated next_state such that it becomes the current_state. This is the only process that generate sequential elements (F/Fs). The other processes represent combinational logic. Use a third process to represent the generation of the outputs. This process will have inputs of the current state and, depending on the type of state machine, the inputs. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
8
Copyright 2006 - Joanne DeGroat, ECE, OSU
An example The T-Bird tail light problem The turn signal indicator had a light sequence on each lamp. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
9
State machine description
State Diagram and Transition table Output is associated with state 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
10
Copyright 2006 - Joanne DeGroat, ECE, OSU
Design with HDL You still start with a state diagram You may or may not generate a transition table Will now look at the code Where to start – THE INTERFACE What are the inputs and the outputs? 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
11
Copyright 2006 - Joanne DeGroat, ECE, OSU
The Entity Inputs are a signal for Right turn signal Left turn signal Hazard Clock Outputs are the signals for the lights lc, lb, la rc, rb, ra 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
12
Copyright 2006 - Joanne DeGroat, ECE, OSU
The Entity Inputs are a signal for Right turn signal Left turn signal Hazard Clock Outputs are the signals for the lights lc, lb, la rc, rb, ra 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
13
Copyright 2006 - Joanne DeGroat, ECE, OSU
The architecture Will use 3 processes Start of architecture and the process to specify the F/Fs is given here. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
14
Notes on start of architecture
Signal declaration for the state machine state First declare and enumeration type that has an element for each state of the state machine Here- idle, l1,l2,l3, r1,r2,r3, lr3 Then declare signals state and next_state to be of this type. An aside: you can count the number of elements in this type to see that number of states and predict the number of F/Fs the state machine requires. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
15
Copyright 2006 - Joanne DeGroat, ECE, OSU
The F/F process Have a process that specifies latching the next_state into the signal state. This process will synthesize into F/Fs Process specifies that this happens on the clock edge. Note that state and next_state have an initial state of idle. Process will hold waiting for an edge on the clock signal clk 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
16
Copyright 2006 - Joanne DeGroat, ECE, OSU
The next state process The second of the processes for the state machine. What is the next state given the current state and the state of the input signals Process can be of considerable size Continued on next slide 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
17
Copyright 2006 - Joanne DeGroat, ECE, OSU
The next state process Continued Note that a case is used to switch to actions based on the current_state Then the value of the inputs directs the next_state for the state machine 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
18
Copyright 2006 - Joanne DeGroat, ECE, OSU
The output process Use a separate process to specify the outputs In this case there is a specific set of outputs for each state. The outputs are only dependent on the state which makes this a Moore Machine 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
19
Once you have state machine description
Simulate it in a test suite to verify the design meets specifications. This is the HDL topic of verification (ECE 764 – even years and a terminal grad course) Then can synthesize the design to generate an FPGA implementation or use standard cells and generate the standard cells which can be sent to a place and route program for automatic generation of the circuit for a custom IC. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
20
Copyright 2006 - Joanne DeGroat, ECE, OSU
If this is done What would you expect How many F/Fs??? In this case you would expect 3 FFs. Why? There are 8 states You could even ballpark the number of gates, but that is a bit much. 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
21
Copyright 2006 - Joanne DeGroat, ECE, OSU
The synthesis result Note the number of F/Fs 1/8/ L20 Project Step 8 - Data Path Copyright Joanne DeGroat, ECE, OSU
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.