สารบัญ:
2025 ผู้เขียน: John Day | [email protected]. แก้ไขล่าสุด: 2025-01-13 06:58
เชื่อมต่อบอร์ดพัฒนา Mojo ของคุณกับอินพุตภายนอกด้วยโล่นี้
คณะกรรมการพัฒนา Mojo คืออะไร?
คณะกรรมการพัฒนา Mojo เป็นคณะกรรมการพัฒนาที่ใช้ Xilinx spartan 3 FPGA กระดานทำโดย Alchitry FPGA มีประโยชน์มากเมื่อต้องดำเนินการหลายกระบวนการพร้อมกัน
คุณจะต้องการอะไร?
เสบียง
คณะกรรมการพัฒนาโมโจ
ไฟล์เกอร์เบอร์
ตัวต้านทาน 8 x 15k ohm (อุปกรณ์เสริม*)
ตัวต้านทาน 4 x 470 โอห์ม
ตัวต้านทาน 4 x 560 โอห์ม
4 x CC เจ็ดส่วนแสดง
ไฟ LED 4 x 3 มม.
สวิตช์สัมผัส 4 x SPDT
สวิตช์ DIP แบบติดตั้งบนพื้นผิว 1 x 4 ตำแหน่ง
2 x 25 x 2 หรือ 4 x 25 ส่วนหัว
หัวกล่องขนาด 1x2 x 5 พิน
หัวแร้ง
ประสาน
ฟลักซ์
*(หากละเว้นตัวต้านทานเหล่านี้ภายใน pullup/pulldown ต้องเปิดใช้งานสำหรับพินที่เกี่ยวข้อง)
ขั้นตอนที่ 1: อัปโหลด Gerber ไปยังผู้ผลิต Pcb ที่คุณเลือก
สำหรับบอร์ดของฉัน ฉันสั่งจาก JLC PCB
การเปลี่ยนแปลงเพียงอย่างเดียวที่ฉันทำคือสีที่ฉันต้องการให้เข้ากับสีดำของ Mojo
ขั้นตอนที่ 2: การประกอบบอร์ด
เมื่อทำการบัดกรี ฉันพบว่ามีประโยชน์ในการประสานชิ้นส่วนที่ต่ำที่สุดก่อนเสมอ ดังนั้นการเริ่มด้วยตัวต้านทานจึงเป็นความคิดที่ดี
R5, R6, R7, R8, R9, R10, R11 และ R12 เป็นตัวต้านทาน 15k ohm ที่ใช้ในการดึงสวิตช์ลง (หากคุณใช้ pullup/pulldown ภายในไม่ต้องสนใจสิ่งนี้)
R1, R2, R3, R4 เป็นตัวต้านทาน 560 โอห์ม ซึ่งมีหน้าที่จำกัดกระแสผ่านจอแสดงผล 7 ส่วน
R13, R14, R15, R16 เป็นตัวต้านทาน 470 โอห์ม ซึ่งมีหน้าที่จำกัดกระแสผ่าน LED 4 ตัว
ถัดไปประสานสวิตช์จุ่ม สวิตช์สัมผัส ไฟ LED จอแสดงผลเจ็ดส่วน และขั้วต่อส่วนหัวของกล่องในลำดับนั้น
ตอนนี้วาง 25 คูณ 2 (หรือ 2 25 คูณ 1) ลงในโมโจเพื่อจัดตำแหน่งหมุด จัดแนวโล่กับหมุดและประสานเข้าที่
ขั้นตอนที่ 3: ตั้งค่าซอฟต์แวร์
สำหรับซอฟต์แวร์ที่อ้างอิงถึงเว็บไซต์ Alchitry จะแจ้งให้คุณทราบถึงสิ่งที่คุณต้องเริ่มต้นและติดตั้ง Xilinx ISE อย่างไรก็ตาม การเปลี่ยนไฟล์.ucf เพื่อให้รู้ว่าพินใดบ้างที่เชื่อมต่อกับสิ่งสำคัญในการทำให้โปรแกรมของคุณทำงาน
นี่คือไฟล์.ucf ที่ฉันใช้กับโล่:
กำหนดค่า VCCAUX=3.3;
NET "clk" TNM_NET = clk; TIMESPEC TS_clk = PERIOD "clk" 50 MHz สูง 50%; NET "clk" LOC = P56 | IOSTANDARD = LVTTL; NET "rst_n" LOC = P38 | IOSTANDARD = LVTTL; NET "cclk" LOC = P70 | IOSTANDARD = LVTTL; NET "spi_mosi" LOC = P44 | IOSTANDARD = LVTTL; NET "spi_miso" LOC = P45 | IOSTANDARD = LVTTL; NET "spi_ss" LOC = P48 | IOSTANDARD = LVTTL; NET "spi_sck" LOC = P43 | IOSTANDARD = LVTTL; NET "spi_channel" LOC = P46 | IOSTANDARD = LVTTL; NET "spi_channel" LOC = P61 | IOSTANDARD = LVTTL; NET "spi_channel" LOC = P62 | IOSTANDARD = LVTTL; NET "spi_channel" LOC = P65 | IOSTANDARD = LVTTL; NET "avr_tx" LOC = P55 | IOSTANDARD = LVTTL; NET "avr_rx" LOC = P59 | IOSTANDARD = LVTTL; NET "avr_rx_busy" LOC = P39 | IOSTANDARD = LVTTL; NET "Q[0]" LOC = P26 | IOSTANDARD = LVTTL; NET "Q[1]" LOC = P23 | IOSTANDARD = LVTTL; NET "Q[2]" LOC = P21 | IOSTANDARD = LVTTL; NET "Q[3]" LOC = P16 | IOSTANDARD = LVTTL; NET "S[0]" LOC = P7 | IOSTANDARD = LVTTL; NET "S[1]" LOC = P9 | IOSTANDARD = LVTTL; NET "S[2]" LOC = P11 | IOSTANDARD = LVTTL; NET "S[3]" LOC = P14 | IOSTANDARD = LVTTL; NET "pb[1]" LOC = P30 | IOSTANDARD = LVTTL; NET "pb[2]" LOC = P27 | IOSTANDARD = LVTTL; NET "pb[3]" LOC = P24 | IOSTANDARD = LVTTL; NET "pb[4]" LOC = P22 | IOSTANDARD = LVTTL; NET "เซก้า[0]" LOC = P57 | IOSTANDARD = LVTTL; NET "sevsegb[0]" LOC = P58 | IOSTANDARD = LVTTL; NET "sevsegc[0]" LOC = P66 | IOSTANDARD = LVTTL; NET "sevsegd[0]" LOC = P67 | IOSTANDARD = LVTTL; NET "sevsege[0]" LOC = P74 | IOSTANDARD = LVTTL; NET "sevsegf[0]" LOC = P75 | IOSTANDARD = LVTTL; NET "sevsegg[0]" LOC = P78 | IOSTANDARD = LVTTL; NET "sevsegdp[0]" LOC = P80 | IOSTANDARD = LVTTL; NET "เซก้า[1]" LOC = P82 | IOSTANDARD = LVTTL; NET "sevsegb [1]" LOC = P83 | IOSTANDARD = LVTTL; NET "sevsegc [1]" LOC = P84 | IOSTANDARD = LVTTL; NET "sevsegd[1]" LOC = P85 | IOSTANDARD = LVTTL; NET "sevsege [1]" LOC = P87 | IOSTANDARD = LVTTL; NET "sevsegf [1]" LOC = P88 | IOSTANDARD = LVTTL; NET "sevsegg [1]" LOC = P92 | IOSTANDARD = LVTTL; NET "sevsegdp [1]" LOC = P94 | IOSTANDARD = LVTTL; NET "เซก้า[2]" LOC = P97 | IOSTANDARD = LVTTL; NET "sevsegb [2]" LOC = P98 | IOSTANDARD = LVTTL; NET "sevsegc [2]" LOC = P99 | IOSTANDARD = LVTTL; NET "sevsegd [2]" LOC = P100 | IOSTANDARD = LVTTL; NET "sevsege [2]" LOC = P101 | IOSTANDARD = LVTTL; NET "sevsegf [2]" LOC = P102 | IOSTANDARD = LVTTL; NET "sevsegg [2]" LOC = P104 | IOSTANDARD = LVTTL; NET "sevsegdp [2]" LOC = P111 | IOSTANDARD = LVTTL; NET "เซก้า[3]" LOC = P114 | IOSTANDARD = LVTTL; NET "sevsegb[3]" LOC = P115 | IOSTANDARD = LVTTL; NET "sevsegc[3]" LOC = P116 | IOSTANDARD = LVTTL; NET "sevsegd[3]" LOC = P117 | IOSTANDARD = LVTTL; NET "sevsege[3]" LOC = P118 | IOSTANDARD = LVTTL; NET "sevsegf[3]" LOC = P119 | IOSTANDARD = LVTTL; NET "sevsegg[3]" LOC = P1120 | IOSTANDARD = LVTTL; NET "sevsegdp[3]" LOC = P121 | IOSTANDARD = LVTTL;
จำไว้ว่าถ้าคุณไม่ได้ติดตั้งตัวต้านทานแบบดึงลงเพื่อแก้ไขพินในไฟล์.ucf ด้วย
| ดึงลงมา; o
| ดึงขึ้น;
หากคุณต้องการใช้บล็อกเพื่ออะไรก็ตาม การเชื่อมต่อมีดังนี้ ซ้ายเป็นหมายเลขพินบล็อกและขวาเป็นหมายเลขพินโมโจที่คุณควรกำหนดใน. ucf ของคุณ:
พิน 1 = 29
พิน 2 = 51
พิน 3 = 32
พิน 4 = 41
พิน 5 = 34
พิน 6 = 35
พิน 7 = 40
พิน 8 = 33
พิน 9 = GND
พิน 10 = +V