I am trying to implement a 8-bit counter that does both BCD(Binary Code decimal) and gray code sequence. If the input control = 0, the circuit will count in BCD and if the input control = 1, the circuit will count in gray code sequence. Here is my implementation:
module grayBCDcounter(
input clk, control,
output reg [2:0] y1,
);
reg [2:0] state // there will be 8 states: 1st state :000
// 2nd state: 001, 3rd state: 010 and so on
// my last state will be 111
parameter s0=3'b000, s1=3'b001, s2=3'b010, s3=3'b011,
s4=3'b100, s5=3'b101, s6=3'b110, s7=3'b111;
always @ (posedge clk)
begin
case(state)
s0: state <= s0;
s1: state <= s1;
s2: if (control == 0)
begin
state <= s2;
end
else if(control ==1)
begin
state <= s3;
end
s3: // and so on
endcase
end
always @ (posedge clk)
begin
if (state == s0)
begin
y1 <= 0;
end
else if(state == s1)
begin
y1 <= 1;
end
else if // so on
end
end
endmodule
When control variable is 0, I want to execute s0,s1,s2,s3,s4,s5, and so on as you can see(BCD), and when control variable is 1, I want to execute s0,s1,s3,s2,s6,s7,s5,s4 respectively (gray code)
When I run a test cases on it, it somehow only prints s0 and seems to be constant throughout the execution. My guess is that the state never goes off from s0.
Any tips on how I should implement the codes?
Best Answer
I think you don't use FSM, instead make simple code like bellow,
Try it.