Sisällysluettelo:
- Vaihe 1: Projektin perustaminen Vivadoon Ernielle
- Vaihe 2: Ernyn PWM: n luominen Vivadossa
- Vaihe 3: Ernyn TDOA: n luominen Vivadossa
- Vaihe 4: Ernie -kääriminen ja vieminen
- Vaihe 5: Ernin rakentaminen
- Vaihe 6: Ernie's First BSP
- Vaihe 7: FreeRTOS -käyttö Ernie
- Vaihe 8: Ernien C -koodin tuominen
- Vaihe 9: Virheenkorjaus Ernie
- Vaihe 10: Ernyn tekeminen itsenäiseksi
- Vaihe 11: Tee Ernie söpöksi
2025 Kirjoittaja: John Day | [email protected]. Viimeksi muokattu: 2025-01-23 14:41
Tämä on opetusohjelma Ernyn, itsenäisen ääniseurantarobotin rakentamisesta Zybo Boardin avulla. Se kattaa, miten: luoda projekti Vivadoon, luoda PWM: n kaltaisia servomoottorin ohjaimia FPGA: han, liitäntä kahdella äänianturilla, luoda saapumisaika-aikaero, käyttää freeRTOSia ja käyttää zyboota akusta. Tämä oli viimeinen projektimme Cal Poly SLO: n reaaliaikaisten käyttöjärjestelmien luokalle (CPE 439).
Varusteluettelo:
- 1 - ZYBO Zynq 7000 -kehityslautakunta
- 2 - Parallax Continuous Rotation Servo
- 2 - Äänianturi (SparkFun Sound Detector)
- 1 - 5 V: n litium -ioni -USB -akku (kortille)
- 4 - AA -paristot (servot)
- 1 - AA -paristo (4 paristoa)
- 1 - Micro -USB -kaapeli
- 1 - Leipälevy
- monet - uros -urosjohdot
- 1 - Servo -alusta
Ohjelmistovaatimukset:
- Xilinx Vivado Design Suite 2016.2
- Digilent Adept 2.16.1
Vaihe 1: Projektin perustaminen Vivadoon Ernielle
- Ohjattu toiminto avautuu
- Napsauta Seuraava
-
Nimeä seuraavaksi projekti
- Älä koskaan käytä projektin nimeä tai hakemistopolkua, jossa on välilyöntejä !!!!!
- Tästä tulee RTL -projekti.
- Emme halua määrittää lähteitä
-
Seuraava -painiketta napsauttamalla pääsemme Osasivulle. Käytämme mallia ZYNQ XC7Z010-1CLG400C.
- Vivadolla ei ole Zboota listattuna yhdeksi sen ennalta määritetyistä levyistä. Valitse: "osat" ja etsi sitten xc7z010clg400-1.
- Jos valitset väärän osan vahingossa, voit helposti vaihtaa siruja: Työkalut -> Projektiasetukset -> Yleiset ja napsauta "Project Device" -kohdan oikealla puolella olevia pisteitä
-
Napsauta Luo lohkosuunnittelu.
Nimeä se design_1 nyt
- Näet vihreän palkin, jossa lukee Lisää IP, napsauta sitä.
-
Etsiä Zynq.
- Kaksoisnapsauta ZYNQ7 -prosessointijärjestelmää,
- Tämä lohko näkyy lohkon suunnittelussa.
- Näet vihreän palkin, jossa lukee Suorita lohkoautomaatio, napsauta sitä.
- Lataa zybo_zynq_def.xml alla.
-
Napsauta Vivadossa "Tuo XPS -asetukset" ja valitse "zybo_zynq_def.xml"
Tämä esitäyttää Vivado-lohkon kokoonpanon kaikilla Zybo-kortin sisäänrakennetuilla oheislaitteilla ja nastojen määrityksillä
-
Kaksoisnapsauta ZYNQ -lohkoa.
-
MIO -kokoonpano
- Ota ajastin 0 käyttöön (Sovellusprosessoriyksikkö - img 1)
- Ota vahtikoira käyttöön (Sovellusprosessoriyksikkö- kuva 1)
- Ota GPIO-> GPIO MIO käyttöön (Sovellusprosessoriyksikkö - img 2)
- Ota GPIO-> ENET-nollaus käyttöön (I/O-oheislaitteet- kuva 2)
-
Kellon määritys
Poista FCLK0 käytöstä (PL -kangaskellojen alla - img 3)
-
- Napsauta OK.
-
"Suorita lohkoautomaatio" nyt.
Signaaleista tulee kysymyksiä, sano OK
-
Napsauta”Luo HDL -kääre”.
Haluamme kopioida luodun kääreen, jotta käyttäjä voi muokata sitä
- Napsauta OK.
Vaihe 2: Ernyn PWM: n luominen Vivadossa
Tämä vaihe luo PWM -IP -osoitteen, jonka tulot lähetetään AXI -kirjaston kautta.
-
Luo AXI GPIO -lohko napsauttamalla hiiren kakkospainikkeella taustaa ja valitsemalla "Lisää IP"
kirjoita hakupalkkiin "AXI_GPIO" ja valitse tämä paketti
- Muokkaa IP-osoitetta kaksoisnapsauttamalla uutta axi_gpio_0-lohkoa
- Aseta GPIO -kohdassa GPIO -leveydeksi 2. Nämä bitit ovat PWM_ON -signaali jokaisen PWM -moduulin esiintymän ohjaamiseksi.
- napsauta "ota kaksikanavainen käyttöön"
- Aseta GPIO 2: ssa GPIO -leveydeksi 2. Nämä bitit ovat PWM_FW -signaali jokaisen PWM -moduulin esiintymän suunnan asettamiseksi.
-
Napsauta hiiren kakkospainikkeella axi_gpio_0 -lähtöporttia, jossa on merkintä GPIO, ja valitse "Tee ulkoinen"
- Napsauta uutta GPIO -tulostetta ja siirry vasemmanpuoleisen työkalupalkin "ominaisuudet" -välilehteen ja muuta nimi PWM_ON
- Napsauta uutta GPIO2 -tulostetta ja siirry vasemmanpuoleisen työkalupalkin "ominaisuudet" -välilehteen ja muuta nimi PWM_FW
-
Valitse Suorita yhteysautomaatio lohkokaavion yläpuolella olevasta vihreästä bannerista.
Jos liität portit manuaalisesti, AXI -osoitteita ei ehkä ole määritetty, mikä johtaa myöhemmin tiedonsiirto -ongelmiin
-
Luo uusi mukautettu IP -lohko valitsemalla Flow Navigator -ruudussa projektipäällikkö -> Lisää lähteitä
- valitse "lisää tai luo suunnittelulähteitä" ja paina seuraava
- Napsauta "luo tiedosto", muuta tiedostotyypiksi "SystemVerilog" ja kirjoita tiedostonimen kenttään "pwm" ja napsauta sitten OK
- napsauta Valmis
-
ohita Määrittele moduuli -ikkuna painamalla OK (korvaamme nämä myöhemmin)
jos se kysyy, oletko varma, napsauta Kyllä
-
Kaksoisnapsauta Lähteet-välilehden pwm.sv-tiedostoa (joka sijaitsee kohdassa Suunnittelulähteet/design_1_wrapper)
Kopioi/liitä koko SystemVerilog -koodi alla olevasta pwm.txt -tiedostosta
Vaihe 3: Ernyn TDOA: n luominen Vivadossa
Tämä vaihe luo TDOA IP: n, jonka tuloksen voi lukea AXI -kirjaston kautta
-
Luo AXI GPIO -lohko napsauttamalla hiiren kakkospainikkeella taustaa ja valitsemalla "Lisää IP"
kirjoita hakupalkkiin "AXI_GPIO" ja valitse tämä paketti
- Muokkaa IP-osoitetta kaksoisnapsauttamalla uutta axi_gpio_1-lohkoa
- valitse GPIO -kohdassa "Kaikki tulot" -ruutu ja aseta GPIO -leveydeksi 32. Tämä väylä on kahden anturin saapumisaikaero.
- napsauta axi_gpio_1 -lohkon GPIO -portin vieressä olevaa + -painiketta, jolloin gpio_io_i [31: 0] tulee näkyviin.
-
Napsauta hiiren kakkospainikkeella axi_gpio_1 -lähtöporttia, jossa on merkintä gpio_io_i [31: 0], ja valitse "Tee ulkoinen"
Napsauta uutta syötettä, nimeltään gpio_io_i [31: 0], ja siirry vasemmanpuoleisen työkalupalkin "Ominaisuudet" -välilehteen ja vaihda nimeksi TDOA_val
-
Valitse Suorita yhteysautomaatio lohkokaavion yläpuolella olevasta vihreästä bannerista.
Jos liität portit manuaalisesti, AXI -osoitteita ei ehkä ole määritetty, mikä johtaa myöhemmin tiedonsiirto -ongelmiin
-
Luo uusi mukautettu IP -lohko valitsemalla Flow Navigator -ruudussa projektipäällikkö -> Lisää lähteitä
- valitse "lisää tai luo suunnittelulähteitä" ja paina seuraava
- Napsauta "luo tiedosto", muuta tiedostotyypiksi "SystemVerilog" ja kirjoita "tdoa" tiedostonimen kenttään ja napsauta sitten OK
- napsauta Valmis
-
ohita Määrittele moduuli -ikkuna painamalla OK (korvaamme nämä myöhemmin)
jos se kysyy, oletko varma, napsauta Kyllä
-
Kaksoisnapsauta Lähteet-välilehden tdoa.sv-tiedostoa (joka sijaitsee kohdassa Suunnittelulähteet/design_1_wrapper)
Kopioi/liitä koko SystemVerilog -koodi alla olevasta tdoa.txt -tiedostosta
Vaihe 4: Ernie -kääriminen ja vieminen
- Varmista, että lohkokaavio näyttää liitteenä olevasta kuvakaappauksesta
-
Napsauta Lähteet-välilehdellä hiiren kakkospainikkeella design_1.bd ja valitse "Luo HDL-kääre …"
- Valitse "Kopioi luotu tulostus salliaksesi käyttäjän muokkaukset" ja paina sitten "OK"
- Kopioi koodi alla olevasta linkistä design_1_wrapper.txt ja liitä se luotun design_1_wrapper.v -koodin tilalle
- tallenna design_1_wrapper.v
-
Kaksoisnapsauta Lähteet-välilehden tiedostoa ZYBO_Master.xdc kohdassa Rajoitukset/constrs1
- Kopioi koodi alla olevasta ZYBO_Master.txt -tiedostosta ja liitä se olemassa olevan ZYBO_Master.xdc -koodin tilalle
-
Huomaa seuraavat tulo-/lähtönastat:
- L15: PWM -signaali vasemmalle moottorille (Pmod JA2 Zyboyssa)
- L14: PWM -signaali oikealle moottorille (Pmod JA8 Zyboyssa)
- V12: porttitulo äänianturista 1 (Pmod JE1 Zyboyssa)
- K16: porttitulo äänianturista 2 (Pmod JE2 Zyboyssa)
-
Napsauta Flow Navigator -ruudussa Ohjelman ja virheenkorjauksen alla "Luo bittivirta"
jos luulet, että se on tehty heti, se ei todennäköisesti ole. vakavasti, keitä teetä
-
Napsauta Tiedosto-> Vie-> Luo laitteisto
Valitse "Sisällytä bittivirta" ja paina OK
- Napsauta Tiedosto-> Käynnistä SDK
Vaihe 5: Ernin rakentaminen
- Asenna servot servokoteloon.
-
Tee servojen teknisen taulukon mukaan seuraavat toimet:
- liitä servojen maa Zybo's JA Pmodin maadoitus nastoihin (katso oheinen pinout -kuva)
-
liitä servojen virtatappi AA -paristoon
Havaitsimme, että kun servot on kytketty Zyboyn Vdd -levyyn, piirilevy imee liikaa virtaa, minkä seurauksena levy nollautuu jatkuvasti
- liitä tulosignaalin nastat Zyboyn sopiviin lähtöliittimiin (vasen: JA2, oikea: JA8)
- asenna äänianturit rungon etuosaan eteenpäinpäin pitäen ne mahdollisimman lähellä toisiaan
-
käytä äänianturin liitäntäopasta integroidaksesi äänianturit
- kytke jokaisen äänianturin maa- ja Vdd -nastat maahan ja Zyboyn JE Pmodin Vdd -nastat (katso oheinen pinout -kuva)
- kytke vasemman äänianturin porttitappi liittimeen JE1
- kytke oikean äänianturin porttitappi JE2: een
Vaihe 6: Ernie's First BSP
-
Luo BSP -paketti juuri luomallamme.
Saat tämän valitsemalla Tiedosto -> Uusi -> Hallituksen tukipaketti
-
Ohjattu toiminto avautuu auttamaan sinua luomaan BSP: n.
- Haluamme yhdistää tämän BSP: n juuri luomaamme alustaan
- Laitteistoalustan pitäisi vastata juuri luomamme alusta (katso kuva 1)
- Suorittimemme on _0 -suoritin.
- Napsauta Valmis
- Muista tarkistaa, että lwip141 sisällytetään bsp: si kanssa avautuvaan ikkunaan (katso kuva 2)
Vaihe 7: FreeRTOS -käyttö Ernie
-
Lataa uusin FreeRTOS -julkaisu Sourceforgesta.
Jos lataus on suoritettava, poista FreeRTOS -tiedostot projektihakemistoosi suorittamalla se
- Pidä SDK auki ja valitse Tiedosto -> Tuo.
- Haluamme napsauttaa Yleiset-> Olemassa olevasta työtilasta, ja sitten haluamme navigoida paikkaan, johon latasimme FreeRTOSin.
-
Demomme sijaitsee FreeRTOS/Demo/CORTEX_A9_Zynq_ZC702. Kun valitset tämän kansion, meidän pitäisi nähdä kolme projektia (koodimme (OS), se BSP ja HW -alusta).
VAIN Tuo RTOSDemo nykyiseen työtilaasi
-
Muuta kaikissa "sinisissä" kansioprojekteissa viitattua BSP: tä
- Napsauta hiiren kakkospainikkeella ja valitse "Muuta viitattua BSP: tä".
- Valitse juuri luomasi BSP -laite BSP: lle
- Koodin muokkaus Xilinxin SDK Blue -kansioissa ovat todellisia koodiprojekteja.
Vaihe 8: Ernien C -koodin tuominen
- Korvaa RTOSDemo/src -hakemistossa olemassa oleva main.c ja main.c -tiedosto, joka on liitetty tähän.
- Kopioi main_sound.c -tiedosto RTOSDemo/src -hakemistoon.
Vaihe 9: Virheenkorjaus Ernie
- Valitse Suorita -> Debug Configuration
- Luo vasemmanpuoleiseen ruutuun uusi System Debugger -käyttö
-
Valitse Kohteen asetukset -välilehdessä
valitse "Nollaa koko järjestelmä", niin sekä että että ps7_init on valittu
-
Valitse nyt Sovellus -välilehti.
- Valitse "lataa sovellus"
- Aseta cortexa9_0 -ydin asentoon "stop at program entry"
- Valitse Käytä ja virheenkorjaus.
- Varmista, ettei virheenkorjausprosessissa ole virheitä
- Pidä robotti tarkasti silmällä ja paina Jatka -painiketta, kunnes ohjelma käynnistyy ilman, että se saavuttaa katkaisupisteitä
- Robotin pitäisi nyt kääntyä ja siirtyä kohti kovia ääniä. Jee!
Vaihe 10: Ernyn tekeminen itsenäiseksi
- Kun projektisi on valmis aloittamaan (voit suorittaa virheettä virheenkorjaimen kautta), olet valmis lataamaan sen levyllesi.
-
Luo niin sanottu ensimmäisen vaiheen käynnistyslatausprojekti (FSBL) ja sisältää kaikki ohjeet, joita korttisi tarvitsee ladatakseen projektitiedostot (bittivirran ja käyttöjärjestelmän) käynnistyksen yhteydessä.
- Valitse: Tiedosto-> Uusi-> Sovellusprojekti ja seuraava ikkuna tulee näkyviin.
- Nimeä se mitä haluat (esim. "FSBL")
- Varmista, että työskentelet laitteistoalustan kanssa
- Paina seuraava (älä paina Valmis)
- Valitse Zynq FSBL -malli
- Napsauta Valmis.
- Kun luomisprosessi on valmis, tiedät, toimiiko kaikki, jos näet seuraavat kaksi uutta kansiota Project Explorer -ikkunassa.
-
Luo käynnistyskuva Nyt sinun on luotava käynnistyskuva.
- Napsauta hiiren kakkospainikkeella projektikansioasi (tässä tapauksessa minun nimeni on "RTOSDemo")
- Napsauta avattavasta valikosta "Luo käynnistyskuva"
-
Jos kaikki on linkitetty oikein, projekti tietää tarvitsemansa tiedostot ja seuraava ikkuna näyttää alla olevasta kuvasta (avain on, että sinulla on kolme osiota Käynnistyskuva -osiossa, käynnistyslatain, bittitiedosto ja projektisi.elf -tiedosto).
Jos näin ei ole, projektisi linkittämisessä on mahdollisesti jotain vikaa. Varmista, että projektikansiot on linkitetty vastaaviin BSP -tiedostoihin
- Napsauta "Luo kuva" -painiketta
-
Ohjelmiston viimeinen vaihe on nyt vilkaista aiemmin luotu kuva levyn muistiin
- Valitse SDK: n päätyökaluriviltä Xilinx Tools-> Program Flash Memory
- Varmista, että oikea laitealusta on valittu ja että kuvatiedoston polku osoittaa oikein edellisessä vaiheessa luotua. BIN -tiedostoa.
- Valitse "qspi single" Flash -tyypistä
- Valitse”Tarkista salaman jälkeen” eheyden varmistamiseksi, mutta sitä ei tarvita
- Taulukon määrittäminen Lopuksi sinun on varmistettava, että levyjen ohjelmointitilan hyppyjohdin (JP5) on asetettu oikein valitsemaan käynnistys qspi: stä (joka sisältää juuri salamasi) BootROMin ollessa käynnissä.
- Käynnistä laite nyt ja varmista, että "Logic Configuration Done LED" (LED 10) palaa vihreänä.
Vaihe 11: Tee Ernie söpöksi
- Turkis
- Paljon turkista
- Isot silmät!
- … Silinteri
Suositeltava:
Kuinka tehdä langaton tinapurkkipuhelin! (Arduino Walkie Talkie): 7 vaihetta (kuvilla)
Kuinka tehdä langaton tinapurkkipuhelin! (Arduino Walkie Talkie): Juuri eilen olin keskellä erittäin tärkeää puhelua, kun banaanipuhelin lakkasi toimimasta! Olin niin turhautunut. Se on viimeinen kerta, kun jätän puhelun tyhmän puhelimen takia! (Jälkeenpäin ajateltuna olen saattanut olla hieman vihainen
Kuinka tehdä ladattava aurinkovalo: 8 vaihetta
Kuinka tehdä ladattava aurinkovalo:
DIY Kuinka näyttää aika M5StickC ESP32: ssa Visuinon avulla - Helppo tehdä: 9 vaihetta
DIY Kuinka näyttää aika M5StickC ESP32: ssa Visuinon avulla - Helppo tehdä: Tässä opetusohjelmassa opimme ohjelmoimaan ESP32 M5Stack StickC: n Arduino IDE: n ja Visuinon avulla näyttämään ajan nestekidenäytöllä
Kuinka tehdä LED -kuutio - LED -kuutio 4x4x4: 3 vaihetta
Kuinka tehdä LED -kuutio | LED -kuutio 4x4x4: LED -kuutio voidaan ajatella LED -näyttönä, jossa yksinkertaiset 5 mm: n LEDit toimivat digitaalisten pikselien roolissa. LED -kuution avulla voimme luoda kuvia ja kuvioita käyttämällä optisen ilmiön käsitettä, joka tunnetaan nimellä visio pysyvyys (POV). Niin
DIY Kuinka tehdä tyylikkään näköinen kello - StickC - Helppo tehdä: 8 vaihetta
DIY Kuinka tehdä tyylikkään näköinen kello - StickC - Helppo tehdä: Tässä opetusohjelmassa opimme ohjelmoimaan ESP32 M5Stack StickC: n Arduino IDE: n ja Visuinon avulla näyttämään ajan nestekidenäytöllä ja asettamaan ajan myös StickC -painikkeilla