inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

[HDL 20장] Internal Memory Interface 에 대해 이해해보자 (FPGA 의 BRAM 을 이해하기 - 실습편)

true_dpbram.v 질문

해결된 질문

133

sgsong

작성한 질문수 1

1

안녕하세요

Verilog Season1 [HDL 20장] 실습 코드에서

true_dpbram 모듈의 input으로

reset_n 신호를 따로 넣어주지 않았는데

BRAM 메모리 값을 초기화할 필요가 없어서

reset_n 신호를 넣지 않으신 건지 궁금합니다!

 

verilog-hdl fpga 임베디드

답변 2

1

설계독학맛비

안녕하세요 🙂

AI 인턴이 잘 달아주었는데요.

FPGA 의 BRAM data sheet 를 보면, 별도의 reset 은 없습니다. (ASIC 은 SRAM)

BRAM 영역 전체를 초기화 하는 것은 비효율 적일 수 있고요. Power 소모와 초기화 로직이 필요함.

현업 설계에서는 전원을 키면 unknown 상태임을 가정하고 설계를 하고 있어요.

즉 전원을 키고 나서, 동일 address 를 Write 를 하고 난 이후에 Read 하면 write 했던 값이 의도했던 대로 read 가 되는데요.

만약 전원을 키고 나서, 동일 address 를 Write 없이 바로 Read 하면 unknown 이 읽힌다는 뜻입니다. 이는 100% 오동작입니다. (이걸 의도하고 설계하지는 않겠죠..?!!)

따라서 "BRAM 메모리 값을 초기화할 필요가 없어서 reset_n 신호를 넣지 않으신 건지 궁금합니다!"

"reset_n을 넣는다고 해서 BRAM 내부 데이터 전체가 자동으로 0으로 클리어되지는 않아요. 대부분의 FPGA BRAM은 전원 인가 시 undefined 상태이며, reset 신호와 무관하게 별도의 초기화 동작이 필요합니다. 필요하다면 이 초기화 동작은 (방법은 여러가지가 있겠지만) 설계자가 직접 Write 를 해주시면 되겠죠?!"

즐공하세요!

1

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

sgk님께서 질문하신 true_dpbram 모듈의 reset_n 신호와 BRAM 초기화에 대한 질문에 대해 비슷한 질문과 답변을 참고하여 내용을 드리겠습니다. 해당 모듈에서 reset_n 신호가 포함되지 않은 이유는 주로 BRAM 자체의 특성 때문입니다. BRAM은 전력 손실 이후에도 데이터가 보존될 수 있도록 설계되었기 때문에, 일반적으로 별도의 외부 초기화가 필요하지 않으며, FPGA의 경우 전원을 끄거나 새롭게 프로그래밍 할 때마다 초기 상태가 설정됩니다. 따라서, 특정 작업 흐름에서 데이터 초기화가 필요한 경우 Verilog 코드 내에서 별도로 초기화 로직을 추가할 수 있지만, 대부분의 경우에 그렇지 않고도 설계가 가능합니다.

다음은 해당 주제와 관련된 유사한 질문과 답변 링크입니다. 질문자님께서 이 답변들을 통해 BRAM의 초기화 여부 및 reset_n 신호의 역할을 더 깊이 이해하는 데 도움이 될 것입니다:

이 링크들은 관련 논의와 BRAM의 사용 사례를 이해하는 데 유용한 리소스가 될 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

latency 개념 구현

1

80

3

비바도 all os버전

1

65

2

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

1

66

2

다운로드용량

1

67

2

비바도리눅스설치

1

78

2

전체path복사넣기

1

58

2

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

1

141

2

explorer.exe오류

1

96

3

mobaxterm설치오류

1

83

2

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

1

50

2

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

1

120

2

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

0

56

1

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

1

59

3

16장 mealy 설계.

1

70

2

14장 Cycle 관련, Testbench 코드.

1

62

2

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

1

58

1

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

1

62

2

build에러 질문

0

53

2

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

1

69

2

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

1

103

2

5장 DFF특성에 대한 질문

1

71

3

vivado linux 사용 이유.

1

131

2

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

1

100

2

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

1

89

2