

# Chapter 1 소개 및 툴 설치

## 1-1 Verilog HDL 소개

책 참고

## 1-2 Xilinx 및 Vivado 툴 소개

책 참고

## 1-3 CORA Z7 Kit 소개

책 참고

# 1-4 Vivado 툴 설치

1. 다음과 같이 검색합니다.

Google vivado ml standard download

2. 다음 사이트로 들어갑니다.

Advanced Micro Devices  
<https://www.xilinx.com/support/download> ::  
**Downloads**  
2023. 10. 19. — Important Information. Vivado™ ML 2023.2 is now available for download:  
Meeting Fmax targets. Increase performance of designs in Versal ...

3. 다음과 같이 2002.2 버전을 선택합니다.

Version

2023.2

2023.1

**2022.2**

2022.1

4. 페이지 아래로 조금 내려 다음 부분을 찾아 마우스 클릭합니다.

 Xilinx Unified Installer 2022.2: Windows Self Extracting Web Installer (EXE - 209.61 MB)

5. 다음과 같은 창이 나타납니다. 회원 가입을 위해 하단에 있는 [계정 만들기] 버튼을 마우스 클릭합니다.



6. 개정을 생성한 후, 로그인을 수행한 후, 다음과 같이 하단에 있는 [Download] 버튼을 누릅니다.

File Name:  
Xilinx\_Unified\_2022.2\_1014\_8888\_Win64.exe

If you are downloading the Vivado / Vitis unified installer, you will receive a follow-up confirmation email with a notice regarding our Developer Program.

You can read about how we handle your personal data, your personal data rights, and how you can contact us in our [privacy policy](#).

[Download](#)

7. 그러면 다음과 같이 프로그램이 다운로드 됩니다. 마우스 클릭하여 실행시킵니다.

Xilinx\_Unified\_2022.2\_1014\_8888\_Win64.exe

8. 다음과 같은 창이 뜨면 [허용] 버튼을 누릅니다.



9. 다음 창이 뜨면 [Continue] 버튼을 눌러줍니다.



10. 다음과 같이 설치화면이 뜹니다. [Next] 버튼을 누릅니다.



\*\*\* [Welcome] 창에서 현재 컴퓨터의 OS를 확인합니다.

11. 다음과 같은 창이 나오면 앞에서 회원 가입 시 사용했던 아이디와 패스워드를 입력한 후, [Next] 버튼을 누릅니다.



12. 다음과 같은 창이 나오면 [Vitis]를 선택한 후, [Next] 버튼을 누릅니다.



13. 다음과 같이 설치할 항목을 선택한 후 [Next] 버튼을 누릅니다.



\*\*\* 이 책에서는 CORA Z7 보드를 교보재로 사용합니다.

14. 다음과 같은 창이 나오면 사용권 동의를 체크한 후, [Next] 버튼을 누릅니다.



\*\*\* 우측 스크롤바를 하단으로 내려 동의 체크를 해 주도록 합니다.

15. 다음과 같이 설치 위치 창이 뜹니다. 기본 상태로 [Next] 버튼을 누릅니다.



\*\*\* 사용자 필요에 따라 디렉터리를 변경할 수 있습니다.

16. 그러면 다음과 같은 창이 뜹니다. 디렉터리 생성창입니다. [Yes] 버튼을 누릅니다.



17. 그러면 다음과 같이 [설치 진행 요약] 창이 뜹니다. [Install] 버튼을 누릅니다.



18. 그러면 다음과 같이 설치가 진행됩니다.



19. 중간에 다음과 같은 창이 뜨면 [설치(I)] 버튼을 누릅니다.



\*\*\* 보드 사용을 위한 드라이버 설치 창입니다.

20. 다음과 같은 창이 뜨면 [액세스 허용(A)] 버튼을 누릅니다.



21. 다음과 같이 설치가 완료됩니다. [확인] 버튼을 누릅니다.



22. 바탕 화면에 다음과 같은 아이콘을 확인합니다.



# 1-5 Vivado 프로젝트 만들기

Vivado를 이용하여 프로젝트를 생성해보도록 합니다.

1. 다음 아이콘을 찾아 실행시킵니다.



2. 다음과 같이 프로그램이 실행됩니다. [Quick Start] 하단에 있는 [Create Project]를 마우스 클릭합니다.



3. 다음과 같이 [새 프로젝트] 창이 뜹니다. [Next] 버튼을 누릅니다.



4. 다음과 같은 창이 뜹니다.



5. 다음과 같이 프로젝트 이름과 프로젝트 디렉터리를 정한 후, [Next] 버튼을 누릅니다.



6. 다음은 [프로젝트 형태]를 선택하는 창입니다. [RTL Project]를 선택한 후, [Next] 버튼을 누릅니다.



7. 다음은 [소스 추가] 창입니다. ①과 같이 Verilog 언어를 선택한 후, ②[Next] 버튼을 누릅니다.



8. 다음은 [제약 파일] 추가창입니다. 기본 상태에서 [Next] 버튼을 누릅니다.



9. 다음은 [칩 선택] 창입니다.



10. 보드 상에 있는 FPGA 칩의 이름을 확인합니다.



12. 칩 위에 있는 이름을 아래와 같이 [Search] 창에 입력합니다. [xc7z007sclg400-1]을 선택한 후, [Next] 버튼을 누릅니다.



13. 다음은 [새 프로젝트 요약] 창입니다. [Finish] 버튼을 누릅니다.



## 15. 다음과 같이 프로젝트가 생성됩니다.



# 1-6 Vivado Design Flow

프로젝트에 Verilog 디자인 소스를 추가하여 CORA Z7 보드에 프로그래밍해 봅니다.



다음과 같이 좌측에 있는 [Flow Navigator]를 기준으로 설계를 진행합니다.



1. 다음과 같이 [Flow Navigator]의 상단에 있는 [Add Sources]를 마우스 클릭합니다.



2. 그러면 다음과 같은 창이 뜹니다. [Add or create design sources]를 선택한 후, [Next] 버튼을 누릅니다.



3. 다음 창에서 [Create File] 버튼을 누릅니다.



4. 그러면 다음과 같은 창이 뜹니다. [ander]라고 입력해줍니다.



5. 그러면 다음창으로 돌아옵니다. [Finish] 버튼을 누릅니다.



6. 그러면 다음과 같이 [모듈 정의] 창이 뜹니다.



7. 다음과 같이 입출력 포트를 설정한 후, [OK] 버튼을 누릅니다.



8. 다음과 같이 소스가 추가된 것을 확인합니다.



9. 다음과 같이 소스의 내용을 확인합니다.

```
22 :  
23 ⌂ module ander(  
24     input A,  
25     input B,  
26     output Z  
27 );  
28 ⌂ endmodule  
29 :  
30 :  
31 :  
32 :  
33 :  
34 :  
35 :  
36 :  
37 :  
38 :  
39 :  
40 :  
41 :  
42 :  
43 :  
44 :  
45 :  
46 :  
47 :  
48 :  
49 :  
50 :  
51 :  
52 :  
53 :  
54 :  
55 :  
56 :  
57 :  
58 :  
59 :  
60 :  
61 :  
62 :  
63 :  
64 :  
65 :  
66 :  
67 :  
68 :  
69 :  
70 :  
71 :  
72 :  
73 :  
74 :  
75 :  
76 :  
77 :  
78 :  
79 :  
80 :  
81 :  
82 :  
83 :  
84 :  
85 :  
86 :  
87 :  
88 :  
89 :  
90 :  
91 :  
92 :  
93 :  
94 :  
95 :  
96 :  
97 :  
98 :  
99 :  
100 :  
101 :  
102 :  
103 :  
104 :  
105 :  
106 :  
107 :  
108 :  
109 :  
110 :  
111 :  
112 :  
113 :  
114 :  
115 :  
116 :  
117 :  
118 :  
119 :  
120 :  
121 :  
122 :  
123 :  
124 :  
125 :  
126 :  
127 :  
128 :  
129 :  
130 :  
131 :  
132 :  
133 :  
134 :  
135 :  
136 :  
137 :  
138 :  
139 :  
140 :  
141 :  
142 :  
143 :  
144 :  
145 :  
146 :  
147 :  
148 :  
149 :  
150 :  
151 :  
152 :  
153 :  
154 :  
155 :  
156 :  
157 :  
158 :  
159 :  
160 :  
161 :  
162 :  
163 :  
164 :  
165 :  
166 :  
167 :  
168 :  
169 :  
170 :  
171 :  
172 :  
173 :  
174 :  
175 :  
176 :  
177 :  
178 :  
179 :  
180 :  
181 :  
182 :  
183 :  
184 :  
185 :  
186 :  
187 :  
188 :  
189 :  
190 :  
191 :  
192 :  
193 :  
194 :  
195 :  
196 :  
197 :  
198 :  
199 :  
200 :  
201 :  
202 :  
203 :  
204 :  
205 :  
206 :  
207 :  
208 :  
209 :  
210 :  
211 :  
212 :  
213 :  
214 :  
215 :  
216 :  
217 :  
218 :  
219 :  
220 :  
221 :  
222 :  
223 :  
224 :  
225 :  
226 :  
227 :  
228 :  
229 :  
230 :  
231 :  
232 :  
233 :  
234 :  
235 :  
236 :  
237 :  
238 :  
239 :  
240 :  
241 :  
242 :  
243 :  
244 :  
245 :  
246 :  
247 :  
248 :  
249 :  
250 :  
251 :  
252 :  
253 :  
254 :  
255 :  
256 :  
257 :  
258 :  
259 :  
260 :  
261 :  
262 :  
263 :  
264 :  
265 :  
266 :  
267 :  
268 :  
269 :  
270 :  
271 :  
272 :  
273 :  
274 :  
275 :  
276 :  
277 :  
278 :  
279 :  
280 :  
281 :  
282 :  
283 :  
284 :  
285 :  
286 :  
287 :  
288 :  
289 :  
290 :  
291 :  
292 :  
293 :  
294 :  
295 :  
296 :  
297 :  
298 :  
299 :  
300 :  
301 :  
302 :  
303 :  
304 :  
305 :  
306 :  
307 :  
308 :  
309 :  
310 :  
311 :  
312 :  
313 :  
314 :  
315 :  
316 :  
317 :  
318 :  
319 :  
320 :  
321 :  
322 :  
323 :  
324 :  
325 :  
326 :  
327 :  
328 :  
329 :  
330 :  
331 :  
332 :  
333 :  
334 :  
335 :  
336 :  
337 :  
338 :  
339 :  
340 :  
341 :  
342 :  
343 :  
344 :  
345 :  
346 :  
347 :  
348 :  
349 :  
350 :  
351 :  
352 :  
353 :  
354 :  
355 :  
356 :  
357 :  
358 :  
359 :  
360 :  
361 :  
362 :  
363 :  
364 :  
365 :  
366 :  
367 :  
368 :  
369 :  
370 :  
371 :  
372 :  
373 :  
374 :  
375 :  
376 :  
377 :  
378 :  
379 :  
380 :  
381 :  
382 :  
383 :  
384 :  
385 :  
386 :  
387 :  
388 :  
389 :  
390 :  
391 :  
392 :  
393 :  
394 :  
395 :  
396 :  
397 :  
398 :  
399 :  
400 :  
401 :  
402 :  
403 :  
404 :  
405 :  
406 :  
407 :  
408 :  
409 :  
410 :  
411 :  
412 :  
413 :  
414 :  
415 :  
416 :  
417 :  
418 :  
419 :  
420 :  
421 :  
422 :  
423 :  
424 :  
425 :  
426 :  
427 :  
428 :  
429 :  
430 :  
431 :  
432 :  
433 :  
434 :  
435 :  
436 :  
437 :  
438 :  
439 :  
440 :  
441 :  
442 :  
443 :  
444 :  
445 :  
446 :  
447 :  
448 :  
449 :  
450 :  
451 :  
452 :  
453 :  
454 :  
455 :  
456 :  
457 :  
458 :  
459 :  
460 :  
461 :  
462 :  
463 :  
464 :  
465 :  
466 :  
467 :  
468 :  
469 :  
470 :  
471 :  
472 :  
473 :  
474 :  
475 :  
476 :  
477 :  
478 :  
479 :  
480 :  
481 :  
482 :  
483 :  
484 :  
485 :  
486 :  
487 :  
488 :  
489 :  
490 :  
491 :  
492 :  
493 :  
494 :  
495 :  
496 :  
497 :  
498 :  
499 :  
500 :  
501 :  
502 :  
503 :  
504 :  
505 :  
506 :  
507 :  
508 :  
509 :  
510 :  
511 :  
512 :  
513 :  
514 :  
515 :  
516 :  
517 :  
518 :  
519 :  
520 :  
521 :  
522 :  
523 :  
524 :  
525 :  
526 :  
527 :  
528 :  
529 :  
530 :  
531 :  
532 :  
533 :  
534 :  
535 :  
536 :  
537 :  
538 :  
539 :  
540 :  
541 :  
542 :  
543 :  
544 :  
545 :  
546 :  
547 :  
548 :  
549 :  
550 :  
551 :  
552 :  
553 :  
554 :  
555 :  
556 :  
557 :  
558 :  
559 :  
560 :  
561 :  
562 :  
563 :  
564 :  
565 :  
566 :  
567 :  
568 :  
569 :  
570 :  
571 :  
572 :  
573 :  
574 :  
575 :  
576 :  
577 :  
578 :  
579 :  
580 :  
581 :  
582 :  
583 :  
584 :  
585 :  
586 :  
587 :  
588 :  
589 :  
590 :  
591 :  
592 :  
593 :  
594 :  
595 :  
596 :  
597 :  
598 :  
599 :  
600 :  
601 :  
602 :  
603 :  
604 :  
605 :  
606 :  
607 :  
608 :  
609 :  
610 :  
611 :  
612 :  
613 :  
614 :  
615 :  
616 :  
617 :  
618 :  
619 :  
620 :  
621 :  
622 :  
623 :  
624 :  
625 :  
626 :  
627 :  
628 :  
629 :  
630 :  
631 :  
632 :  
633 :  
634 :  
635 :  
636 :  
637 :  
638 :  
639 :  
640 :  
641 :  
642 :  
643 :  
644 :  
645 :  
646 :  
647 :  
648 :  
649 :  
650 :  
651 :  
652 :  
653 :  
654 :  
655 :  
656 :  
657 :  
658 :  
659 :  
660 :  
661 :  
662 :  
663 :  
664 :  
665 :  
666 :  
667 :  
668 :  
669 :  
670 :  
671 :  
672 :  
673 :  
674 :  
675 :  
676 :  
677 :  
678 :  
679 :  
680 :  
681 :  
682 :  
683 :  
684 :  
685 :  
686 :  
687 :  
688 :  
689 :  
690 :  
691 :  
692 :  
693 :  
694 :  
695 :  
696 :  
697 :  
698 :  
699 :  
700 :  
701 :  
702 :  
703 :  
704 :  
705 :  
706 :  
707 :  
708 :  
709 :  
710 :  
711 :  
712 :  
713 :  
714 :  
715 :  
716 :  
717 :  
718 :  
719 :  
720 :  
721 :  
722 :  
723 :  
724 :  
725 :  
726 :  
727 :  
728 :  
729 :  
730 :  
731 :  
732 :  
733 :  
734 :  
735 :  
736 :  
737 :  
738 :  
739 :  
740 :  
741 :  
742 :  
743 :  
744 :  
745 :  
746 :  
747 :  
748 :  
749 :  
750 :  
751 :  
752 :  
753 :  
754 :  
755 :  
756 :  
757 :  
758 :  
759 :  
760 :  
761 :  
762 :  
763 :  
764 :  
765 :  
766 :  
767 :  
768 :  
769 :  
770 :  
771 :  
772 :  
773 :  
774 :  
775 :  
776 :  
777 :  
778 :  
779 :  
780 :  
781 :  
782 :  
783 :  
784 :  
785 :  
786 :  
787 :  
788 :  
789 :  
790 :  
791 :  
792 :  
793 :  
794 :  
795 :  
796 :  
797 :  
798 :  
799 :  
800 :  
801 :  
802 :  
803 :  
804 :  
805 :  
806 :  
807 :  
808 :  
809 :  
8010 :  
8011 :  
8012 :  
8013 :  
8014 :  
8015 :  
8016 :  
8017 :  
8018 :  
8019 :  
8020 :  
8021 :  
8022 :  
8023 :  
8024 :  
8025 :  
8026 :  
8027 :  
8028 :  
8029 :  
8030 :  
8031 :  
8032 :  
8033 :  
8034 :  
8035 :  
8036 :  
8037 :  
8038 :  
8039 :  
8040 :  
8041 :  
8042 :  
8043 :  
8044 :  
8045 :  
8046 :  
8047 :  
8048 :  
8049 :  
8050 :  
8051 :  
8052 :  
8053 :  
8054 :  
8055 :  
8056 :  
8057 :  
8058 :  
8059 :  
8060 :  
8061 :  
8062 :  
8063 :  
8064 :  
8065 :  
8066 :  
8067 :  
8068 :  
8069 :  
8070 :  
8071 :  
8072 :  
8073 :  
8074 :  
8075 :  
8076 :  
8077 :  
8078 :  
8079 :  
8080 :  
8081 :  
8082 :  
8083 :  
8084 :  
8085 :  
8086 :  
8087 :  
8088 :  
8089 :  
8090 :  
8091 :  
8092 :  
8093 :  
8094 :  
8095 :  
8096 :  
8097 :  
8098 :  
8099 :  
80100 :  
80101 :  
80102 :  
80103 :  
80104 :  
80105 :  
80106 :  
80107 :  
80108 :  
80109 :  
80110 :  
80111 :  
80112 :  
80113 :  
80114 :  
80115 :  
80116 :  
80117 :  
80118 :  
80119 :  
80120 :  
80121 :  
80122 :  
80123 :  
80124 :  
80125 :  
80126 :  
80127 :  
80128 :  
80129 :  
80130 :  
80131 :  
80132 :  
80133 :  
80134 :  
80135 :  
80136 :  
80137 :  
80138 :  
80139 :  
80140 :  
80141 :  
80142 :  
80143 :  
80144 :  
80145 :  
80146 :  
80147 :  
80148 :  
80149 :  
80150 :  
80151 :  
80152 :  
80153 :  
80154 :  
80155 :  
80156 :  
80157 :  
80158 :  
80159 :  
80160 :  
80161 :  
80162 :  
80163 :  
80164 :  
80165 :  
80166 :  
80167 :  
80168 :  
80169 :  
80170 :  
80171 :  
80172 :  
80173 :  
80174 :  
80175 :  
80176 :  
80177 :  
80178 :  
80179 :  
80180 :  
80181 :  
80182 :  
80183 :  
80184 :  
80185 :  
80186 :  
80187 :  
80188 :  
80189 :  
80190 :  
80191 :  
80192 :  
80193 :  
80194 :  
80195 :  
80196 :  
80197 :  
80198 :  
80199 :  
80200 :  
80201 :  
80202 :  
80203 :  
80204 :  
80205 :  
80206 :  
80207 :  
80208 :  
80209 :  
80210 :  
80211 :  
80212 :  
80213 :  
80214 :  
80215 :  
80216 :  
80217 :  
80218 :  
80219 :  
80220 :  
80221 :  
80222 :  
80223 :  
80224 :  
80225 :  
80226 :  
80227 :  
80228 :  
80229 :  
80230 :  
80231 :  
80232 :  
80233 :  
80234 :  
80235 :  
80236 :  
80237 :  
80238 :  
80239 :  
80240 :  
80241 :  
80242 :  
80243 :  
80244 :  
80245 :  
80246 :  
80247 :  
80248 :  
80249 :  
80250 :  
80251 :  
80252 :  
80253 :  
80254 :  
80255 :  
80256 :  
80257 :  
80258 :  
80259 :  
80260 :  
80261 :  
80262 :  
80263 :  
80264 :  
80265 :  
80266 :  
80267 :  
80268 :  
80269 :  
80270 :  
80271 :  
80272 :  
80273 :  
80274 :  
80275 :  
80276 :  
80277 :  
80278 :  
80279 :  
80280 :  
80281 :  
80282 :  
80283 :  
80284 :  
80285 :  
80286 :  
80287 :  
80288 :  
80289 :  
80290 :  
80291 :  
80292 :  
80293 :  
80294 :  
80295 :  
80296 :  
80297 :  
80298 :  
80299 :  
80300 :  
80301 :  
80302 :  
80303 :  
80304 :  
80305 :  
80306 :  
80307 :  
80308 :  
80309 :  
80310 :  
80311 :  
80312 :  
80313 :  
80314 :  
80315 :  
80316 :  
80317 :  
80318 :  
80319 :  
80320 :  
80321 :  
80322 :  
80323 :  
80324 :  
80325 :  
80326 :  
80327 :  
80328 :  
80329 :  
80330 :  
80331 :  
80332 :  
80333 :  
80334 :  
80335 :  
80336 :  
80337 :  
80338 :  
80339 :  
80340 :  
80341 :  
80342 :  
80343 :  
80344 :  
80345 :  
80346 :  
80347 :  
80348 :  
80349 :  
80350 :  
80351 :  
80352 :  
80353 :  
80354 :  
80355 :  
80356 :  
80357 :  
80358 :  
80359 :  
80360 :  
80361 :  
80362 :  
80363 :  
80364 :  
80365 :  
80366 :  
80367 :  
80368 :  
80369 :  
80370 :  
80371 :  
80372 :  
80373 :  
80374 :  
80375 :  
80376 :  
80377 :  
80378 :  
80379 :  
80380 :  
80381 :  
80382 :  
80383 :  
80384 :  
80385 :  
80386 :  
80387 :  
80388 :  
80389 :  
80390 :  
80391 :  
80392 :  
80393 :  
80394 :  
80395 :  
80396 :  
80397 :  
80398 :  
80399 :  
80400 :  
80401 :  
80402 :  
80403 :  
80404 :  
80405 :  
80406 :  
80407 :  
80408 :  
80409 :  
80410 :  
80411 :  
80412 :  
80413 :  
80414 :  
80415 :  
80416 :  
80417 :  
80418 :  
80419 :  
80420 :  
80421 :  
80422 :  
80423 :  
80424 :  
80425 :  
80426 :  
80427 :  
80428 :  
80429 :  
80430 :  
80431 :  
80432 :  
80433 :  
80434 :  
80435 :  
80436 :  
80437 :  
80438 :  
80439 :  
80440 :  
80441 :  
80442 :  
80443 :  
80444 :  
80445 :  
80446 :  
80447 :  
80448 :  
80449 :  
80450 :  
80451 :  
80452 :  
80453 :  
80454 :  
80455 :  
80456 :  
80457 :  
80458 :  
80459 :  
80460 :  
80461 :  
80462 :  
80463 :  
80464 :  
80465 :  
80466 :  
80467 :  
80468 :  
80469 :  
80470 :  
80471 :  
80472 :  
80473 :  
80474 :  
80475 :  
80476 :  
80477 :  
80478 :  
80479 :  
80480 :  
80481 :  
80482 :  
80483 :  
80484 :  
80485 :  
80486 :  
80487 :  
80488 :  
80489 :  
80490 :  
80491 :  
80492 :  
80493 :  
80494 :  
80495 :  
80496 :  
80497 :  
80498 :  
80499 :  
80500 :  
80501 :  
80502 :  
80503 :  
80504 :  
80505 :  
80506 :  
80507 :  
80508 :  
80509 :  
80510 :  
80511 :  
80512 :  
80513 :  
80514 :  
80515 :  
80516 :  
80517 :  
80518 :  
80519 :  
80520 :  
80521 :  
80522 :  
80523 :  
80524 :  
80525 :  
80526 :  
80527 :  
80528 :  
80529 :  
80530 :  
80531 :  
80532 :  
80533 :  
80534 :  
80535 :  
80536 :  
80537 :  
80538 :  
80539 :  
80540 :  
80541 :  
80542 :  
80543 :  
80544 :  
80545 :  
80546 :  
80547 :  
80548 :  
80549 :  
80550 :  
80551 :  
80552 :  
80553 :  
80554 :  
80555 :  
80556 :  
80557 :  
80558 :  
80559 :  
80560 :  
80561 :  
80562 :  
80563 :  
80564 :  
80565 :  
80566 :  
80567 :  
80568 :  
80569 :  
80570 :  
80571 :  
80572 :  
80573 :  
80574 :  
80575 :  
80576 :  
80577 :  
80578 :  
80579 :  
80580 :  
80581 :  
80582 :  
80583 :  
80584 :  
80585 :  
80586 :  
80587 :  
80588 :  
80589 :  
80590 :  
80591 :  
80592 :  
80593 :  
80594 :  
80595 :  
80596 :  
80597 :  
80598 :  
80599 :  
80600 :  
80601 :  
80602 :  
80603 :  
80604 :  
80605 :  
80606 :  
80607 :  
80608 :  
80609 :  
8
```

## 소스 작성하기

10. 다음과 같이 소스를 작성합니다.

```
23 ⌂ module ander(
24     input A,
25     input B,
26     output Z
27 );
28
29     assign Z = A & B;
30
31 ⌂ endmodule
```

## RTL 스키매틱 확인하기

11. [RTL ANALYSIS]--[Open Elaborated Design]을 마우스 클릭합니다.



12. 다음과 같은 창이 뜨면 [Save] 버튼을 눌러 소스를 저장합니다.



13. 다음과 같은 창이 뜨면 [OK] 버튼을 누릅니다.



14. 다음과 같이 RTL 레벨의 [Schematic]을 확인합니다.



## 합성하기

15. 다음과 같이 [SYNTHESIS]--[Run Synthesis]를 마우스 클릭합니다.



16. 다음과 같은 창이 뜹니다. [OK] 버튼을 누릅니다.



17. 우측 상단에 합성 진행 상태가 표시됩니다. 시간이 몇 분 정도 걸립니다.



18. 합성이 끝나면 다음과 같이 표시됩니다.



19. 다음과 같은 창이 뜹니다. [Cancel] 버튼을 누릅니다.



## 합성 스키마틱 보기

20. [SYNTHESIS]--[Open Synthesized Design]--[Schematic]을 눌러줍니다.



21. FPGA 블록 기반의 합성 스키마틱을 확인합니다.



## 핀 배치하기

여기서는 핀 배치를 해 봅니다.

1. 다음과 같이 [Layout] -- [I/O Planning]을 선택합니다.



2. 다음 [Package]창을 확인합니다.



3. 하단에 있는 [I/O Ports]를 선택합니다.



#### 4. CORA Z7 보드의 핀을 확인합니다.



Figure 11.1. Cora Z7 Basic I/O

\*\*\* 다음 사이트를 참조합니다.

<https://digilent.com/reference/programmable-logic/cora-z7/reference-manual>

5. 다음과 같이 [Package Pin] 란에 핀을 설정해줍니다. [I/O Std]는 LVCMOS33\*로 해줍니다. 버튼과 LED가 3.3V를 사용하도록 보드가 설계되어 있습니다.

| Name                    | Direction | Neg Diff Pair | Package Pin | Fixed                               | Bank | I/O Std   | Vcco  | Vref | Drive Strength | Slew Type | Pull Type | Off-Chip Termination | IN_TERM |
|-------------------------|-----------|---------------|-------------|-------------------------------------|------|-----------|-------|------|----------------|-----------|-----------|----------------------|---------|
| <b>All ports (3)</b>    |           |               |             |                                     |      |           |       |      |                |           |           |                      |         |
| <b>Scalar ports (3)</b> |           |               |             |                                     |      |           |       |      |                |           |           |                      |         |
| IN                      |           |               | D20         | <input checked="" type="checkbox"/> | 35   | LVCMOS33* | 3.300 |      |                |           | NONE      | NONE                 |         |
| IN                      |           |               | D19         | <input checked="" type="checkbox"/> | 35   | LVCMOS33* | 3.300 |      |                |           | NONE      | NONE                 |         |
| OUT                     |           |               | N15         | <input checked="" type="checkbox"/> | 35   | LVCMOS33* | 3.300 | 12   |                |           | NONE      | FP_VTT_50            |         |



6. 다음과 같이 파일로 저장합니다.



7. 다음과 같은 창이 뜨면 [OK] 버튼을 누릅니다.



8. 다음과 같은 창이 뜨면 [OK] 버튼을 눌러줍니다.



9. 다음과 같이 파일이 생성된 것을 확인합니다.



10. 다음은 파일의 내용입니다.

```
set_property PACKAGE_PIN D20 [get_ports A]
set_property PACKAGE_PIN D19 [get_ports B]
set_property PACKAGE_PIN N15 [get_ports Z]
set_property IOSTANDARD LVCMOS33 [get_ports A]
set_property IOSTANDARD LVCMOS33 [get_ports B]
set_property IOSTANDARD LVCMOS33 [get_ports Z]
```

## 구현하기

11. 다음과 같이 [IMPLEMENTATION]--[Run Implementation]을 선택합니다.



12. 다음과 같은 창이 뜹니다. [OK] 버튼을 누릅니다.



13. 우측 상단에서 구현이 진행되는 것을 확인할 수 있습니다. 시간이 걸립니다.



14. 다음과 같이 구현이 완료됩니다.



15. 다음과 같은 창이 뜹니다. [Cancel] 버튼을 누릅니다.



## FPGA 내부 확인하기

16. [IMPLEMENTATION] -- [Open Implemented Design] -- [Schematic]을 선택합니다.



17. 다음 [Device] 창을 확인합니다.



18. [Routing Resources] 아이콘을 눌러줍니다.



19. 그러면 다음과 같이 배선을 볼 수 있습니다.



다음 부분을 확대해 봅니다.



20. 파란 블록 주변으로 마우스 왼쪽 버튼을 눌러 사각형을 만든 후, 마우스 버튼을 놓습니다.



21. 그러면 사각형이 확대됩니다. 한 번 더 같은 동작을 반복합니다.



22. 그러면 다음과 같이 확대되는 것을 볼 수 있습니다.



23. 다음과 같이 LUT를 확인합니다.



24. 원래대로 돌려놓기 위해서는 [Zoom Fit] 아이콘을 선택합니다.



25. 다음과 같이 원래대로 돌아갑니다.



26. 이번엔 같은 방법으로 I/O 블록 영역을 확대해봅니다.



27. 다음과 같이 확대되는 것을 확인합니다.



29. I/O 블록을 좀 더 확대해봅니다.



30. 다음과 같이 확대됩니다. I/O 블록 내부를 자세히 볼 수 있습니다.



## 비트스트림 생성하기(FPGA 이미지)

1. 다음과 같이 [PROGRAM AND DEBUG] -- [Generate Bitstream]을 선택합니다.



2. 다음과 같은 창이 뜹니다. [OK] 버튼을 눌러줍니다.



3. 우측 상단에서 작업 진행을 확인할 수 있습니다.



4. 다음과 같이 창이 뜹니다. 일단 [Cancel] 버튼을 눌러줍니다.



## 보드 연결하기

1. 다음과 같이 CORA Z7 보드를 PC에 연결한 후, 전원을 켭니다.



## FPGA 이미지 다운로드하기

1. 다음과 같이 [PROGRAM AND DEBUG] -- [Open Hardware Manager]를 선택합니다.



2. [Open Target]을 선택합니다.



4. [Auto Connect]를 선택합니다.



5. [Program Device]를 선택합니다.



6. [xc7a35t\_0]을 선택합니다.



7. 다음과 같은 창이 뜹니다. ander.bit 파일을 확인 후, [Program] 버튼을 누릅니다.



9. 다음과 같이 완료된 것을 확인합니다.



10. 2 개의 버튼을 눌러 LED가 들어오는 것을 확인합니다.



## bit 파일 확인하기

bit 파일은 FPGA 설정 파일로 다음과 같이 확인할 수 있습니다.

1. 다음과 같이 디렉터리를 찾아갑니다.

```
바탕 화면 > HDL_Labs > comb_logic > comb_logic.runs > impl_1 >
```

2. 다음 파일을 확인합니다.

|           |                    |        |         |
|-----------|--------------------|--------|---------|
| ander.bit | 2023-03-11 오전 9:19 | BIT 파일 | 2,036KB |
|-----------|--------------------|--------|---------|

# 논리 로직의 트랜지스터 구조

## AND

Digital Logic "AND" Gate Types

The 2-input Logic AND Gate

| Symbol                                                                            | Truth Table             |   |   |
|-----------------------------------------------------------------------------------|-------------------------|---|---|
|                                                                                   | B                       | A | Q |
|  | 0                       | 0 | 0 |
|                                                                                   | 0                       | 1 | 0 |
|                                                                                   | 1                       | 0 | 0 |
|                                                                                   | 1                       | 1 | 1 |
| Boolean Expression Q = A.B                                                        | Read as A AND B gives Q |   |   |



## OR

Digital Logic "OR" Gate Types

The 2-input Logic OR Gate

| Symbol                                                                              | Truth Table            |   |   |
|-------------------------------------------------------------------------------------|------------------------|---|---|
|                                                                                     | B                      | A | Q |
|  | 0                      | 0 | 0 |
|                                                                                     | 0                      | 1 | 1 |
|                                                                                     | 1                      | 0 | 1 |
|                                                                                     | 1                      | 1 | 1 |
| Boolean Expression Q = A+B                                                          | Read as A OR B gives Q |   |   |



## NOT

The Logic NOT Gate Truth Table

| Symbol                                                                              | Truth Table                               |   |
|-------------------------------------------------------------------------------------|-------------------------------------------|---|
|                                                                                     | A                                         | Q |
|  | 0                                         | 1 |
|                                                                                     | 1                                         | 0 |
| Inverter or NOT Gate                                                                | Boolean Expression Q = not A or $\bar{A}$ |   |
|                                                                                     | Read as inverse of A gives Q              |   |



# NAND

The Digital Logic "NAND" Gate

2-input Logic NAND Gate

| Symbol                                                                            | Truth Table                 |   |   |
|-----------------------------------------------------------------------------------|-----------------------------|---|---|
|                                                                                   | B                           | A | Q |
|  | 0                           | 0 | 1 |
|                                                                                   | 0                           | 1 | 1 |
| 2-input NAND Gate                                                                 | 1                           | 0 | 1 |
|                                                                                   | 1                           | 1 | 0 |
| Boolean Expression $Q = \overline{A \cdot B}$                                     | Read as A AND B gives NOT Q |   |   |



# NOR

The Digital Logic "NOR" Gate

2-input NOR Gate

| Symbol                                                                              | Truth Table                |   |   |
|-------------------------------------------------------------------------------------|----------------------------|---|---|
|                                                                                     | B                          | A | Q |
|  | 0                          | 0 | 1 |
|                                                                                     | 0                          | 1 | 0 |
| 2-input NOR Gate                                                                    | 1                          | 0 | 0 |
|                                                                                     | 1                          | 1 | 0 |
| Boolean Expression $Q = \overline{A+B}$                                             | Read as A OR B gives NOT Q |   |   |

