Kamera ZYBO OV7670 Me Kontroll Pan/Tilt: 39 Hapa (me Fotografi)
Kamera ZYBO OV7670 Me Kontroll Pan/Tilt: 39 Hapa (me Fotografi)

Përmbajtje:

Anonim
Image
Image
Kamera ZYBO OV7670 Me Kontroll Pan/Tilt
Kamera ZYBO OV7670 Me Kontroll Pan/Tilt

Filloni në hapin një për detaje mbi krijimin e një kontrolluesi servo PWM me 2 boshte.

Filloni në bllok skemën masive (Hapi 19) për projektin e plotë.

Kamera + Konfigurimi i tiganit/pjerrësisë që përdorëm:

PmodCON3 nga Digilent u përdor për të lidhur servot.

Hapi 1: Ndërtimi i një Moduli PWM- Skedari Burimor

Hapi 2: Ndërtimi i një Moduli PWM- Konfigurimi Vivado

Ndërtimi i një Moduli PWM- Konfigurimi Vivado
Ndërtimi i një Moduli PWM- Konfigurimi Vivado

Së pari, shkarkoni uebfaqen e Vivado Design Suite Nga Xilinx. Instaloni të gjithë kompletin e dizajnit, duke përfshirë Vivado Software Development Kit (SDK). Ky projekt përdor versionin 2017.2.

Ndërkohë, Digilent Adept 2 gjithashtu duhet të instalohet si një drejtues bordi Zybo.

Hapi 3: Ndërtimi i një moduli PWM- Krijoni një skedar projekti

Ndërtimi i një moduli PWM- Krijoni një skedar projekti
Ndërtimi i një moduli PWM- Krijoni një skedar projekti

Para se të krijoni një skedar projekti, duhet të siguroheni që tashmë e keni instaluar skedarin Zybo siç duhet si udhëzues këtu:

Vivado Version 2015.1 dhe më vonë Instalimi i Skedarit të Bordit

Hap Vivado 2017.2. Në Fillimin e Shpejtë, klikoni në Krijo Projekt -> Tjetër -> Emri i Projektit (Emërtoni emrin e projektit tuaj këtu) -> Lloji i Projektit. Në Llojin e Projektit, zgjidhni RTL Project dhe shënoni në "Mos specifikoni burimet në këtë kohë". Tjetra, për Pjesën e Parazgjedhur, zgjidhni "Bordet" dhe "Zybo" si Emri i Shfaqur. Tjetra, Kliko Finish për të filluar projektin.

Hapi 4: Ndërtimi i një Moduli PWM- Blloku i Dizajnit dhe Vendosja e Kufizimit të Skedarit (I)

Ndërtimi i një moduli PWM- Blloku i dizajnit dhe cilësimi i skedarit të kufizimit (I)
Ndërtimi i një moduli PWM- Blloku i dizajnit dhe cilësimi i skedarit të kufizimit (I)

Në Flow Navigator, klikoni në "" Krijo dizajn blloku ", pastaj shtypni OK. klikoni shenjën "+" për të shtuar IP -të e nevojshme. Shto:

  • Një sistem përpunimi ZYNQ7 Dy kohëmatës AXI
  • Dy kohëmatës AXI

Hapi 5: Ndërtimi i një Moduli PWM- Dizajni i Bllokut dhe Vendosja e Skedarit të Kufizimit (II)

Ndërtimi i një moduli PWM- Blloku i dizajnit dhe vendosja e skedarit të kufizimit (II)
Ndërtimi i një moduli PWM- Blloku i dizajnit dhe vendosja e skedarit të kufizimit (II)

Pas Shtimit të IP -ve, Drejtoni Automatizimin e Bllokut dhe automatizimin e lidhjes. Pasi të përfundojë automatizimi, në bllokun "axi_timer_0", kliko me të djathtën në pwm0 -> Make External. Emërtoni pinin e jashtëm pwm0 si pwm_Xaxis. Gjithashtu, përsëritni procesin e mësipërm në bllokun "axi_timer_1" dhe emërtoni pinin e jashtëm pwm0 si pwm_Zaxis.

Hapi 6: Ndërtimi i një moduli PWM- Blloku i dizajnit dhe vendosja e skedarit të kufizimit (III)

Ndërtimi i një Moduli PWM- Dizajni i Bllokut dhe Vendosja e Skedarit të Kufizimit (III)
Ndërtimi i një Moduli PWM- Dizajni i Bllokut dhe Vendosja e Skedarit të Kufizimit (III)

Vini re se çdo herë kur të përfundojmë Dizajnin e Bllokut në Vivado, duhet të krijojmë një Mbështjellës HDL. Meqenëse do të jetë moduli i nivelit të lartë për secilin projekt.

Hapi 7: Ndërtimi i një Moduli PWM- Dizajni i Bllokut dhe Vendosja e Skedarit të Kufizimit (IV)

Ndërtimi i një moduli PWM- Blloku i dizajnit dhe vendosja e skedarit të kufizimit (IV)
Ndërtimi i një moduli PWM- Blloku i dizajnit dhe vendosja e skedarit të kufizimit (IV)

Tani, ne duhet të vendosim skedarin tonë të kufizimit për të caktuar kunjat e lidhur me bllok -diagramin tonë. Mbyllni dritaren e Dizajnit të Bllokut, në skedën "Burimet", "Shto burime"-> Shtoni ose krijoni kufizime-> shtoni Zybo-Master.xdc si skedarët tanë kufizues.

Hapi 8: Ndërtimi i një Moduli PWM- Blloku i Dizajnit dhe Vendosja e Kufizimit të Skedarit (V)

Ndërtimi i një moduli PWM- Bllokimi i dizajnit dhe vendosja e skedarit të kufizimit (V)
Ndërtimi i një moduli PWM- Bllokimi i dizajnit dhe vendosja e skedarit të kufizimit (V)

Hapni skedarin e kufizimit Zybo-Master.xdc nga dosja Kufizimet, mos komentoni portet që duam të specifikojmë si sinjale dalëse dhe riemërtoni “get_ports {XXXX}”, i cili XXXX tregon pinin e jashtëm të emërtuar në Diagramin e Bllokut. Vendosja e skedarit të kufizimit është treguar në figurë.

Hapi 9: Ndërtimi i një moduli PWM- Instalimi i harduerit

Ndërtimi i një moduli PWM- Instalimi i harduerit
Ndërtimi i një moduli PWM- Instalimi i harduerit

Lidhni motorët servo me Pmod CON3. TowerPro SG90 është modeli servo motor që kemi përdorur në këtë projekt. Për telat e servo motorit, tela portokalli përfaqëson sinjalin PWM, të lidhur me kunjin SIG në Pmod CON3. Teli i kuq Vcc është një tel i energjisë i lidhur me pin VS në Pmod CON3. Së fundi, tela ngjyrë kafe Gnd është një tel i tokëzuar i lidhur me kunjin GND. Tjetra, futni Pmod CON3 në rreshtin e sipërm të portit JD në Bordin Zybo.

Hapi 10: Ndërtimi i një Moduli PWM- Gjeneroni Bitstream dhe Nisni SDK

1. Në skedën Project Navigator, ekzekutoni Generate BitStream.

2. Eksportoni pajisjet: Skedari> Eksporti> Eksporti i pajisjeve-> shënoni në "përfshini bitstream"-> OK 3. Nisni SDK: Skedar-> Nisni SDK.

Hapi 11: Ndërtimi i një Moduli PWM- Krijoni një Aplikacion të Ri në Xilinx SDK

Ndërtimi i një Moduli PWM- Krijoni një Aplikacion të Ri në Xilinx SDK
Ndërtimi i një Moduli PWM- Krijoni një Aplikacion të Ri në Xilinx SDK

Krijoni një aplikacion të ri:

Skedar> E Re> Projekti i Aplikimit -> Shkruani emrin e projektit tuaj -> Përfundo

Nën Project Explorer, duhet të ketë tre dosje.

Në këtë rast, "design_1_wrapper_hw_platform_0" është dosja e eksportuar më parë nga Vivado. Axis_2_PWM_SDK_bsp është dosja e paketës së mbështetjes së bordit. Dhe Axis_2_PWM_SDK është dosja jonë kryesore e projektit në SDK. Ju mund të shihni skedarin "helloworld.c" nën dosjen "src" të Axis_2_PWM_SDK, ku "helloworld.c" është skedari kryesor.

Hapi 12: Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (I)

Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (I)
Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (I)

Le të kontrollojmë disa skedarë nën Project Explorer. Së pari, në dosjen "design_1_wrapper_hw_platform_0", hapni "system.hdf". Ky skedar demonstron hartën e adresave për procesorin ps7_cortex9 dhe blloqet IP të pranishme në dizajnin tonë.

Hapi 13: Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (II)

Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (II)
Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (II)

Pastaj, kontrolloni skedarin "përfshi" dhe "libsrc" nën dosjen "Axis_2_PWM_SDK_bsp". Skedarët e bibliotekës këtu na mundësojnë të ndërveprojmë me pajisjet periferike pa regjistra "duke luajtur".

Hapi 14: Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (III)

Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (III)
Ndërtimi i një Moduli PWM- Vështrim i Përgjithshëm i Projektit Explorer (III)

Përmes dokumentacionit BSP, xtmrctr.h gjendet si Biblioteka e Kontrollit të Kohëmatësit Xilinx që lidhet me AXI Timer. Në mënyrë tipike, ne mund të gjejmë funksionin e dëshiruar PWM këtu. Sidoqoftë, nëse lexoni dokumentacionin "tmrctr_v4_3", kjo tregon se shoferi aktualisht nuk e mbështet funksionimin PWM të pajisjes. Për shkak të mangësisë në funksionin PWM, ne duhet të mbyllim funksionin tonë PWM me ndihmën e xtmrctr.h dhe AXI Timer v2.0 LogiCORE IP Guide Product.

Hapi 15: Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (I)

Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (I)
Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (I)

Kthehuni te skedari kryesor "helloworld.c", përfshini skedarët e mëposhtëm të kokës:

Hapi 16: Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (II)

Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (II)
Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (II)

Përcaktoni adresat bazë të dy AXI TImer përmes "xparameters.h".

Hapi 17: Ndërtimi i një Moduli PWM- Përfundoni Funksionin PWM (III)

Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (III)
Ndërtimi i një moduli PWM- Përfundoni funksionin PWM (III)

Ndërtoni funksionin e dëshiruar PWM.

Duty_val: konverton vlerën e shkallës në ciklin e punës. PWM_Freq_Duty: vendosni frekuencën e dëshiruar dhe ciklin e punës për të gjeneruar PWM. Periudha e orës gjithashtu duhet të caktohet.

PWM_START: caktoni adresën e regjistrit PWM dhe filloni të gjeneroni PWM.

PWM_STOP: caktoni adresën e regjistrit PWM dhe ndaloni së gjeneruari PWM.

Pjesa tjetër e kodit demo tregohet në "helloworld.c" nën "Axis_2_PWM_SDK"

Hapi 18: Ndërtimi i një moduli PWM- Bëni të funksionojë

1. Programoni FPGA përmes SDK

  • Lidhni Zybo Board përmes portit USB me PC.
  • Mjetet Xilinx -> Programi FPGA

2. Drejtoni programin

Klikoni në ikonën "Run" dhe lëshoni menunë -> Run As -> Launch on Hardware

3. Terminali i SDK -së

  • Hapni Terminalin SDK -> Lidhu me Portin Serial -> OK
  • Drejtoni programin. Nëse kodi demo funksionon me sukses, duhet të shihni "Fillimi është bërë!" në Terminalin e SDK -së.

Hapi 19: Transmetimi i përpunimit të videove në Digilent ZYBO Me OV7670

Skedari i plotë i arkivit është bashkangjitur.

Hapi 20: Plotësoni Diagramin e Bllokut

Plotësoni diagramin e bllokut
Plotësoni diagramin e bllokut

Kjo tregon diagramin e plotë të të gjitha lidhjeve dhe blloqeve IP në projekt

Hapi 21: Lidhni OV7670 me ZYBO

Lidhni OV7670 me ZYBO
Lidhni OV7670 me ZYBO

Krijoni një lidhje për të lidhur modulin ov7670 me ZYBO Pmods

Të dhënat Pmod janë Pmod D

Kontrolli Pmod është Pmod C

Për më tepër, lidhni PmodCON3 dhe servos siç specifikohet në gjysmën e parë të këtij mësimi

Hapi 22: Krijoni Dizajn Blloku

Krijo Dizajn Blloku
Krijo Dizajn Blloku

Në Flow Navigator, klikoni në "Krijo dizajn blloku", pastaj shtypni OK.

Hapi 23: Shtoni skedarë VHDL për kontrollin dhe kapjen e kamerës OV7670

Shtoni skedarët VHDL të bashkangjitur në këtë hap në projekt

Hapi 24: Shtoni Skedarin e Kufizimeve

Shtoni skedarin e bashkëngjitur të kufizimeve në projektin tuaj.

Hapi 25: Shtoni IP Repo për HLS IP

Shto IP Repo për HLS IP
Shto IP Repo për HLS IP

Merrni skedarin Zip të bashkangjitur dhe hapeni atë në një dosje të re të quajtur në mënyrë të ngjashme në një drejtori (dosje) të re të quajtur "HLS_repo".

Shtoni një depo IP në projektin tuaj duke shkuar në katalogun IP dhe klikoni me të djathtën duke zgjedhur "Shto depo …"

Shkoni te drejtoria juaj "HLS_repo" dhe zgjidhni atë.

Opsionale: Krijoni bllokun e përpunimit të videos HLS për veten tuaj!

Hapi 26: Shtoni module dhe IP

Shtoni module dhe IP
Shtoni module dhe IP
Shtoni module dhe IP
Shtoni module dhe IP

Shtoni modulet ov7670_axi_stream_capture, debounce dhe ov7670_controller në bllok diagram duke klikuar me të djathtën në sfond dhe duke zgjedhur "Shto modul …"

Në mënyrë të ngjashme, shtoni IP -të:

  • HLS_Video_Track
  • Tampon i Kornizës Video Shkruani
  • Tampon i kornizës së videos të lexuar
  • Kontrolluesi i kohës së videos
  • AXI4-Transmeto në Video Out
  • 3 të "Fetë"
  • Konstante
  • 2 të Kohëmatësit AXI

Hapi 27: Cilësimet e konfigurimit të IP

Cilësimet e konfigurimit të IP
Cilësimet e konfigurimit të IP
Cilësimet e konfigurimit të IP
Cilësimet e konfigurimit të IP
Cilësimet e konfigurimit të IP
Cilësimet e konfigurimit të IP

Siç tregohet në fotografi

Hapi 28: Shtoni dhe Konfiguroni Bllokun IP të PS

Shtoni dhe Konfiguroni Bllokun IP të PS
Shtoni dhe Konfiguroni Bllokun IP të PS
Shtoni dhe Konfiguroni Bllokun IP të PS
Shtoni dhe Konfiguroni Bllokun IP të PS

Shtoni sistemin e përpunimit ZYNQ7 në bllok diagram

modifikoni konfigurimin:

  • Konfigurimi PS-PL

    • HP

      • Aktivizo S HP 0
      • Aktivizo S HP 1
  • Konfigurimi i orës

    • Orë pëlhure PL

      • FCLK_0 në 100MHz
      • FCLK_1 në 25MHz (OutputClock)
      • FLCK_2 në 35MHz (<= 50MHz) (CameraClock)

Hapi 29: Pjesa 1. Ndërtimi i një Moduli PWM për Servo Motors

Sillni axi_timer_0 pwm0 në portin e ri të daljes pwm_Xaxis

Sillni axi_timer_1 pwm0 në portin e ri të daljes pwm_Zaxis

Hapi 30: Lidhjet anësore të hyrjes së videos (e theksuar aklk)

Lidhjet anësore të hyrjes së videos (e theksuar aclk)
Lidhjet anësore të hyrjes së videos (e theksuar aclk)

Lidhni blloqet IP të anës së hyrjes së videos në mënyrë korrekte

(* këto lidhje duhet të krijohen duke zgjedhur opsionet e duhura gjatë automatizimit të lidhjes) "aclk" nga aksi_stream_capture shkon në:

  • ap_clk në tampon të kornizës së videos shkruaj
  • ap_clk në bllokun e përpunimit të rrjedhës video HLS
  • *aklk në AXI smartconnect IP nga Buffer Video Frame Shkruani në S_AXI_HP0
  • *aclk që korrespondon me kanalet e IP -së AXI Interconnect për kanalet S_AXI të bllokut të përpunimit të videos HLS dhe tamponit të kornizës video shkruani S_AXI_HP0_ACLK në bllokun PS

Sinjali i transmetimit video lidhet thjesht në seri nga blloku i kapjes në ndërfaqen e kujtesës Zynq.

  • Video kalon nga blloku i kapjes në bllokun e përpunimit HLS.
  • Videoja e përpunuar nga blloku HLS shkon në bllokun e shkrimit të tamponit të kornizës.
  • *Blloku i shkrimit tampon i kornizës lidhet me ndërfaqen HP0 në bllokun Zynq PS.
  • Sinjali m_axis_tuser nga dalja e bllokut të kapjes lidhet me dorë si në sinjalin e hyrjes video_in_TUSER në bllokun e përpunimit HLS ashtu edhe në sinjalin ap_start në të njëjtin bllok.

Sinjali TUSER (tuser) përdoret nga protokolli i transmetimit video AXI për të treguar fillimin e një kornize të videos. AP_Start i thotë bllokut HLS të fillojë përpunimin. Ne po përdorim kështu tuser për të shkaktuar bllokun HLS për të përpunuar çdo kornizë ashtu siç është hyn. Kur lidhni një sinjal të vetëm të një autobusi dhe e ndani atë në këtë mënyrë, është e nevojshme ta lidhni atë gjithashtu me pikën normale të përfundimit të pjesës tjetër të autobusit. Vivado supozon se nëse e lidhni sinjalin me dorë që dëshironi të shkëputni atë me të cilën normalisht do të lidhej.

Cilësimet e konfigurimit të blloqeve IP:

Tamponi i kornizës së videos shkruani:

Formatet e videos: RGB8

1 mostër për orë Kolona maksimale: 1280 (> = 640) Rreshta maksimale: 960 (> = 480) Gjerësia maksimale e të dhënave: 8

Hapi 31: Lidhjet me OV7670

Lidhjet me OV7670
Lidhjet me OV7670

Në bllokun ov7670_axi_stream_capture

  • Bëni të gjitha hyrjet të jashtme (klikoni me të djathtën në një kunj dhe zgjidhni nga menyja, ose klikoni me të majtën-> ctrl+T)
  • Lërini emrat ashtu siç janë

Në bllokun ov7670_controller

  • Bëni të gjitha daljet e bllokut të jashtme
  • Riemërtoni portën config_finished në led0
  • lidhni clk me CameraClock (<= 50MHz) (FCLK_2)

Në bllokun e debunimit

  • lidhni hyrjen e butonit1 me një portë hyrëse të jashtme të quajtur btn0
  • lidhni out1 me linjën e ri -dërgimit në bllokun IP të ov7670_controller
  • lidhni hyrjen e butonit2 me një portë hyrëse të jashtme të quajtur btn3
  • lidhni out2n me hyrjen ext_reset_in në IP të Rivendosjes së Sistemit të Procesorit për domenin e orës së kapjes së videos. (*Kjo mund të ketë nevojë të bëhet pasi të krijohet IP*)
  • lidhni clk me CameraClock (<= 50MHz) (FCLK_2)

Hapi 32: Lidhjet në Video Out Side

Lidhjet në Video Out Side
Lidhjet në Video Out Side
Lidhjet në Video Out Side
Lidhjet në Video Out Side
Lidhjet në Video Out Side
Lidhjet në Video Out Side
Lidhjet në Video Out Side
Lidhjet në Video Out Side

Lidhjet për blloqet e kontrollit të kohës së videos (VTC), AXI4-Stream to Video Out dhe feta

  • Përdorni orën 25MHz (FCLK_1) për vid_io_out_clk dhe VTC clk
  • Përdorni orën 100MHz (FCLK_0) për aclk në AXI4-Stream to Video Out
  • vtiming_out në vtiming_in
  • Tampon i kornizës së videos Lexo m_axis_video shkon në AXI4-Stream to Video Out video_in
  • vtg_ce shkon në gen_clken
  • Lidheni VTC clken, aclken, vid_io_out_ce me Constant dout [0: 0]
  • Sillni vid_hsync dhe vid_vsync në portat e jashtme të daljes vga_hs dhe vga_vs, respektivisht. (jo ne foto)

Feta:

  • Feta duhet të vendosen siç tregohet në fotot e bashkangjitura
    • riemërtoni blloqet në slice_red, slice_green, dhe slice_blue
    • vargjet e konfigurimit të konfigurimit siç tregohen në imazhe sipas emrit të bllokut
    • lidhni secilën dalje të fetë me një dalje të portit të jashtëm siç tregohet në imazh.
  • vid_data [23: 0] lidhet me hyrjet për secilën fetë (Din [23: 0])

Hapi 33: Drejtoni Automatizimin e Bllokut dhe Lidhjes

Drejtoni Automatizimin e Bllokut dhe Lidhjes
Drejtoni Automatizimin e Bllokut dhe Lidhjes
Drejtoni Automatizimin e Bllokut dhe Lidhjes
Drejtoni Automatizimin e Bllokut dhe Lidhjes
Drejtoni Automatizimin e Bllokut dhe Lidhjes
Drejtoni Automatizimin e Bllokut dhe Lidhjes

Drejtoni Automatizimin e Bllokut për të lidhur gjërat nga blloku PS ZYNQ7. Siç tregohet në foto.

Drejtoni automatizimin e lidhjes për të krijuar të gjithë IP -në e ndërlidhjes. Kushtojini vëmendje të gjitha opsioneve në secilën fotografi.

Në bllokun e daljes, lidheni out2n me domenin e orës së kapjes së videos Procesori i Sistemit Reset ext_reset_in në hyrje.

Hapi 34: Gjeneroni mbështjellës HDL

Gjeneroni mbështjellës HDL
Gjeneroni mbështjellës HDL

Krijoni mbështjellësin HDL për modelin tuaj të bllokut.

Vendoseni atë si modulin kryesor.

Hapi 35: Gjeneroni Bitstream, Eksportoni Hardware në SDK, Nisni SDK Nga Vivado

Sigurohuni që të përfshini bitstream në eksport.

Gjenerimi i bitstream mund të marrë një kohë shumë të gjatë.

Pastaj nisni SDK

Hapi 36: SDK (pa FreeRTOS)

SDK (pa FreeRTOS)
SDK (pa FreeRTOS)

Ky version bën gjithçka pa përdorur FreeRTOS, duke e kondensuar bukur kodin.

Krijoni një BSP të pavarur bazuar në modelin e harduerit. Opsionet e paracaktuara duhet të jenë të mira. Sigurohuni që burimet e BSP të jenë krijuar.

Krijoni aplikacion siç tregohet në figurë. (aplikacion bosh)

Fshini autogjenerimin kryesor dhe importoni skedarët e bashkangjitur.

Hapi 37: Zbatimi i FreeRTOS

Zbatimi i FreeRTOS
Zbatimi i FreeRTOS

Ky version përdor FreeRTOS. Krijoni një BSP FreeRTOS901 bazuar në modelin e harduerit. Opsionet e paracaktuara duhet të jenë të mira. Sigurohuni që burimet e BSP të jenë krijuar.

Krijoni aplikacion siç tregohet në figurë. (aplikacion bosh)

Fshini autogjenerimin kryesor dhe importoni skedarët e bashkangjitur.

Hapi 38: Udhëzimet e përdorimit

Ky projekt është pak i ndërlikuar për tu zbatuar. Ndiqni hapat me radhë.

Sigurohuni që ZYBO juaj të mos ngarkojë asgjë kur të ndizet. Kjo do të thotë që LED i Bërë nuk duhet të ndizet. Një mënyrë për ta bërë këtë është të vendosni kërcyesin e burimit të nisjes në JTAG.

Hapni projektin (FreeRTOS ose jo) që dëshironi të programoni nga SDK

  1. Ndizni ZYBO -në tuaj. LED i Bërë nuk duhet të ndizet.
  2. Programoni FPGA me skedarin bit. LED i Bërë duhet të ndizet. Led0 nuk duhet të ndizet.
  3. Drejtoni kodin (mos harroni të kaloni pikën e fillimit nëse e bëni këtë).

Në këtë pikë ju duhet të merrni një dalje në ekranin tuaj VGA.

Për të rinisur (nëse ka defekte ose çfarëdo): trokitni shpejt butonin PS-SRST ose fikni ZYBO dhe pastaj ndizeni përsëri. Vazhdoni nga hapi 2.

Ndalimi i procesorit me korrigjuesin do të bëjë që Kamera të mbajë pozicionin në vend që të lëvizë. Transmetimi i videos do të vazhdojë gjithsesi.

Hapi 39: Referencat dhe Lidhjet

Udhëzuesit dhe dokumentacioni referues i Xilinx:

  • PG044 - Transmetimi AXI në Video
  • PG278 - Tampon i Kornizës Video Lexoni/Shkruani

Lidhje të tjera:

  • Blogu i Laurit - hyrja VDMA
  • Blogu i Laurit - OV7670 në daljen VGA duke përdorur BRAM
  • Wiki Hamsterworks, nga Mike Fields, burimi origjinal i kodit OV7670
  • Fleta e të dhënave që tregon specifikimet bazë të kohës