#### 01076113 Digital System Fundamentals in Practice 2567/1

ภาควิชาวิศวกรรมคอมพิวเตอร์ คณะวิศวกรรมศาสตร์ สถาบันเทคโนโลยีพระจอมเกล้าเจ้าคุณทหารลาดกระบัง

# การทดลองที่ 4 วงจรบวกเลขโดยใช้วิธี Schematic บนบอร์ด FPGA วัตถุประสงค์

- 1. เพื่อให้นักศึกษาฝึกใช้งานโปรแกรมทูลช่วยการออกแบบวงจรดิจิตอลเป็น
- 2. เพื่อให้นักศึกษาฝึกการใช้งาน FPGA

หมายเหตุ ให้อ่านเอกสารการทดลองและเอกสารประกอบให้ครบก่อนเริ่มทำการทดลอง

#### บทนำ

การทดลองนี้แตกต่างจากการทดลองที่ผ่านมา นักศึกษาจะได้รู้จักการออกแบบวงจรด้วยการวาดรูป (Schematic Circuit) และบันทึกโปรแกรมลงในชิป Field Programmable Gate Array (FPGA)

#### โปรแกรม ISE Xilinx WebPACK

นักศึกษาที่มีหนังสือ "ออกแบบไอซีดิจิตอลด้วย FPGA และ CPLD ภาคปฏิบัติ โดยใช้วิธี Schematic ซอฟต์แวร์ทูล ISE WebPACK" ให้อ่านหนังสือก่อนการทดลองในบทที่ 1 และ 2 ก่อน

#### บอร์ดทดลอง

วงจรดิจิตอลในปัจจุบันมีความซับซ้อนสูงทำให้การปรับแก้ไขวงจรทำไม่สะดวก การลากสายไฟการ ติดตั้งไอซีเกตเพิ่มเติมเพื่อปรับเปลี่ยนการทำงานของวงจรทำได้ยาก จึงมีการใช้ไอซีที่สามารถโปรแกรมวงจรได้ ซึ่งมี หลายแบบไม่ว่าจะเป็น Generic Logic Array (GAL), Programmable Array Logic (PAL), Programmable Logic Device (PLD), Complex Programmable Logic Device (CPLD) และ Field Programmable Gate Array (FPGA) ซึ่งล้วนแต่มีลักษณะที่แตกต่างกัน ทั้งขนาดจำนวนเกต ภาวการณ์คงอยู่ ของโปรแกรม/ข้อมูล การโปรแกรม โดยการทดลองนี้ใช้งาน FPGA

FPGA มีหลายบริษัทเป็นผู้ผลิต แต่มีสองบริษัทใหญ่คือ Xilinx กับ Altera โดยตระกูลผลิตภัณฑ์ของ Xilinx ที่นิยมกันคือตระกูล Spartan รุ่นเทคโนโลยีขนาด 45nm และตระกูล Virtex รุ่นเทคโนโลยีขนาด 28nm ทางด้าน Altera ตระกูลผลิตภัณฑ์ที่นิยมคือตระกูล Stratix รุ่นเทคโนโลยีขนาด 40nm และ 28nm การทดลองในวิชานี้ใช้ Xilinx Spartan-3 รุ่นเทคโนโลยีขนาด 90nm

ทั้งนี้ Spartan-3 ที่ใช้ในการทดลองคือรุ่น XC3S400 มีความจุขนาด 400,000 เกต จำนวนเกตยิ่งมาก ยิ่งสามารถสร้างวงจรที่มีขนาดใหญ่และซับซ้อนได้ จุดอ่อนที่ต้องระมัดระวังของ FPGA คือมีอายุการใช้งาน จำกัด กล่าวคือสามารถเขียนโปรแกรมลงได้ไม่เกิน 20,000 ครั้ง จากนั้นต้องเปลี่ยนไอซี FPGA ใหม่ การเขียน โปรแกรมลง FPGA ทำได้โดยใช้สายซึ่งใช้มาตรฐานการเชื่อมแบบ Joint Test Action Group (JTAG) และ ส่งผ่านโปรแกรมด้วย Parallel Port to JTAG (ปัจจุบันนิยมใช้ USB to JTAG มากกว่า)



รู**ปที่ 1** เลย์เอาต์ของบอร์ด FPGA รุ่น XC3S200 และ XC3S400

บอร์ด FPGA ที่ใช้ในการทดลองดังรูปที่ 1 นั้นหมายเลข Pxx ต่างๆ ระบุถึงขาที่เชื่อมกับตัวชิป FPGA ฉะนั้นจึง<u>ไม่ควรสัมผัสตัวไอซี ขา และส่วนประกอบในบอร์ด</u> เนื่องจากไฟฟ้าสถิตจากร่างกายอาจก่อให้เกิด ความเสียหายแก่ไอซี อีกทั้งเหงื่อทำให้เกิดอ็อกไซด์ที่ขาและส่วนประกอบโลหะในวงจร

#### วงจรภายในของบอร์ดทดลอง

• สวิตซ์ (SWO – SW7) ลักษณะการต่อภายในวงจรเป็นการต่อแบบ R - Pull Up ดังรูปที่ 2 ซึ่งตัว ต้านทานต่อเข้า VCC เพื่อรักษาระดับของแรงดันให้คงที่ วงจรจึงอยู่สถานะลอจิก "1" ตลอดเวลา และ เมื่อเลื่อนสวิตช์จะให้สถานะลอจิก "0" หรือที่เรียกว่า Active Low เพราะจะทำงาน (ON) เมื่อ กระแสไฟฟ้าไหลลงกราวด์ วงจรแบบ Pull Up ได้รับความนิยมมากเพราะกันสัญญาณรบกวนได้ดี ฉะนั้นเมื่อเลื่อน SW = OFF ให้ "1" และ ON ให้ "0"



รูปที่ 2 วงจร R-Pull Up (ซ้าย) และวงจร R-Pull Down (ขวา)

พลอด LED0 - LED7 ลักษณะวงจรเป็นดังรูปที่ 3 สัญญาณลอจิกจาก FPGA ผ่าน R ความต้านทาน
 470Ω เพื่อจำกัดกระแสป้องกัน LED เสียหาย ฉะนั้น<u>เมื่อกำหนดให้ Pxx ดังกล่าวเป็น "1" หลอด</u>
 LEDx จะสว่างเป็นสีแดง และเมื่อกำหนดให้ Pxx เป็น "0" LED จะไม่สว่าง



หลอด LED สองสี (MN0 – MN7) ลักษณะวงจรขับแสดงดังรูปที่ 4 ลักษณะวงจรมีอินเวอร์เตอร์ ทำหน้าที่กลับบิตโดยต่ออนุกรมกับ LED กับ R ความต้านทาน 470Ω เพื่อจำกัดกระแสป้องกัน LED เสียหาย หากลอจิกที่ขา P36 เป็น "1" จะได้ผลลัพธ์ไปยัง LED เป็น "0" กระแสย่อมไหลผ่าน LED ดวงซ้ายมือทำให้ติดสว่าง แต่หากขา P36 เป็น "0" กระแสจะมีทิศทางกลับกัน LED ดวงขวามือจึงติด สว่างแทน ฉะนั้นเมื่อกำหนดให้ Pxx ดังกล่าวเป็น "1" หลอด MNx จะสว่างเป็นสีแดง หากเป็น "0" จะเป็นสีเขียว และกำหนดเป็นสัญญาณนาหิกาจะติดสลับไปมาเป็นสีส้ม



รูปที่ 4 วงจรขับ LED สองสี

## ขั้นตอนการออกแบบวงจรอย่างย่อของ version 14.7(ฉบับเต็ม version 8.1i ดูในหนังสือ)

กระบวนการออกแบบวงจรดิจิตอลด้วย FPGA มีทั้งหมด 5 ขั้นตอนดังนี้



**รูปที่ 5** กระบวนการออกแบบ 5 ขั้นตอน

1. Design Entry การสร้างวงจรด้วยวิธีการต่างๆ เช่น สร้างด้วยภาษา VHDL หรือ Verilog สร้างด้วย วิธีการออกแบบผังวงจร (Schematic Design) และสร้างด้วยแผนภูมิสถานะ (State diagram) ดังรูป ที่ 6 ซึ่งการทดลองครั้งนี้สร้างวงจรด้วยวิธี Schematic Design



รูปที่ 6 ขั้นตอนการสร้างวงจรดิจิตอลทั้ง 3 แบบ

- 2. Design Verification การตรวจสอบวงจรที่ออกแบบเป็นการนำวงจรที่ออกแบบมาตรวจสอบ ความถูกต้องด้วยโปรแกรมจำลองการทำงาน โดยทั่วไปมีการจำลองการทำงานใน 3 ระดับคือ
  - Behavioral Simulation การจำลองเฉพาะพฤติกรรมของวงจรโดยยังไม่คิดถึงโครงสร้าง
    ภายใน เพื่อได้แบบจำลองการทำงานเบื้องต้น
  - Functional Simulation การจำลองการทำงานของโค้ดในระดับ Register-Transfer-Level (RTL) เพื่อตรวจสอบการทำงานของวงจรก่อนนำไป Synthesis
  - Timing simulation การจำลองการทำงานที่ใกล้เคียงกับฮาร์ดแวร์มากที่สุดเนื่องจากนำ ข้อมูลเชิงเวลา (Timing) ที่เกิดขึ้นใน FPGA มาประกอบด้วย มักใช้หาข้อผิดพลาดในกรณีที่ การทำงานจริงบน FPGA ไม่เหมือนผลจาก Functional Simulation
- 3. Design Synthesis การสังเคราะห์วงจร คือ การแปลงโค้ดให้เป็นวงจรในระดับเกต (Gate level) ซึ่งเป็น Netlist ของเกตต่างๆ ในวงจร ผู้ออกแบบต้องระบุถึงเทคโนโลยี ผู้ผลิต และหมายเลขรุ่น ของฮาร์ดแวร์ที่ใช้แก่โปรแกรม Synthesis ซึ่งบางโปรแกรมเปิดโอกาสให้เลือกวิธีการสังเคราะห์วงจรได้ ว่าต้องการออปติไมซ์แบบใดระหว่างความเร็วสูงกับประหยัดเนื้อที่

- 4. Design Implementation ขั้นตอนนี้ประกอบด้วย การแบ่งวงจร การวางอุปกรณ์ และการเชื่อมต่อ สัญญาณ (Partioning, Placement and Routing) ตามลำดับ โดยแบ่งวงจรที่ได้จากการสังเคราะห์ แล้วแยกเป็นวงจรย่อยๆ เพื่อวางลงในโครงสร้างของอุปกรณ์ชนิดต่างๆ ตามชิปที่เลือกเป็นเป้าหมาย จากนั้นจึงวิเคราะห์ความเหมาะสมถึงการวางวงจรย่อยๆ เหล่านั้น ณ ตำแหน่งภายในชิปดังกล่าว ท้ายสุดเป็นขั้นตอนการเชื่อมต่อสัญญาณภายในชิปเข้าด้วยกัน
- 5. Download and Test เป็นการนำข้อมูลวงจรบันทึกลงชิป โดยใช้ไฟล์บิตสตรีม (.bit) ที่ได้จากขั้นตอน Design Implementation ก่อนหน้า

#### <u>การทดลอง</u>

1. ให้นักศึกษาสร้างวงจร 1-Bit Half Adder ดังรูปข้างล่างนี้ จนเสร็จสมบูรณ์ และทำการจำลองการทำงาน แล้วบันทึกผลการทดลองลงตาราง



บันทึกผลการทดลอง (สว่าง=1 ดับ=0)

| а | b | Х | у |
|---|---|---|---|
| 0 | 0 |   |   |
| 0 | 1 |   |   |
| 1 | 0 |   |   |
| 1 | 1 |   |   |

| วิเคราะห์ผลลัพธ์ที่ได้จากตา | าราง |      |  |
|-----------------------------|------|------|--|
|                             |      |      |  |
|                             |      | <br> |  |
|                             |      | <br> |  |
|                             |      |      |  |
|                             |      | <br> |  |
|                             |      | <br> |  |
|                             |      | <br> |  |

2. ให้นักศึกษาสร้างวงจรบวกเลขสองบิตดังรูปข้างล่างนี้ โดยเทียบเคียงจากขั้นตอนการใช้งานโปรแกรมตาม ข้อ 1 แล้วโปรแกรมลงบอร์ด FPGA โดยให้กำหนดอินพุทมาจากสวิทซ์เลื่อน และเอ้าท์พุทแสดงที่ LED บันทึกหมายเลข PIN และบันทึกผลการทดลองลงตาราง



- A หมายเลข PIN คือ P.......
- B หมายเลข PIN คือ P.......
- C หมายเลข PIN คือ P.......
- D หมายเลข PIN คือ P.......

- S0 หมายเลข PIN คือ P.......
- S1 หมายเลข PIN คือ P.......
- C1 หมายเลข PIN คือ P.......

### บันทึกผลการทดลอง (สว่าง=1 ดับ=0)

| SW0 | SW1 | SW2 | SW3 | LED0 | LED1 | LED2 |
|-----|-----|-----|-----|------|------|------|
| (A) | (B) | (C) | (D) | (C1) | (S1) | (S0) |
| 0   | 0   | 0   | 0   |      |      |      |
| 0   | 1   | 1   | 0   |      |      |      |
| 0   | 1   | 1   | 1   |      |      |      |
| 1   | 0   | 1   | 1   |      |      |      |
| 1   | 1   | 0   | 1   |      |      |      |
| 1   | 1   | 1   | 0   |      |      |      |
| 1   | 1   | 1   | 1   |      |      |      |

## ใบตรวจการทดลองที่ 4

| วัน/เดือน/ปี                           | 🗌 กลุ่ม 116 🔲 กลุ่ม 117 🔲 กลุ่ม 153 |  |
|----------------------------------------|-------------------------------------|--|
| รหัสนักศึกษา                           | _ชื่อ-นามสกุล                       |  |
| การตรวจการทดลอง                        |                                     |  |
| การทดลองข้อ 1 ลายเซ็นผู้ควบคุมการทดลอ  | ۹                                   |  |
| การทดลองข้อ 2 ลายเซ็นผู้ควบคุมการทดลอง |                                     |  |

หมายเหตุ ไม่รับ ใบตรวจการทดลองที่มีร่องรอยการแก้ไข ขูด ลบ ขีดฆ่า เปลี่ยนแปลงทุกชนิด