Sisällysluettelo:
2025 Kirjoittaja: John Day | [email protected]. Viimeksi muokattu: 2025-01-13 06:57
Huolimatta siitä, että FPGA DueProLogic on virallisesti suunniteltu Arduinolle, aiomme tehdä FPGA: sta ja Raspberry Pi 4B -yhteensopiviksi.
Tässä opetusohjelmassa toteutetaan kolme tehtävää:
(A) Käännä RPi -kameran kulma painamalla samanaikaisesti kahta FPGA -painikkeen painiketta.
(B) Raspberry Pi 4B ohjaa FPGA: n ulkoista LED -piiriä.
(C) Suoratoista Raspberry Pi -kamera selaimessa WiFi -yhteyden kautta
Vaihe 1: Rakenna elektroninen piiri
Vaihe 2: Muokkaa Verilog -koodia
Kun ostat FPGA DueProLogicin, sinun pitäisi saada DVD. Kun olet avannut "Projects_HDL", sinun pitäisi nähdä alkuperäinen HDL -kooditiedosto. Kun olet määrittänyt nastasuunnittelijan, lisää korostettu koodi osien 2A, 2B, 2C ja 2D mukaisesti.
2A: Painikkeiden aktivoimiseksi sinun on käytettävä tätä koodia
// Painonappikytkimet
tulojohto UBA,
tulojohto UBB
Jotta voit kommunikoida Raspberry Pi: n kanssa, sinun on lisättävä nämä.
reg sel_send; // aktivoi Raspberry pi
reg rece; // saatu vadelmalta pi
2B: Jos haluat määrittää porteille arvoja, sinun on muokattava koodi vastaavasti
anna XIO_1 [3] = start_stop_cntrl;
antaa XIO_2 [2] = rece; // lähtö HIGH tai LOW LED -piirissä
määritä XIO_2 [3] = ~ UBA; //paina nappia
määritä XIO_2 [4] = UBB; //paina nappia
anna XIO_2 [5] = sel_send; // FPGA lähettää signaalin vadelmapi: lle
anna sel_read = XIO_5 [1]; // FPGA vastaanottaa signaalin vadelmalta pi
anna c_enable = XIO_5 [2]; // XIO_5 - UB57 - D17
määritä LEDExt = XIO_5 [5];
2C: Jos kahta painonappia painetaan samanaikaisesti, FPGA lähettää HIGH -lähdön Raspberry Pi: lle.
aina @(sel_send tai UBB tai UBA) // lähetä RPi: lle
alkaa
jos (UBB == 1'b0 && UBA == 1'b0)
sel_send = 1'b1;
muu
sel_send = 1'b0;
loppuun
2D: FPGA lukee Raspberry Pi -signaalin kellotaajuudella 66 MHz. Portti XIO_2 [2] on linkitetty vastaanottimeen.
aina @(sel_read) // lue pi
alkaa
jos (sel_read == 1'b1)
rece = 1'b0;
muu
rece = 1'b1;
loppuun
Vaihe 3: Lähetä Verilog -koodi
Lataa sitten koottu pof -tiedosto FPGA: han. Jos laitteistoa ei tunnisteta automaattisesti, korjaa se manuaalisesti napsauttamalla "Laitteiston asennus"
Vaihe 4: Lataa Raspberry Pi -koodi
Korostetut linjat mahdollistavat FPGA: n kommunikoinnin Raspberry Pi: n kanssa.
Raspberry Pi -koodi tälle projektille,
A = GPIO.input (pin) #read FPGAprint (A);
jos (A == 1):
camera.rotation = 0
GPIO. output (18, GPIO. LOW) #lähetetään FPGA: lle
jos (A == 0):
kamera. kierto = 180
GPIO. output (18, GPIO. HIGH) #lähetetään FPGA: lle
Vaihe 5: Kokeillaan
Avaa selain ja kirjoita IP -osoitteesi esim. 192.168.xx.xxx:8000.
Loppujen lopuksi järjestelmän pitäisi toimia!