Continue to Site

Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

[SOLVED] FSM output function of the encoded states

Status
Not open for further replies.

carmeloA

Junior Member level 1
Junior Member level 1
Joined
Jul 17, 2017
Messages
19
Helped
1
Reputation
2
Reaction score
1
Trophy points
3
Activity points
188
Hi to all,
I want to build a simple FSM in vhdl where the output is the same of the state encoding of the FSM.
I want this behaviour because I want to change the state encoding at every syntesis (with the command set_fsm_encoding in DC) and make some consideration.
For example, given a simple state machine:

Code:
TYPE states IS (state1,state2 ... state8); 
  SIGNAL current_state, next_state        : states; 

BEGIN

   current_state_update: process(clk, reset)
	begin
		if reset='1' then 
			current_state<=state1;
		elsif (clk'event and clk='1') then
			current_state<=next_state;
		end if;
	end process current_state_update;

   next_state_up : process(current_state)
	begin
		case current_state is
			when state1=> next_state<=state2;
			when state2=> next_state<=state3;
			....
			when state8=> next_state<=state1;
		end case;
	end process next_state_up;

   output_gen: process(current_state)
	begin
		case current_state is
			when state1=> output<="000";
			when state2=> output<="001";
			....
			when state8=> output<="111";
			when others=> output<="000";
		end case;
	end process output_gen;

In this example, the output is fixed 000 when state 1 etc; what i want instead, is that the signal "output" is always the state encoding that design vision gives to the fsm.


I'd like to ask if anyone could give me any tips to achive my goal.
Thank you so much
 

Code:
TYPE states IS (state1,state2 ... state8); 
  SIGNAL current_state, next_state        : states; 

BEGIN

   output_gen: process(current_state)
	begin
		case current_state is
			when state1=> output<="000";
			when state2=> output<="001";
			....
			when state8=> output<="111";
			when others=> output<="000";
		end case;
	end process output_gen;

You need to declare output as state TYPE. And then simply assign the current_state to output. You don't need the output_gen process.

You can create a pkg, where you can define the state TYPE. And then import this pkg to declare output and current_state, next_state of state type.
 
I manage to solve my problem with the method you have proposed! :-D
actually it was so simple but i hadn't even thought this solution, maybe because i was so involved in the vhdl that i was focused in many different code configuration! :bang:
Thank you so much!
 

Status
Not open for further replies.

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top