49
สิ่งที่จะได้จากการปฏิบัติการครั ้งนี้ คือ Nios II soft processor, JTAG UART, on-chip memory, PLLs, and an I2C interface. 1. Set up project! 1.1. ดาวน์โหลดไฟล์แลปจากเว็บไซต์ของรายวิชา จากนั้นสร ้าง directory ใหม่ขึ้นมาชื่อว่า gesture_labแล้วนาไฟล์แลปที่โหลดมา มาแตกไฟล์ใส่ไว้ 1.2. เปิดโปรแกรม Quartus II 15.0 (64-bit) เลือก File -> New Project Wizard 1.3. Browse ไปที่ ตัวอย่าง C:\DECA\workshop_labs\4_Gesture_Sensor_Lab Name of the project: gesture_lab Name of the top level entity: gesture_lab_top 1.4. หน้า Project Type เลือกเป็น Empty Project Gesture Sensor

Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

  • Upload
    others

  • View
    2

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

สิ่งท่ีจะได้จากการปฏิบตัิการครัง้นี ้คือ Nios II soft processor, JTAG UART, on-chip

memory, PLLs, and an I2C interface.

1. Set up project!

1.1. ดาวน์โหลดไฟล์แลปจากเว็บไซต์ของรายวิชา จากนัน้สร้าง directory ใหม่ขึน้มาช่ือว่า

‘gesture_lab’ แล้วน าไฟล์แลปท่ีโหลดมา มาแตกไฟล์ใส่ไว้

1.2. เปิดโปรแกรม Quartus II 15.0 (64-bit) เลือก File -> New Project Wizard

1.3. Browse ไปท่ี ตวัอย่าง C:\DECA\workshop_labs\4_Gesture_Sensor_Lab

Name of the project: gesture_lab

Name of the top level entity: gesture_lab_top

1.4. หน้า Project Type เลือกเป็น Empty Project

Gesture Sensor

Page 2: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

1.5. Add files ตามรูปต่อไปนี ้

1.6 ตัง้ค่า Devices Setting ให้ตรงกบับอร์ดท่ีเราใช้ โดยเลือกดงันี ้

1.7 จากนัน้เลือก Finish

Page 3: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

2. ต่อไปเป็นเร่ืองของ Hardware Design!

ภาพรวม จะเป็นการใช้ Qsys system integration tool ช่วยในการ design hardware system

โดยนิสิตจะได้ใช้ทัง้ standard และ custom components ในการเช่ือมต่ออินเตอร์เฟสต่างๆเข้า

ด้วยกนั, .ในการจดัการเร่ือง clocks, การตัง้ interrupt ต่างๆ รวมถึงการสร้าง HDL ให้ระบบ

2.1. เลือก tools -> Qsys เพ่ือเปิดหน้าต่างของ Qsys

2.2 หน้าต่างใหม่ท่ีเปิดขึน้มาจะแสดงส่วนประกอบต่างๆของระบบให้ดวู่ามีอะไรบ้าง

Page 4: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

2.3. ใส่ clock ให้กบัระบบโดย double click ท่ี clk_0. จากนัน้ตัง้ค่าพารามิเตอร์ clock

frequency ให้เป็น 50 MHz (50000000 Hz) ตามรูป จากนัน้กดปุ่ ม ‘X’ เพ่ือปิดหน้าต่าง

2.4. เปล่ียนช่ือ clk_0 ให้เป็น clk_50 โดยกด CTRL + R หรือคลิกขวาตามรูป

Page 5: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

2.5. File -> Save as… ตัง้ช่ือเป็น decs_top.qsys

3. Add a Nios II Processor!

เน่ืองจากพวกเราต้องการให้ Software ช่วย decode raw data ท่ีมาจาก Si1143 Gesture

Sensor IC. Nios จงึเป็นสิ่งจ าเป็นอย่างมากในแลปนี ้

3.1 ในส่วน IP Catalog, เลือกตามรูป (นิสิตสามารถใช้ค าสัง่ search หาเอาได้เช่นกนั)

Page 6: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

3.2 หลงัจากกดปุ่ ม Add แล้วจะมีหน้าต่างเด้งขึน้มา, ให้นิสิตเลือก option ‘Nios II/e’

3.3. In Vectors tab, จะกลบัมาตัง้ค่าในส่วนนีภ้ายหลงั ซึง่ตอนนีน้ิสิตอาจมีเออเร่อดงันี ้

3.4. ในส่วน tabs อ่ืนๆ นิสิตสามารถศกึษาการตัง้ค่าอ่ืนๆได้เพิม่เติมได้ด้วยตนเองได้

จากนัน้กด Finish

3.5 แก้ช่ือ Nios II เป็น nios2.qsys

4. Add On-Chip Memory!

Nios II จะเข้าถึงหน่วยความจ าท่ีมีความเร็วสงู เพ่ือใช้ในการรันโค้ดและเป็นท่ีส าหรับ

เก็บตวัโปรต่างๆ โดยตวัหน่วยความจ านีจ้ะอยู่ใน on-chip memory ซึง่ภายในจะมี RAM/ROM อยู่

4.1. ในหน้า IP Catalog ให้นิสิต Add ตามดงัรูป

Page 7: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

4.2. หน้า parameter editor จะถกูเปิดขึน้มา ให้นิสิตตัง้ค่าตามนี ้

4.3. คลิก Finish ซึง่อาจมีเออเร่อเกิดขึน้มาบ้าง ไม่ต้องเป็นกงัวลั ตอนนีใ้ห้เปล่ียนช่ือ

ส่วนประกอบนีใ้ห้เป็น onchip_ram

Page 8: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

5. JTAG UART Peripheral

ตรงส่วนนีท้ าให้เราสามารถ Debug โปรแกรมได้คล้ายๆกบัการ printf ออกมา โดยตวั

JTAG UART จะต่อเข้ากบั Nios II processor และสามารถควบคมุได้ผ่านตวั IDE ของมนั

5.1. ส่วน IP Catalog, เลือกตามรูป หรือ เสริชว่า jtag

Page 9: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

5.2. ในหน้า parameter editor ให้ตัง้ค่าตามรูป

5.3. เช่นเดิม อาจจะมีเออเร่อเกิดขึน้มาบ้าง ให้ปล่อยผ่านไปก่อน และตัง้ช่ือส่วนประกอบนี ้

ว่า jtag_uart

6. Add a PLL

จะใช้เป็นตวัสร้าง clock ให้ Qsys system

6.1 ในหน้า IP Catalog ให้เลือกตามรูป หรือเสริชว่า

Avalon ALTPLL

Page 10: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

6.2. ในหน้า Parameter Setting -> General/Modes tab, ให้เปล่ียน clock frequency

เป็น 50 MHz (ซึง่เป็นค่าท่ีมากท่ีสดุแล้วท่ีตวั oscillator บนบอร์ดอนญุาต)

6.3. ในหน้า Parameter Settings -> Inputs/Lock tab, ติก้ถกูแค่ตรง Create ‘locked’

output เท่านัน้!!!

Page 11: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

6.4 ในส่วนของ Output Clocks/clk tab, ให้เปิดใช้งานเฉพาะ c0 โดยตัง้ค่าตามรูป

(50 MHz * 2 multiplication factor = 100 MHz)

6.5. กด Finish ได้เลย โดยไม่ต้องสนใจ errors ก่อน, จากนัน้เปล่ียนช่ือ PLL ให้เป็น pll_qsys

Page 12: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

6.6. เน่ืองจากเรา enable ตวั locked output ไว้ก่อนหน้านี ้เราจงึจ าเป็นต้องเพิม่ input

port ไปให้ระบบ Qsys ของเรา ให้ท าตามรูปจะเป็นการเปิดพอร์ตการเช่ือมต่อด้าน output กบั

user logic โดยการ Double click ส่วน export column ซึง่อยู่ใกล้กบั external_connection

จากนัน้ให้พมิพ์ว่า pll_qsysy_locked

7. Add a timer!

จะเป็นตวั periodic interrupts เพ่ือปอ้งกนัการเกิด system lockups

7.1. เช่นเดิม, IP Catalog ให้เสริชว่า timer และตัง้ค่าในส่วน parameter editor ดงัรูป

Page 13: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

7.2. กด Finish โดยไม่ต้องสนใจ warnings/erorrs ใดๆทัง้สิน้ เราจะกลบัมาแก้ทัง้หมดใน

ภายหลงัทีเดียว

7.3. เปล่ียนช่ือตวั timer ให้เป็น timer_qsys

Page 14: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

8. Add a System ID Peripheral!

8.1. IP Catalog เลือก system id ตามรูป และตัง้ค่า parameter editor ตามรูปเช่นกนั

Page 15: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

8.2. เลือก Finish, ไม่ต้องสนใจ errors, เปล่ียนช่ือในส่วนนีเ้ป็น sysid_qsys

9. Add an Interrupted Pin!

เป็นตวัท่ีใช้ Interrupt ใน Gesture sensor เพ่ือประโยชน์ในหลายๆอย่าง เช่นเม่ือตวัวดัค่า

วดัค่าได้เกินค่า threshold ท่ีโปรแกรมเมอร์ตัง้ไว้ ทัง้นีเ้พราะตวั I2C bus ไม่มี interrupt เป็นของ

ตวัเอง

9.1. เลือก PIO ใน IP Catalog และตัง้ค่าในหน้าต่าง Parameter editor ดงัรูป

Page 16: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

9.2. เลือก Finish, เปล่ียนช่ือเป็น pio_0

9.3. ต้อง Add ส่วนนีเ้ข้ากบั Qsys system เพ่ือท่ีจะสามารถเช่ือมต่อกบั external pin ได้

เช่นเดียวกบัขัน้ตอน 6.6 ให้ Doucle-click ท่ี export column ข้าง external_connection ท่ีเป็น

ของ pio_0 แล้วพมิพ์ไปว่า i2c_irq

Page 17: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

10. Add an I2C Peripheral!

I2C bus ใช้ใน Gesture Sensor เพิม่คยุกบัโฮสต์, I2C controller ใช้ควบคมุอีกทีนงึ

10.1. IP Catalog, เลือก i2c ดงัรูป

10.2. จากนัน้คลิก Finish ได้เลย เพราะไม่มีอะไรให้ตัง้ค่าในหน้า Parameter Editor

10.3. เปล่ียนช่ือ component เป็น i2c_opencores_0

10.4. เช่นเดิม เราจ าเป็นต้อง add i2c เข้ากบั Qsys system ให้ท าตาม 9.3. ได้เลย แต่ให้

ท าในส่วนของ i2c_opencores_0 พมิพ์ไปว่า i2c_pins

Page 18: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

11. เช่ือมต่อเข้ากบั Qsys system และก าจดั errors!

Errors ต่างๆ ก่อนหน้านีเ้กิดจากการท่ี Avalon interface และ ตวัประกอบต่างๆ แม้กระทัง่

Clock, resets ต่างๆนัน้ ไม่ได้ถกูเช่ือมต่อเข้ากบั Qsys system โดยสมบรูณ์

11.1. เปิดหน้าต่าง Nios II Processor ขึน้มาและคลิกขวาท่ี clk จากนัน้ให้เลือกตามรูป

ซึง่จะเป็นการเช่ือม clk input เข้ากบั c0 ของ PLL ท่ีเราเคยคอนฟิกเอาไว้

หมายเหตุ: สญัญาณต่างๆจะถกูอ้างถึงด้วย format ดงันี ้<component_name.signal_name>

โดย component_name จะเป็นการอ้างถึงส่วน Name column ใน Qsys โหมด System

Contents และ signal_name จะเป็นการอ้างถึงอินเตอร์เฟสใน component นัน้ๆ

Page 19: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

11.2. ให้ Connect signal ท่ีเหลือตามตารางด้านล่างด้วยวิธีเดียวกนั โดยบางสญัญาณ

อาจมีมากกว่า 1 connections

Page 20: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

12. Set Interrupt Priorities!

ซึง่ Nios II Processor มีถึง 32 independent interrupts (IRQs) ซึง่สามารถถกู assign

ล าดบัความส าคญัต่างๆได้ แต่ระบบท่ีเราท ากนัอยู่นัน้มีเพียง 4 interrupts เท่านัน้ ซึง่การ

ก าหนดค่าความส าคญัสามารถท าตามได้ดงันี ้

12.1. ในหน้าจอของ Qsys เลือก System -> Assign Interrupt Numbers

Page 21: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

12.2. การตัง้ค่า Priority สามารถกระท าได้โดยการดบัเบิล้คลิกเข้าไปท่ี Column IRQ ได้

เลย (0 จะหมายถึงล าดบัความส าคญัสงูสดุ)

12.3 โดยขอให้นิสิตตัง้ค่าล าดบัความส าคญัของ 4 interrupts ตามนี ้

13. ก าหนด Nios II Reset และ Exception Vectors

จ าเป็นต้องมี memory location ให้เม่ือ processor มีการ reset/exception ขึน้ ซึง่ใน

ขัน้ตอนนีจ้ะเป็นการจดัการกบัเร่ืองดงักล่าว

13.1. การก าหนด vectos เหล่านี,้ สามารถกระท าได้โดยการดบัเบิล้คลิก nios2_qsys ใน

หน้า Nios II component ซึง่จะเป็นการเปิดตวั Parameter Editor ขึน้มา

Page 22: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

13.2. ให้เลือก Vector tab, จากนัน้ตัง้ค่าในส่วนทัง้ของ reset vector memory และ

exception vector memory ให้เป็น onchip_ram.s1 ซึง่จะได้ดงัรูป โดยค่า offset อาจจะต่างกับ

ในรูป ไม่ต้องท าอะไรกับมันก่อน เราจะแก้ในหวัข้อถัดไป

13.3. ปิดตวั parameter editor และเตรียมตวัส าหรับการแก้ errors ในขัน้ตอนต่อไป

Page 23: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

14. จดัการ Memory Address

ในแตล่ะ components ของ Qsys system นั 3น เราจําเป็นจะต้องระบ ุmemory address ให้มนั เพื?อที?จะทําให้ components อื?นๆ นั 3นสามารถ เข้าถงึข้อมลูของ components นี 3ได้ ซึ?งจะมีสองแบบ คือ automatically กบั manually โดยในที?นี 3เราจะทําแบบ manually โดยเริ?มจาก เลอืก System -> Assign Base Addresses

14.1 double-click ที่ hex address โดยเลือก base column ของ System Contents tab ที่อยู่ถัดจาก debug_mem_slave signal และใส่ค่า 0x0008_0800 เพื่อเปลี่ยน base address ของ component

14.2 ทำตามขั้นตอนที่ 14.1 กับ component ในตาราง

Page 24: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

Component Base Address

nios2_qsys 0x0008_0800

timer_qsys 0x0008_1020

pll_qsys 0x0000_0000

onchip_ram 0x0004_0000

i2c_opencores_0 0x0008_1000

jtag_uart 0x0008_1058

sysid_qsys 0x0008_1050

pio_0 0x0008_1040

Page 25: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

15. ตรวจสอบระบบทั 3งหมด

15.1 ตรวจสอบ Qsys system อีกรอบวา่เหมือนดงัรูปข้างลา่ง (ไมต้่องสนใจลาํดบั)

15.2 ตรวจสอบให้แนใ่จวา่ไมมี่ error messages in the Messages tab. และมีเพียง 2 warning messages ดงัรูปข้างลา่งนี 3เทา่นั 3น

Page 26: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

16 Generate the Qsys System

เป็นการ generate HDL (hardware description language) code จาก Qsys system

16.1 เลอืก Generate -> Generate HDL

16.2 จะมีหน้าตา่ง generate ขึ 3นมา ให้เลอืกภาษาเป็น verilog และเลอืก None จากปุ่ ม drop down simulation model.

Page 27: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

16.3 กดปุ่ ม Generate. Qsys จะทําการสร้าง HDL ที?จําเป็น มารวมเข้าด้วยกนั. เมื?อสร้างเสร็จแล้ว ให้กดปิดได้เลย

17. เพิ่ม Qsys System ไปยัง Quartus Project

17.1 กดปุ่ม “X” ขวาบนของหน้าต่าง Qsys เพื่อปิด. จะมีหน้าต่าง ของ Quartus II ขึ้นมาเพื่อบอกให้เราเพิ่ม Qsys system ไปยัง project. [1]

17.2 คลิกปุ่ม OK และ เลือก Project -> Add/Remove Files in Project จาก Quartus II Menu.

17.3 คลิก “...” และ directory ของ systhesis ที่เพิ่งปรากฏในรูป (1) และเลือกไฟล์ deca_top.qip

Page 28: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

17.4 คลิกปุ่ม “Add” เพื่อแอดไฟล์ .qip ไปยังโปรเจ็ค. คลิก “Apply” and “OK”

18. Modify the Top-Level Design File

top-level design file บางส่วนนั้นได้สร้างให้เรียบร้อยแล้วแต่มีบางส่วนนั้นที่เราจำเป็นจะต้องแก้ไขเพื่อที่จะทำให้ compile ผ่าน

18.1 ดับเบิ้ลคลิก top-level design entity, geasure_lab_top, ของ Hierarchy tab ไฟล์ geasure_lab_top.v ที่ได้เคยเพิ่มไปในโปรเจ็คนั้นควรจะขึ้นมาในหน้าต่างนี้

18.2 ให้ดูบน top-level file และมองหา ports, wire declarations, และ structural coding. และให้ไปที่บรรทัดที่ 198 ของไฟล์ จะเห็นได้ว่า signal ที่ได้ export มาจาก Qsys นั้นแสดงอยู่

18.3 Uncomment บรรทัด ที่ 187-190 และ เพิ่ม signal names สำหรับ I2C signals และ PLL locked signal.

Page 29: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

18.4 คลิก File -> Save All

19 Import Pin Assignments

โดยปกติแล้ว การกำหนด pin สำหรับการ design จำเป็นต้องกำหนดด้วยตัวเอง. แต่สำหรับ DECA board มี pin คงที่ ทำให้เราสามารถ import pin config เข้ามาใช้งานได้เลย

19.1 คลิกที่ Assignments -> Import Assignments19.2 คลิกที่ “...” และ เลือก DECA_golden_top.csv. คลิก OK. Quartus II จะขึ้นข้อความ มาว่า

563 assignments imports.

Page 30: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

19.3 เปิด Pin Planner จาก Assignments -> Pin Planner. ดูที่ pin assignments ที่ signal ขึ้นต้นด้วย LIGHT. signals เหล่านี้คือ I2C signals ไปยัง Si1143 Sensor

19.4 คลิก ปุ่ม “X” ขวาบนเพื่อปิด Pin Planner

20. Compile the Quartus II Project

เราได้ทำ hardware design เรียบร้อยแล้ว แต่ยังมี device settings บางส่วน จำเป็นต้องเปลี่ยนแปลง และ โปรเจค จึงจะสามารถคอมไพล์ เพื่อสร้าง configuration file ได้

20.1 เปิด Device settings จาก Assignments -> Device… และ คลิก “Device and Pin Options”

20.2 Unselect checkboxes ดังรูป

Page 31: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

20.3 เลือก category: configuration และเลือก configuration mode เป็น single uncompressed image ดังรูป

� 20.4 ทำการ compile โดยเลือก Processing -> Start Compilation

Page 32: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

20.5 หลังจากผ่านไปซักพักแล้วควรจะขึ้นหน้าจอดังนี้

� 21. Download the configuration file ไปยัง DECA

หลังจากที่ได้ configuration ไฟล์จากการ compile แล้ว. เราก็จะมาโปรแกรม DECA ต่อ

21.1 เปิด Quartus II Programmer จาก Tool -> Programmer หรือ ดับเบิ้ลคลิก บน Program Devices จาก Tasks pane. เนื่องจากเรายังไม่ได้ต่อ DECA, หน้าต่าง Programmer จะแสดงหน้าต่าง configuration โล่งๆ.

Page 33: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

21.2 ต่อ DECA board มายัง PC ด้วย USB cable. ตรวจสอบให้แน่ใจว่า เชื่อม mini-USB เรียบร้อยแล้ว เนื่องจากเราได้ลง USB Blaster II driver ได้ลงเรียบร้อยแล้ว. Windows Device Manager ควรจะแสดง ดังรูป

� เราควรจะเห็น แสดง LED บางส่วนแสดงขึ้นมาบน DECA รวมถึง blue LED 3.3V และ green LED ที่ label ไว้ว่า CONF_D

21.3 ในหน้าต่าง Programmer, เลือก Hardware Setup และดับเบิ้ลคลิก Arrow MAX10 DECA entry ใน Hardware pane. Currently selected hardware: ควรเป็น ดังรูป

21.4 คลิก “Add File..” เลือกไปยัง “<project_directory>/output_files/“ ใน compilation directory. เลือกไฟล์ gesture_lab_top.sof

Page 34: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

21.5 ตรวจสอบให้แน่ใจว่า หน้าต่าง Programmer แสดงถูกไฟล์ และ JTAG ถูกต้อง

21.6 ตรวจสอบให้แน่ใจนะ Program/Configuration checkbox ได้ checked เรียบร้อยแล้ว และ คลิก Startเพื่อเริ่ม DECA. เราควรจะเป็น CONF_D LED ทำการกระพริบ เป็นการบ่งบอกว่าทำการ configuration เรียบร้อยแล้ว และ progress bar เป็น 100%

22. เปิด Nios II Software Build Tools for Eclipse

22.1 จากหน้าต่างหลักของ Quartus, เปิด SBT จาก Tools -> Nios II Software Build Tools for Eclipse

Page 35: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

Page 36: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

22.2 สร้าง workspace ตามที่ๆเราต้องการ เช่นดังรูป

23 สร้าง New Software Project 23.1 เลือก File -> New -> Nios II Application and BSP from Template

Page 37: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

23.2 คลิก “...” และเลือก deca_top.sopcinfo จาก project directory และเรียก โปรเจค lab_work. เลือก Blank Project จาก templates section. ตรวจสอบว่า settings ต่างๆเป็นดังรูป

Page 38: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

23.3 Eclipse จะสร้าง 2 directories ใน workspace ; สำหรับ application และอีก directory สำหรับ BSP. ใน BSP directory (lab_work_bsp) จะมี software drivers, system.h, source code เริ่มต้น และ software ของ infrastructure ต่างๆ

24 เพิ่ม Source Code ไปยัง Project

24.1 เปิด Folder <project_directory>/sw_src/. ก๊อบไฟล์ C source และ headers ไฟล์ไปยัง lab_work ใน eclipse และ click “OK”

Page 39: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

Page 40: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

25 Configure the Board Support Package

25.1 คลิกขวา folder lab_work_bsp เลือก Nios II -> BSP Editor จาก popup-menu

Page 41: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

25.2 เมื่อ Nios BSP Editor เปิดขึ้นมา ในหน้าต่าง Main-> Settings -> Common ตรวจสอบว่าเป็นดังรูป

25.3 คลิกปุ่ม “Generator” เพื่ออัพเดท BSP และ เลือก File -> Exit เพื่อปิด หลังจาก ที่ generate เสร็จแล้ว

Page 42: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

25.4 แก้ BSP Settings ส่วนที่เหลือ. คลิกขวาที่ lab_work_bsp เลือก Properties

Page 43: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

25.5 ในหน้าต่าง Properties เลือก Nios II BSP Properties tab. เลือก Optimization Level เป็น 2 enable “Reduced device driver” และ disable “Support C++” เนื่องจากเราไม่มีการใช้ C++ ในที่นี้

25.6 เลือก Apply และ คลิก “OK”

Page 44: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

26 Configure the Application Project

26.1 คลิกขวาที่ lab_work และเลือก properties เลือก Nios Application Properties tab และเลือก Optimization Level เป็น 2

� 26.2 เลือก Apply และ กด OK

27 Build the Software Project สร้าง executable ไฟล์ที่ใช้ในการรันบน DECA

Page 45: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

27.1 คลิกขวาที่ lab_work_bsp เลือก Build Project

27.2 คลิกขวาที่ lab_work เลือก build project

Page 46: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

� ถ้าหากไม่มี errors แปลว่า เราได้ compiled สำเร็จเรียบร้อยแล้ว

Page 47: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

28 Download executable to the DECA

28.1 คลิกขวาที่ lab_work เลือก Run As -> Nios II Hardware

Page 48: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

Note: ถ้าหากหน้าต่าง Run Configuration dialogue ปรากฏขึ้นมา เราอาจจะต้อง คลิก Target Connection tab และ คลิก “Refresh Connections”. และ คลิก Run

28.2 หลังจากผ่านไปซักพัก Nios II Console จะเปิดขึ้นมาที่ข้างล่างของโปรแกรม Eclispe

� 28.3 ทำการพลิก board ให้ MAX10 หันหน้าลง

Page 49: Gesture Sensor - Kasetsart Universityparuj/204224/final_practice...Gesture ส งท จะได จากการปฏ บ ต การคร งน ค อ Nios II soft processor,

28.4 ทำการขยับมือ หลัง DECA โดยห่างประมาณ 2-3 นิ้ว จาก board โดยทำมุม 90 องศา จากขอบของ board. โดยการขยับมือแต่ละครั้งประมาณ 0.5 วิ ก็ควรจะเห็น ข้อความขึ้นในหน้าต่าง console

เชื่อมต่อ LED เข้ามาในระบบ แล้วให้การแสดงผลของ Gesture sensor ไปปรากฏที ่ LED โดยให้กําหนด

29 ทำแบบฝึกหัดต่อไปนี้เพื่อทดสอบว่านิสิตเข้าใจเรื่องการเชื่อมต่อและการโปรแกรม

สร้างโค๊ดไบนารีที่จะใช ้ LED แสดงผลแทน UP DOWN LEFT RIGHT ด้วยตนเอง