inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

설계독학맛비's 실전 Verilog HDL Season 1 (Clock부터 Internal Memory까지)

[HDL 16장] HW 의 동작을 제어하는 FSM 을 이해해보자. (실습편)

16장 FSM 강의 Code 질문

해결된 질문

527

박찬용

작성한 질문수 6

2

module FSM(
	input clk,
	input rst_n,
	input i_run,
	output reg o_done
);
reg[1:0] state; //00:IDLE, 01:RUN, 10:DONE, 11:None
wire is_done;

always@(posedge clk or negedge rst_n) begin

case(state)

2'b00 : // IDLE 
begin if (rst_n == 1 && i_run == 1)
state <= 01;
else
state <= 00;
end

2'b01 : // Run
begin if (!rst_n)
state <= 00;
else if (rst_n == 1 && is_done == 1)
state <= 10;
else
state <= 01;
end

2'b10 : // Done
begin
state <= 00;
end

dafault : //Deafalt
begin
state <=00;
end

endcase

end

endmodule

보이는 그대로 FSM을 state를 case로 나눠서 기술해봤는데, 혹시 위와 같은 방식으로 설계하면 문제 없을까요?

verilog-hdl 임베디드 fpga 임베디드

답변 1

0

설계독학맛비

안녕하세요 :)

(개인코드는 양해 부탁드립니다. https://www.inflearn.com/news/312949)

개인의 차이일 수 있습니다. 올려주신 코딩 스타일이 제 생각에는 가독성이 좋아보이지는 않네요.

돌려보시고 Function 에 문제가 없다면, 그렇게 하셔도 됩니다.

즐공하세요 :)

latency 개념 구현

1

90

3

비바도 all os버전

1

76

2

초기화를 reset_n 이 '1'일 때가 아닌 '0' 일 때 실행시키는 이유 질문

1

75

2

다운로드용량

1

74

2

비바도리눅스설치

1

83

2

전체path복사넣기

1

63

2

Vivado 2025.2 리눅스 설치 후 실행 에러와 솔루션 (libxv_commontasks.so)

1

154

2

explorer.exe오류

1

107

3

mobaxterm설치오류

1

92

2

./build시, waveform 'divide color' 사용

1

57

2

Latch와 관련하여 (Time borrowing, Latch-based design)

1

134

2

clean 명령어가 안되는데, 따로 저장해줘야 하는지 궁금합니다.

0

64

1

안녕하세요 설치 관련 질문 드립니다.

1

65

3

16장 mealy 설계.

1

74

2

14장 Cycle 관련, Testbench 코드.

1

64

2

21강(16장) 초기값 설정이 적용되는 시점 질문

1

60

1

20강(15장) - 밀리 머신 관련하여 질문 드립니다.

1

69

2

build에러 질문

0

58

2

1장 ./build에서 에러가 나요

1

74

2

FPGA 강의 보드 문의 드립니다.

1

110

2

5장 DFF특성에 대한 질문

1

77

3

vivado linux 사용 이유.

1

139

2

메모리의 형태가 전체설계에 미치는 영향이 궁금합니다.

1

105

2

디스코드 멤버쉽 등업 관련 문제

1

92

2