인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

5 ciotlab님의 프로필 이미지
5 ciotlab

작성한 질문수

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

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

메모리 인터페이스 timing diagram

작성

·

30

1

안녕하세요 🙂

[1. 질문 챕터] : eg) 몇 장, 몇 분 몇 초 쯤. or 수강생 분들이 봤을 때 어디구나?! 할 수 있게 표기 부탁 드려요.

[2. 질문 내용] : eg) 질문 내용을 자유롭게 작성해주시면 되겠습니다 🙂

[3. 시도했던 내용, 그렇게 생각하는 이유] : eg) 설치영상은 이렇게 시도했는데 안되더라 or 본인의 생각을 적어주세요. (실습 내용 중에 이해가 안되거나 잘못된 내용이 있는데, 이러 이러한 근거로 나는 이렇게 생각합니다.)

 

================ 다음 내용은 읽어보시고 지우시면 됩니다.=================

질문 내용을 작성해주실 때, 위의 3단계로 제가 이해할 수 있게 작성해주시면 정확한 답변을 드릴 수 있을 것 같아요!!

현업자인지라 업무때문에 답변이 늦을 수 있습니다. (길어도 만 3일 안에는 꼭 답변드리려고 노력중입니다 ㅠㅠ)

  1. 강의에서 다룬 내용들의 질문들을 부탁드립니다!! (설치과정, 강의내용을 듣고 이해가 안되었던 부분들, 강의의 오류 등등)

  2. 이런 질문은 부담스러워요.. (답변거부해도 양해 부탁드려요)

    1. 개인 과제, 강의에서 다루지 않은 내용들의 궁금증 해소, 영상과 다른 접근방법 후 디버깅 요청, 고민 상담 등..

  3. 글쓰기 에티튜드를 지켜주세요 (저 포함, 다른 수강생 분들이 함께보는 공간입니다.)

    1. 서로 예의를 지키며 존중하는 문화를 만들어가요.

    2. 질문글을 보고 내용을 이해할 수 있도록 남겨주시면 답변에 큰 도움이 될 것 같아요. (상세히 작성하면 더 좋아요! )

  4. 먼저 유사한 질문이 있었는지 검색해보세요.

  5. 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

==================

 

안녕하세요. 19장에 9분 정도에 timing diagram에 궁금한 점이 생겨서 질문 드립니다.

제가 이해하기로는 Dout 이 Read operation 중일 때 read하고자 하는 어떤 address의 data 값이 Dout에 출력되는 것으로 이해했는데, 영상의 timing diagram 상에는 WE=1, 즉 writing operation 중일 때도 Din의 write하고 싶은 data값이 Dout에 출력되는 것 처럼 보여서요.

Dout 은 read operation일 때 read 하고자 하는 주소의 data값만 출력되는 포트 아닌가요?

제가 잘못 이해한 것이라면, Dout은 read, write operation 상관 없이 그 당시 가리키는 주소에 해당하는 data값이 출력되는 것일까요..??

 

감사합니다!

답변 2

0

설계독학맛비님의 프로필 이미지
설계독학맛비
지식공유자

안녕하세요 🙂

Single port ram 의 경우 R/W 는 동시에 처리할 수 없습니다.

따라서 WE = 1 (write) 동작일때는 ADDRA 와 Dout 은 Write 용으로 사용됩니다.

파형을 보시면, 순서상 "WEA + DIN + ADDRA" -> DOUT 형태로 파형이 그려진 것으로 이해가 됩니다.

즐공하세요 🙂

5 ciotlab님의 프로필 이미지
5 ciotlab
질문자

그럼 Dout은 read operation일 때만 그 주소의 data가 출력되는 포트가 아니라,

read, write 모든 operation 상황에 해당하는 주소의 data값이 출력되는 포트라고 생각하면 될까요?

설계독학맛비님의 프로필 이미지
설계독학맛비
지식공유자

네, 현재 보고계신 Xilinx 계열의 FPGA BRAM timing diagram 은 ADDR 에 종속되어 data 가 출력되는 것으로 보여집니다.

여기서 모든 RAM 이 그러냐? 의 답은 아니라고 답변드리고 싶어요.

사용하시려는 target RAM 의 data sheet 를 꼭 확인 해주시고 사용 부탁드릴께요.

오해를 방지하고자, WE=1 일때의 Dout 을 쓸 것인가 의 문제는

처음 알고계신 내용처럼, RAM 의 Dout 은 Read 일때 사용하는 것이 옳습니다. WE=1 의 Dout 을 사용하진 않아요. write 를 할때, Din 의 출력을 사용할 수 있는 상황인데, Dout 의 출력을 사용할 이유는 없으니까요.

즐공하세요 🙂

0

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

메모리 인터페이스에서 데이터 경로와 동작에 대한 이해가 정말 중요합니다. 특히 timing diagram을 분석할 때 헷갈릴 수 있는 부분이 많아 질문을 주시는 경우가 많습니다. 해당 내용에 대한 답변과 관련 자료를 제공해드릴게요.

Dout에 데이터가 출력된다는 것은 보통 read operation이 수행될 때 해당 주소의 데이터 값이 출력된다는 의미로 해석됩니다. 그러나 여러 아키텍처나 설계에 따라 때로는 write 중에도 버퍼 처리 등으로 인해 해당 주소의 데이터가 보이는 것처럼 동작할 수도 있습니다.

참조할 관련 답변

  1. 19장 write first mode example 질문입니다
    • 이 질문에서도 메모리 동작 시 read와 write 시의 DOUTA 값에 대한 혼란이 있었는데, 동기화된 동작지연(delay)을 상황별로 다룹니다.

서로 다른 동작의 기본 원리에 따라, 설계 및 실습 환경에서 다르게 보일 수 있습니다. 어떤 환경에서는 데이터가 즉시 반영되지 않고, 지연 후에 나타날 수 있습니다. 이 경우, 모의 실습 환경이 동기 작동을 시뮬레이션하면서도 실제와 다른 타이밍을 보여줄 수 있음에 유의해야 합니다.


저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

5 ciotlab님의 프로필 이미지
5 ciotlab

작성한 질문수

질문하기