일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 파이썬
- 나르왈프레오
- 패턴인식
- SSM
- Friendship
- 삼성
- Neural Network
- Bidirectional Associative Memory
- 동아리
- 신경회로망
- BAM
- Google App Engine
- 패턴 인식
- 물걸레자동세척로봇청소기
- 빅데이터
- 구글 앱 엔진
- NarwalFreo
- 물걸레로봇청소기추천
- 멤버십
- hopfield network
- 신경망
- 가상화
- 삼성소프트웨어멤버십
- 고려대학교
- 하이퍼바이저
- 삼성전자 소프트웨어멤버십 SSM
- 갤럭시탭S8울트라
- 인공지능
- Python
- 증강현실
- Today
- Total
정보공간_1
[3기 전주 전환규] Design Compiler를 이용한 Synthesis 본문
[3기 전주 전환규] Design Compiler를 이용한 Synthesis
알 수 없는 사용자 2013. 3. 2. 19:58안녕하세요 전주멤버십 22-1기 전환규 회원입니다.
오늘은 지난 달에 이어 Design Compiler를 이용하여 Verilog Source를 합성하는
과정을 살펴보도록 하겠습니다.
1. .sysnopsys_dc.setup
Design Compiler를 사용하기 전에 우선 .sysnopsys_dc.setup 파일의 설정을 수정해야 합니다.
자신이 사용하는 라이브러리의 경로와 타겟 라이브러리를 설정해줘야 합니다. Chip 설계 과정중에 3가지
라이브러리 중에 worst로 합성을 해야 가장 악 조건을 고려 할 수 있습니다.
[그림 1] .sysnopsys_dc.setup
.sysnopsys_dc.setup |
# vi .sysnopsys_dc.setup [vi editor] //------------------------------------------------------------------------------------------- set search_path "$search_path /target_worst_library_Path \ /target_RAM_worst_library_Path ./" set target_library "target_worst_library.db" set link_library " * $target_library target_RAM_worst_library.db" set symbol_library "target_library_veri.sdb" |
위와 같이 설정하고 저장하면 됩니다.
2. Design Compiler
Design Compiler를 이용하여 컴파일 하는 과정은 다음과 같습니다.
# source syn.cshrc # dc_shell-xg-t # read_verilog LAB.v # current_design -multiple_design # link # compile (or compile_ultra) |
일반 compile 명령어 보다 라이센스가 있다면 compile_ultra 명령어를 추천한다. Design Compiler를
이용하여 Synthesis를 마치면 작성했던 Verilog Source가 gate model로 변화된걸 확인 할 수 있다.
[그림 2] Synthesis 결과
Synthesis를 하고 나면 파일이름.sdc 파일이 생성된 것을 확인 할 수 있다. 이 파일은 후에 Place and Route
과정에서 필요하니 꼭 보관하도록 하자.
3. Design Vision
Design Vision은 Synthesis 과정을 눈으로 직접 확인할 수 있는 툴입니다. 간단한 과정으로 살펴 보도록 하겠습니다.
# source syn.cshrc [Design Compiler]
# design_vision
[그림 3] Design Vision
그림 2는 Design Vision을 실행한 화면 입니다.
[그림 4] Read Verilog
a. File - Read [Click] b. Lab.v - Open [Click] |
그림 4 는 Verilog 파일을 읽어 오는 과정을 간략하게 보여주는 예입니다. Lab.v는 제가 상용한 Verilog 파일 입니다.
[그림 5] Schematic & Symbol
Design Vision은 작성된 Verilog Source를 Symbol 형태로 확인 할 수 있다. 그림 5는 필자가 작성했던
Verilog Source이다. 이 후 과정은 위와 마찬가지로 다음과 같이 입력하면 됩니다.
design_vision-xg-t > current_design LAB design_vision-xg-t > check_design -multiple_design a. File - Link Design [Click] b. Design - Compile Design...[Click] |
[그림 6] Synthesis
그림 6은 Design Vision을 이용하여 Synthesis 과정이다. Shell 환경과 다르게 Design Vision은 결과를
직접 눈으로 확인 할 수 있습니다. 각 모듈의 내부 구조 또한 확인 할 수 있습니다.
지금까지 Design Compiler를 이용하여 Synthesis 한 결과를 살펴보았다. Verilog 작성부터 Design Compiler
를 이용하여 자신이 설계한 Chip의 타이밍 및 결과가 정확히 일치하지 않을 경우에는 gate 교체를 하면 됩니다.
만약 gate를 교체하여도 타이밍이 정확히 일치 하지 않을 시에는 Verilog를 다시 수정하여 작성해야 합니다.
'IT 놀이터 > Elite Member Tech & Talk' 카테고리의 다른 글
[3기 대전 김재원] Linux Kernel Debugging - Dynamic Probes(3) (0) | 2013.03.05 |
---|---|
[3기 강북 김승현] ffmpeg 를 이용한 간단한 동영상 플레이어 제작 #1 (0) | 2013.03.05 |
[3기 강남 정준호] MP-Core Scheduling (0) | 2013.02.06 |
[3기 강남 정준호] SMP Struct와 Multi-core System (0) | 2013.02.06 |
[3기 강북 김승현] Android Heap Memory 관리 (0) | 2013.02.06 |