Ernie valmistamine: 11 sammu
Ernie valmistamine: 11 sammu
Anonim
Kuidas teha Ernie
Kuidas teha Ernie

See on õpetus selle kohta, kuidas Znie Boardi abil luua oma autonoomne heli jälgiv robot Ernie. See hõlmab järgmisi toiminguid: Vivados projekti loomine, FPGA-s PWM-sarnaste servomootorite draiverite loomine, kahe helianduriga liides, saabumisaja IP-i ajavahe loomine, freeRTOS-i kasutamine ja zybo aku käivitamine. See oli meie viimane projekt Cal Poly SLO reaalajas opsüsteemide klassi (CPE 439) jaoks.

Varustuse loend:

  • 1 - ZYBO Zynq 7000 arendusnõukogu
  • 2 - Parallaxi pideva pöörlemise servo
  • 2 - heliandur (SparkFun helidetektor)
  • 1 - 5 V liitiumioonaku USB -aku (plaadile)
  • 4 - AA patareid (servodele)
  • 1 - AA patareipakk (4 akupesaga)
  • 1 - mikro -USB -kaabel
  • 1 - leivalaud
  • palju - meessoost juhtmed
  • 1 - Servo šassii

Tarkvara nõuded:

  • Xilinx Vivado disainikomplekt 2016.2
  • Digilent Adept 2.16.1

1. samm: projekti loomine Vivados Ernie jaoks

Projekti seadistamine Ernie jaoks Vivados
Projekti seadistamine Ernie jaoks Vivados
Projekti seadistamine Ernie jaoks Vivados
Projekti seadistamine Ernie jaoks Vivados
Projekti seadistamine Ernie jaoks Vivados
Projekti seadistamine Ernie jaoks Vivados
  1. Ilmub nõustaja
  2. Klõpsake nuppu Edasi
  3. Järgmine projekti nimi

    1. Ärge kunagi kasutage projekti nime ega kataloogi teed, kus on tühikuid !!!!!
    2. See saab olema RTL -i projekt.
  4. Me ei taha allikaid täpsustada
  5. Klõpsates nuppu Edasi, jõuame lehele Osa. Kasutame seadet ZYNQ XC7Z010-1CLG400C.

    1. Vivadol pole Zybo-d etteantud tahvlitena loetletud. Valige: „osad”, seejärel otsige xc7z010clg400-1.
    2. Kui valite kogemata vale osa, saate kiipe hõlpsalt vahetada: Tööriistad -> Projekti seaded -> Üldine ja klõpsake jaotisel „Projekti seade” paremal asuvaid punkte
  6. Klõpsake nuppu Loo ploki kujundus.

    Pange sellele praegu nimi design_1

  7. Näete rohelist riba, mis ütleb Lisa IP, klõpsake seda.
  8. Otsi Zynq.

    1. Topeltklõpsake töötlemissüsteemi ZYNQ7,
    2. See plokk ilmub meie ploki kujunduses.
  9. Näete rohelist riba, mis ütleb Run Block Automation, klõpsake seda.
  10. Laadige alla zybo_zynq_def.xml.
  11. Vivados klõpsake "Impordi XPS -i seaded" ja valige "zybo_zynq_def.xml"

    See täidab Vivado ploki konfiguratsiooni kõigi Zybo plaadi sisseehitatud välisseadmete ja tihvtide määramisega

  12. Topeltklõpsake plokki ZYNQ.

    1. MIO konfiguratsioon

      1. Luba taimer 0 (rakenduse töötleja üksuse all - img 1)
      2. Valvekoera lubamine (rakenduse töötleja üksuse all- img 1)
      3. Luba GPIO-> GPIO MIO (rakenduse töötleja üksuse all - img 2)
      4. Luba GPIO-> ENET lähtestamine (I/O välisseadmete all- img 2)
    2. Kella seadistamine

      Keela FCLK0 (PL -kangakellade all - img 3)

  13. Klõpsake nuppu OK.
  14. „Käivita plokkide automatiseerimine” kohe.

    Signaalide kohta tekib küsimusi, öelge OK

  15. Klõpsake „Loo HDL -pakend”.

    Soovime loodud ümbrise kopeerida, et kasutaja saaks seda muuta

  16. Klõpsake nuppu OK.

2. samm: Ernie PWM -i loomine Vivados

Ernie PWM -i loomine Vivados
Ernie PWM -i loomine Vivados
Ernie PWM -i loomine Vivados
Ernie PWM -i loomine Vivados

See samm loob PWM IP sisenditega, mis saadetakse AXI raamatukogu kaudu.

  1. Looge AXI GPIO plokk, paremklõpsates taustal ja klõpsates nuppu "Lisa IP"

    tippige otsinguribale "AXI_GPIO" ja valige see pakett

  2. Kohandage IP-d uuesti, topeltklõpsates uut plokki axi_gpio_0

    1. GPIO all määrake GPIO laiuseks 2. Need bitid on PWM_ON -signaaliks iga PWM -mooduli eksemplari juhtimiseks.
    2. klõpsake "Luba kahe kanaliga"
    3. GPIO 2 all seadke GPIO laius väärtuseks 2. Need bitid on PWM_FW signaal, et määrata iga PWM -mooduli eksemplari suund.
  3. Paremklõpsake väljundporti axi_gpio_0 sildiga GPIO ja valige käsk "Tee väline"

    1. Klõpsake uut väljundit nimega GPIO ja navigeerige vasakul tööriistaribal vahekaardile "Atribuudid" ja muutke nimeks PWM_ON
    2. Klõpsake uut väljundit nimega GPIO2 ja navigeerige vasakul tööriistaribal vahekaardile "Atribuudid" ja muutke nimeks PWM_FW
  4. Valige plokkskeemi kohal asuvas rohelises ribas käsk Käivita ühenduse automatiseerimine.

    Kui ühendate pordid käsitsi, ei pruugi AXI -aadresse konfigureerida, mis põhjustab hiljem sideprobleeme

  5. Paanil Flow Navigator valige uue kohandatud IP -ploki loomiseks projektijuht -> Lisa allikad

    1. valige "Lisa või loo kujundusallikaid" ja klõpsake nuppu Järgmine
    2. klõpsake "loo fail", muutke failitüübiks "SystemVerilog" ja tippige failinime väljale "pwm", seejärel klõpsake nuppu OK
    3. klõpsake nuppu Lõpeta
    4. ignoreerige mooduli määratlemise akent, vajutades OK (kirjutame need hiljem üle)

      kui küsitakse, kas olete kindel, klõpsake nuppu Jah

  6. Topeltklõpsake vahekaardil Allikad pwm.sv (see asub jaotises „Disainiallikad/design_1_wrapper”)

    Kopeerige/kleepige kogu SystemVerilogi kood allpool lisatud failist pwm.txt

3. samm: Ernie TDOA loomine Vivados

Ernie TDOA loomine Vivados
Ernie TDOA loomine Vivados
Ernie TDOA loomine Vivados
Ernie TDOA loomine Vivados

See samm loob TDOA IP, mille väljundit saab lugeda AXI raamatukogu kaudu

  1. Looge AXI GPIO plokk, paremklõpsates taustal ja klõpsates nuppu "Lisa IP"

    tippige otsinguribale "AXI_GPIO" ja valige see pakett

  2. Kohandage IP-d uuesti, topeltklõpsates uut axi_gpio_1 plokki

    1. GPIO all märkige ruut "Kõik sisendid" ja määrake GPIO laius 32. See buss on kahe anduri saabumise aja erinevus.
    2. klõpsake axi_gpio_1 ploki sees GPIO pordi kõrval olevat +, et näha gpio_io_i [31: 0].
  3. Paremklõpsake väljundporti axi_gpio_1 sildiga gpio_io_i [31: 0] ja valige „Tee väline”

    Klõpsake uut sisendit nimega gpio_io_i [31: 0] ja navigeerige vasakul tööriistaribal vahekaardile "Atribuudid" ja muutke nimeks TDOA_val

  4. Valige plokkskeemi kohal asuvas rohelises ribas käsk Käivita ühenduse automatiseerimine.

    Kui ühendate pordid käsitsi, ei pruugi AXI -aadresse konfigureerida, mis põhjustab hiljem sideprobleeme

  5. Paanil Flow Navigator valige uue kohandatud IP -ploki loomiseks projektijuht -> Lisa allikad

    1. valige "Lisa või loo kujundusallikaid" ja klõpsake nuppu Järgmine
    2. klõpsake "loo fail", muutke failitüübiks "SystemVerilog" ja tippige failinime väljale "tdoa", seejärel klõpsake nuppu OK
    3. klõpsake nuppu Lõpeta
    4. ignoreerige mooduli määratlemise akent, vajutades OK (kirjutame need hiljem üle)

      kui küsitakse, kas olete kindel, klõpsake nuppu Jah

  6. Topeltklõpsake vahekaardil Allikad allikat tdoa.sv (see asub jaotises „Disainiallikad/design_1_wrapper”)

    Kopeerige/kleepige kogu SystemVerilogi kood allpool lisatud failist tdoa.txt

Samm: Ernie pakkimine ja eksportimine

Ernie pakkimine ja eksport
Ernie pakkimine ja eksport
  1. Veenduge, et plokkskeem näeb välja nagu manustatud ekraanipilt
  2. Vahekaardil Allikad paremklõpsake disaini_1.bd ja valige „Loo HDL-pakend…”

    1. Valige "Kopeeri loodud väljund kasutaja redigeerimiseks", seejärel vajutage "OK"
    2. Kopeerige kood alltoodud failist design_1_wrapper.txt ja kleepige see loodud koodi_1_wrapper.v asemel
    3. salvesta design_1_wrapper.v
  3. Topeltklõpsake vahekaardil Allikad faili ZYBO_Master.xdc jaotises Constraints/constrs1

    1. Kopeerige kood alltoodud failist ZYBO_Master.txt ja kleepige see olemasoleva koodi ZYBO_Master.xdc asemele
    2. Pange tähele järgmisi sisendi/väljundi kontakte:

      1. L15: PWM -signaal vasaku mootori jaoks (Pmod JA2 Zybo -l)
      2. L14: PWM -signaal paremale mootorile (Pmod JA8 Zybo -l)
      3. V12: värava sisend heliandurist 1 (Pmod JE1 Zyboyl)
      4. K16: värava sisend heliandurist 2 (Pmod JE2 Zybo -l)
  4. Klõpsake paanil Flow Navigator nuppu Programm ja silumine jaotises "Loo bitivool"

    kui arvate, et see on kohe tehtud, siis ilmselt mitte. tõsiselt, tee teed

  5. Klõpsake Fail-> Eksport-> Loo riistvara

    Märkige "Kaasa bitivool" ja klõpsake nuppu OK

  6. Klõpsake Fail-> Käivita SDK

Samm: Ernie ehitamine

Ernie ehitamine
Ernie ehitamine
Ernie ehitamine
Ernie ehitamine
  1. Paigaldage servod šassii külge.
  2. Tehke servode andmelehe järgi järgmist.

    1. ühendage servode maandus Zybo's JA Pmod maandusnõeltega (vt lisatud pinout -pilti)
    2. ühendage servode toitenupp AA patareiga

      Leidsime, et kui servod on Zybo Vdd -ga ühendatud, tõmbab plaat liiga palju voolu, põhjustades plaadi pideva lähtestamise

    3. ühendage sisendsignaali tihvtid Zybo vastavate väljundpistikutega (vasakul: JA2, paremal: JA8)
  3. paigaldage heliandurid šassii ette, näoga ettepoole, hoides neid võimalikult lähestikku
  4. heliandurite integreerimiseks kasutage helianduri ühendamisjuhendit

    1. ühendage iga helianduri maandus ja Vdd -tihvtid maapinnaga ja Zyboy JE Pmod Vdd -tihvtidega (vt lisatud pinout -pilti)
    2. ühendage vasaku helianduri värava tihvt JE1 külge
    3. ühendage parem helianduri värava tihvt JE2 -ga

6. samm: Ernie esimene BSP

Ernie esimene BSP
Ernie esimene BSP
Ernie esimene BSP
Ernie esimene BSP
  1. Looge BSP, et lõpetada äsja loodud platvorm.

    Selle saate hankida menüüst File -> New -> Board Support Package

  2. Ilmub viisard, mis aitab teil BSP -d luua.

    1. Me tahame siduda selle BSP oma platvormiga, mille me just lõime
    2. Riistvaraplatvorm peaks vastama äsja loodud platvormile (vt img 1)
    3. Meie protsessoriks on _0 protsessor.
    4. Klõpsake nuppu Lõpeta
    5. Kontrollige kindlasti lwip141, kas teie bsp -ga kaasatakse avanevas aknas (vt img 2)

7. samm: FreeRTOS -i kasutamine Ernie

  1. Laadige alla uusim FreeRTOS -i versioon Sourceforge'ist.

    Kui allalaaditav fail on käivitatav, käivitage see FreeRTOS -failide hankimiseks oma projekti kataloogi

  2. Hoidke see SDK avatuna ja klõpsake nuppu Fail -> Impordi.
  3. Tahame klõpsata Üldine-> Olemasolevast tööruumist ja seejärel navigeerida kohta, kust FreeRTOS-i alla laadisime.
  4. Meie demo asub FreeRTOS/Demo/CORTEX_A9_Zynq_ZC702. Selle kausta valimisel peaksime nägema kolme projekti (meie kood (OS), see on BSP ja HW platvorm).

    AINULT importige RTOSDemo oma praegusesse tööruumi

  5. Kõigil sinise kausta projektidel muutke viidatud BSP -d

    1. Paremklõpsake ja valige „Muuda viidatud BSP -d”.
    2. Valige oma Bybo jaoks just loodud BSP
    3. Koodide redigeerimine Xilinxi SDK Blue kaustades on tegelikud koodiprojektid.

8. samm: Ernie C -koodi importimine

  1. Kirjutage kataloogis RTOSDemo/src olemasolev main.c üle siia lisatud failiga main.c.
  2. Kopeerige fail main_sound.c kataloogi RTOSDemo/src.

9. samm: Ernie silumine

  1. Valige Käivita -> silumiskonfiguratsioonid
  2. Vasakul paanil looge uus System Debugger
  3. Vahekaardil Sihthäälestus

    valige „Lähtesta kogu süsteem”, et valida nii see kui ka ps7_init

  4. Nüüd valige vahekaart Rakendus.

    1. Valige "rakenduse allalaadimine"
    2. Seadke cortexa9_0 tuum olekule „peatu programmi sisenemisel”
    3. Klõpsake nuppu Rakenda ja silumine.
  5. Veenduge, et silumisprotsessis pole vigu
  6. Jälgides robotit tähelepanelikult, vajutage nuppu Jätka, kuni programm töötab ilma katkestuspunkte tabamata
  7. Nüüd peaks robot pöörama ja liikuma valju müra suunas. Jaa!

Samm: muutke Ernie autonoomseks

  1. Kui teie projekt on kõik valmis (saate siluri kaudu probleemideta joosta), olete valmis selle oma tahvli välkmällu laadima.
  2. Looge nn esimese etapi alglaaduri (FSBL) projekt ja see sisaldab kõiki juhiseid, mida teie plaat vajab teie projektifailide (bitivoog ja OS) käivitamisel laadimiseks.

    1. Valige: Fail-> Uus-> Rakendusprojekt ja peaks ilmuma järgmine aken.
    2. Pange sellele nimi, mida soovite (nt „FSBL”)
    3. Veenduge, et riistvaraplatvorm oleks see, millega te töötate
    4. Vajutage järgmist (ärge vajutage nuppu Lõpeta)
    5. Valige Zynq FSBL mall
    6. Klõpsake nuppu Lõpeta.
  3. Kui loomisprotsess on lõpule jõudnud, teate, kas kõik toimis, kui näete Project Exploreri aknas järgmisi kahte uut kausta.
  4. Looge alglaadimispilt Nüüd peate looma alglaadimispildi.

    1. Paremklõpsake oma projekti kausta (sel juhul nimetatakse minu nime "RTOSDemo")
    2. Klõpsake rippmenüüst käsku Loo alglaadimispilt
    3. Kui kõik on õigesti lingitud, teab projekt, milliseid faile see vajab, ja järgmine aken näeb välja selline, nagu näete allpool (võtmeks on see, et teil on jaotise Boot image all 3 sektsiooni, alglaadur, teie bitifail ja teie projektide.elf -fail.).

      Kui see pole nii, võib teie projekti linkimisel olla midagi valesti. Veenduge, et projekti kaustad on seotud nende vastavate BSP -dega

    4. Klõpsake nuppu „Loo pilt”
  5. Tarkvara viimane samm on nüüd oma varem loodud pildi välklamp tahvli mällu välgutada
    1. Valige SDK põhitööriistaribalt Xilinxi tööriistad-> Programmeerige välkmälu
    2. Veenduge, et valitud on õige riistvaraplatvorm ja et pildifaili tee osutab õigesti eelmises etapis loodud. BIN -failile.
    3. Valige välgu tüübist „qspi single“
    4. Ehtsuse tagamiseks märkige ruut „Verify after flash”, kuid seda pole vaja
  6. Tahvli konfigureerimine Lõpuks peate veenduma, et tahvlite programmeerimisrežiimi hüppaja (JP5) on õigesti valitud nii, et BootROM -i käivitamisel käivitatakse qspi -st (mis sisaldab äsja välklampi).
  7. Nüüd lülitage seade lihtsalt sisse ja veenduge, et loogikakonfiguratsiooni LED (LED 10) põleb roheliselt.

Samm 11: Ernie armsaks tegemine

  1. Karusnahk
  2. Palju karusnahka
  3. SUURED silmad!
  4. … Silmusmüts

Soovitan: