Mojo FPGA Development Board Shield: 3 trinn
Mojo FPGA Development Board Shield: 3 trinn
Anonim
Mojo FPGA Development Board Shield
Mojo FPGA Development Board Shield

Koble Mojo -utviklingsbordet til eksterne innganger med dette skjoldet.

Hva er Mojo utviklingstavle?

Mojo utviklingsbord er et utviklingsbord basert på Xilinx spartan 3 FPGA. Brettet er laget av Alchitry. FPGA er veldig nyttige der flere prosesser må utføres samtidig.

Hva trenger du?

Rekvisita

Mojo utviklingstavle

Gerber -fil

8 x 15k ohm motstander (valgfritt*)

4 x 470 ohm motstander

4 x 560 ohm motstander

4 x CC syv segment displayer

4 x 3 mm lysdioder

4 x SPDT taktile brytere

1 x 4 -posisjon overflatemonteret DIP -bryter

2 x 25 x 2 eller 4 x 25 overskrifter

1x 2 x 5 -pinners bokshode

Loddejern

Lodding

Flux

*(hvis disse motstandene utelates må intern pullup/nedtrekning være aktivert for relevante pinner)

Trinn 1: Last opp Gerber til PCB -produsenten du ønsker

Last opp Gerber til PC -produsenten du ønsker
Last opp Gerber til PC -produsenten du ønsker

For brettene mine bestilte jeg fra JLC PCB.

Den eneste endringen jeg gjorde var fargen jeg ønsket å matche den svarte på Mojo.

Trinn 2: Styremøte

Styremøte
Styremøte

Ved lodding er det alltid nyttig å lodde de laveste delene først, så det er en god idé å begynne med motstandene.

R5, R6, R7, R8, R9, R10, R11 og R12 er 15k ohm motstander som brukes til å trekke bryterne ned (hvis du bruker intern pullup/pulldown, ignorer dette).

R1, R2, R3, R4 er 560 ohm motstander som er ansvarlige for å begrense strømmen gjennom 7 segmenters display.

R13, R14, R15, R16 er 470 ohm motstander som er ansvarlige for å begrense strømmen gjennom de 4 lysdiodene.

Neste loddetinn dip -bryteren, taktile brytere, LED -er, syv segmentdisplayer og bokshodekontakt i den rekkefølgen.

Plasser nå 25 x 2 (eller 2 25 x 1) i mojo for å justere pinnene. Rett inn skjoldet med pinnene og lodd det på plass.

Trinn 3: Programvareoppsett

For programvare som refererer til Alchitry -nettstedet, gir deg beskjed om hva du trenger for å komme i gang og installere Xilinx ISE. Imidlertid endrer.ucf -filen slik at den vet hvilke pins som er koblet til det som er viktig for å få programmet til å kjøre.

Her er.ucf -filen jeg bruker med skjoldet:

KONFIG VCCAUX = 3,3;

NET "clk" TNM_NET = clk; TIMESPEC TS_clk = PERIODE "clk" 50 MHz HØY 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 "sevsega [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 "sevsega [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 "sevsega [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 "sevsega [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;

Husk hvis du ikke har installert nedtrekksmotstandene for å redigere pinnene i.ucf med

| TREKKE NED; o

| PULLUP;

Hvis du vil bruke blokken til noe, er tilkoblingene som følger. Venstre er blokkeringsnummeret og høyre er mojo -pin -nummeret som du bør tilordne i.ucf:

pin 1 = 29

pin 2 = 51

pin 3 = 32

pinne 4 = 41

pin 5 = 34

pin 6 = 35

pinne 7 = 40

pin 8 = 33

pin 9 = GND

pin 10 = +V