# 8주차 실습

FPGA 보드 사용법



## 실습

- ① A,B 의 입력에 AND, OR, XOR 게이트를 실험하는 예제
  - X,Y,Z 의 출력은 각각 LED 1,2,3을 컨트롤 할 수 있음
  - 해당 회로에 대한 시뮬레이션까지 확인 하기





- ① Xilinx\_ISE\_S6\_Win10\_14.7\_ISE\_VMs\_0206\_1.zip 압축 풀기
- ② xsetup.exe 파일 실행
- ③ Select the directory to share with VM 부분에 VM과 연동할 폴더 지정
- ④ Next 눌러서 설치 진행



① ISE 실행하여 ISE 프로그램의 File > New Project 메뉴를 선택



#### ① 다음과 같이 프로젝트 설정을 한다



Name : 프로젝트이름

Location : 원하는 위치

Working Directory : 원하는 위치

Top-level source type: HDL



Device Family: Spartan-6

Device: XC6SLX45 Package: FGG484

Speed: -3

Simulator: ISim(VHDL/Verilog)



#### ① 플로리안에서 생성한 Verilog 파일 불러오기







## 참고

① 시뮬레이션 할 모듈에 적용된 .v파일 모두 불러오기 (PNULib의 .v파일은 기본적으로 모두 들고오기)

| PC > 로컬 디스크 (C:) > project |             |              |             |  |  |
|----------------------------|-------------|--------------|-------------|--|--|
| PNU_AND2.v                 | PNU_AND3.v  | PNU_AND4.v   | PNU_AND8.v  |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 212바이트                     | 225바이트      | 238바이트       | 290바이트      |  |  |
| PNU_BUF.v                  | PNU_DFF.v   | PNU_DFF_Ce.v | PNU_JKFF.v  |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 196바이트                     | 373바이트      | 437바이트       | 528바이트      |  |  |
| PNU_MUX2.v                 | PNU_MUX4.v  | PNU_MUX8.v   | PNU_NAND2.v |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 225바이트                     | 415바이트      | 602바이트       | 216바이트      |  |  |
| PNU_NAND3.v                | PNU_NAND4.v | PNU_NAND8.v  | PNU_NOR2.v  |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 229바이트                     | 242바이트      | 294바이트       | 215바이트      |  |  |
| PNU_NOR3.v                 | PNU_NOR4.v  | PNU_NOR8.v   | PNU_NOT.v   |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 228바이트                     | 241바이트      | 293바이트       | 197바이트      |  |  |
| PNU_ONE.v                  | PNU_OR2.v   | PNU_OR3.v    | PNU_OR4.v   |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 176바이트                     | 211바이트      | 224바이트       | 237바이트      |  |  |
| PNU_OR8.v                  | PNU_SRAM.v  | PNU_TBUF.v   | PNU_XNOR2.v |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 289바이트                     | 640바이트      | 216바이트       | 214바이트      |  |  |
| PNU_XNOR3.v                | PNU_XNOR4.v | PNU_XOR2.v   | PNU_XOR3.v  |  |  |
| V 파일                       | V 파일        | V 파일         | V 파일        |  |  |
| 229바이트                     | 242바이트      | 212바이트       | 225바이트      |  |  |
| PNU_XOR4.v                 | PNU_ZERO.v  | work1022_2.v |             |  |  |
| V 파일                       | V 파일        | V 파일         |             |  |  |
| 238바이트                     | 177바이트      | 538바이트       |             |  |  |

① ISE 소프트웨어의 Process 창에서 Syntheize-XST 부분에서 마우스 오른쪽 버튼으로 클릭한 후 , Run으로 문법체크 및 논리 합성 과정 진행





- ① 최종 목적인 FPGA 보드에 프로그램을 위해 디바이스의 핀 위치를 설정
  - Process 창에서 User Constraints > I/O Pin Planning 부분을 마우스 오른쪽 버튼으로 클릭하여 Run 메뉴를 선택
  - 다음과 같은 메시지가 나타나면 Yes 버튼을 클릭한다. 핀 설정을 위한 UCF 파일을 생성하여 프로젝트에 추가할 것인지를 묻는 부분





① Yes를 누르면 PlanAhead 라는 소프트웨어가 실행되며 다음과 같은 화면임 - 아래 표는 실습과정에서 필요한 PIN번호를 나타냄

| 포트 이름 | 핀 번호 | 하드웨어 설명 | 포트 이름 | 핀 번호 | 하드웨어 설명 |
|-------|------|---------|-------|------|---------|
| Α     | V1   | DIP_SW1 | X     | K8   | LED1    |
| В     | Y2   | DIP_SW2 | Y     | M4   | LED2    |
|       |      |         | Z     | M6   | LED3    |





① 아래와 같이 PIN설정이 끝나면 저장 후 PlanAhead 소프트웨어를 종료



- ① ISE에서 시뮬레이션이 가능하지만 플로리안에서 시뮬레이션까지 끝난 코드이므로 바로 장비에 프로그래밍 하여 테스트
  - Process 창의 Generate Programming File 부분을 마우스 오른쪽 버튼으로 선택하여 Run 메뉴를 실행
    - \* Synthesize 부터 bitstream 까지 진행





## 실습

① Error 없이 Generate 가 됬다면, Configure Target Device 부분을 확장시켜 Manage Configuration Project(iMPACT)을 실행





Manage Configuration Project (iMPACT)

Analyze Design Using ChipScope



① 아래 iMPACT 가 실행된다면, Boundary Scan을 더블클릭 후 File -> Initialize Chain 으로 연결된 디바이스를 찾음





① Generate된 bit 파일을 불러옴
- bit파일이 verilog파일은 합성 및 bitstream 으로 생성된 파일



① 메세지 창이 뜨면 추가 Prom을 사용하지 않으므로 No를 선택 또한 디바이스가 Scan됬다면 OK 선택





## 실습

① 마지막으로 최종 Program 시키면 디바이스에서 Test 가 가능함 \* 디바이스 전원 연결이 되어있지 않거나 JTAG가 연결되어있지 않을시 디 바이스가 Scan이 안될 수 도 있습니다.



# Clock 사용

#### ① FPGA clock Pin번호: AB16

ERROR: Place: 1108 - A clock IOB / BUFGMUX clock component pair have been found that are not placed at an optimal clock IOB / BUFGMUX site pair. The clock IOB component <clk> is placed at site <AB16>. The corresponding BUFG component <clk BUFGP/BUFG> is placed at site <BUFGMUX X2Y3>. There is only a select set of IOBs that can use the fast path to the Clocker buffer, and they are not being used. You may want to analyze why this problem exists and correct it. If this sub optimal condition is acceptable for this design, you may use the CLOCK DEDICATED ROUTE constraint in the .ucf file to demote this message to a WARNING and allow your design to continue. However, the use of this override is highly discouraged as it may lead to very poor timing results. It is recommended that this error condition be corrected in the design. A list of all the COMP.PINs used in this clock placement rule is listed below. These examples can be used directly in the .ucf file to override this clock rule. < NET "clk" CLOCK DEDICATED ROUTE = FALSE; > Phase 4.2 Initial Placement for Architecture Specific Features (Checksum: 92f031) REAL time: 6 secs Total REAL time to Placer completion: 6 secs Total CPU time to Placer completion: 5 secs 😵 ERROR: Pack: 1654 - The timing-driven placement phase encountered an error.

#### -> clock 사용 시 에러 발생



## Clock 사용

- ① clock을 사용하는 모듈 -> 마우스 오른쪽 -> Add Source -> 모듈의 .ucf 파일 선택
- ② .ucf 파일을 열어 NET "[clock포트이름]" CLOCK\_DEDICATED\_ROUTE = FALSE; 추가

```
# PlanAhead Generated physical constraints
NET "clk" LOC = AB16;
NET "in" LOC = K2;
NET "out" LOC = K8;
NET "rst" LOC = T4;
NET "clk" CLOCK_DEDICATED_ROUTE = FALSE;
```