inflearn logo
강의

講義

知識共有

Basic SystemVerilog Testbench(回路設計検証)

SystemVerilog テストベンチ構造の確認

sv에서 class에 대한 질문입니다.

解決済みの質問

63

rlaalswo8132670

投稿した質問数 3

1

image.png

이 부분에서 class는 tb의 하위블록처럼 취급이 되는 것인가요?

아니면 일반 C++의 클래스처럼 생각하면 되는 것인가요?

verilog-hdl system-verilog verification system-verilog-dpi

回答 1

1

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 김민재님.

SystemVerilog에서는 class를 사용하여 testbench를 구성하는 경우가 많습니다. 이는 객체 지향 프로그래밍(OOP) 개념을 활용하여 testbench의 모듈성을 높이고 재사용성을 강화하기 위한 것입니다.

  1. Testbench의 하위 블록:

    • SystemVerilog에서 class는 보통 testbench의 특정 기능적 요소를 캡슐화하는 데 사용됩니다. 예를 들어, 테스트 데이터를 생성하는 generator, 읽고 쓰는 readerwriter, 그리고 결과를 검증하는 scoreboard 등이 클래스로 구현될 수 있습니다.
    • 이들은 testbench의 하위 구성 요소로 볼 수 있으며, 각각의 클래스는 특정한 역할을 수행합니다.
  2. 일반 C++의 클래스와의 비교:

    • SystemVerilog의 클래스는 C++의 클래스와 유사한 객체 지향 개념을 따릅니다. 여기에는 상속, 다형성, 캡슐화 등의 OOP 개념이 포함됩니다.
    • 다만, SystemVerilog의 클래스는 주로 하드웨어 설계를 위한 시뮬레이션 환경에서 사용되므로, C++과는 다른 특화된 메서드나 데이터 타입을 포함할 수 있습니다.

이미지에서 보이는 구조를 통해 추측할 수 있듯이, test.svenvironment.sv 파일에 각각의 클래스들이 정의되어 있으며, 이들이 어떻게 testbench 내에서 data_fifo 모듈을 검증하기 위한 여러 역할을 수행하는지 살펴보실 수 있습니다.

추가적인 이해를 돕기 위해 클래스 개념 설명을 확인해 보실 수 있습니다. 유사한 자료를 통해 SystemVerilog 클래스에 대한 이해를 확장하실 수 있을 것입니다.

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

1

MetaEncore

김민재 님,

위의 AI 인턴 답변 설명에 혹시 더 질문이 있으실까요?

0

rlaalswo8132670

넵 질문 그대로 입니다. 하위 블록이라 할 수 있는지 궁금합니다.

먼저 기초적인 질문을 드리자면

image.png

위 사진에서 test.sv와 class test는 같은 것인지가 궁금합니다.

.sv 파일 안에 class만 만들어도 되는지 궁금해서 여쭤봅니다.

1

MetaEncore

김민재 님,

네, 보통 현업에서 사용할 때는 class 작성을 하고 그것을 하나의 파일로 만들어서 사용합니다.

위의 예에서 test.sv file 에 test class 만 기술하고 저장해서 사용합니다.

그리고 원 질문에서 말씀하신 사항은

test 가 tb 의 하위 블럭이라고 하는 이야기는 보통 하지 않습니다.

test 가 class 이기 때문에 dynamic object 로서 module 에서의 블럭과 유사한 역할을 하기는 합니다만, simulation 중에 construct 해서 사용하는 object 이고, module 을 instance 하지 못하고, 입출력을 사용하지 않기 때문에 하위 블럭이라기 보다는 그냥 object 라고 이야기 합니다.

답변이 되었을까요? 제가 설명이 부족하다면 더 질문해 주셔도 됩니다.

1

MetaEncore

김민재 님,

질문이 해결 되었다면, "해결" 버튼 부탁 드립니다.

[HDL 32장-2부] 참고 링크 관련

1

36

2

강의 만료일 연장 신청

0

34

2

기초예제 파일 불러오기 문의

0

26

2

Zybo 환경에서 PL RTL UART 보드 검증 방법

0

31

2

혹시 별도의 자료가 있나요?

0

34

2

queue assignment pattern 문의 건

0

33

1

Mission 5 문의 건

0

46

2

Zynq z7 FPGA single-ended 관련

0

40

1

강의자료 PDF 어떻게받나요?

0

43

2

강의 ppt 자료 요청건

0

57

2

미션tree

0

41

3

강의7 질문

0

47

2

mission1 질문

0

60

3

Verilog Testbench DB 원본

0

50

1

Inline constraints 관련 질문

0

45

1

SystemVerilog Interface - 1에서 modport 관련 질문

0

61

1

FIFO read sequence waveform 관련 문의

0

85

2

EDAPlayground에서 코드 찾기

0

82

2

섹션 3. 20 DPI 이해하기 에서 DPI-C : Compile and Debug 부분 질문 입니다.

1

115

2

미션 3 로그 결과 문의

0

80

2

영상이 이상합니다.

0

80

1

'fork-join_none'으로 시작된 백그라운드 스레드의 종료는 어떻게 관리되나요?

0

70

1

SystemVerilog 내 program 이 top module 의 역할을 하는건가요?

2

122

2

강의문의

1

89

1