Forum: FPGA, VHDL & Co. MPMC mit eigner IP


von Markus (Gast)


Lesenswert?

Hallo,

brauche eure HILFE.

Hab vor einigen Wochen mit VHDL programmieren angefangen und nun mein 
erstes Projekt abgeschlossen. Jetzt probiere ich auf einem Spartan3 den 
MicroBlaze mit einer eigenen IP und MPMC zu programmieren.

Was geht momentan:
- der MicroBlaze funktioniert mit IP und MPMC, ABER

ich möchte direkt über externe GPIO in den SDRAM schreiben und über den 
MicroBlaze die Daten lesen und per UART senden.

HAb jedoch momentan kein ansatz wie ich Daten direkt vom GPIO in SDRAM 
schreibe. Hab Ihr einen Ansatz? Benötigt man einen DMA-Zugriff? So wie 
das sehe, muss dies doch komplett in VHDL geschehen, oder?

Hoffe und Bitte um Rat.

Gruß, Markus

von Georg A. (Gast)


Lesenswert?

> Benötigt man einen DMA-Zugriff?

Wenn jemand anders als die CPU in den Speicher schreibt ist das mehr 
oder weniger die Konvention, wann es DMA heisst ;) Allerdings solltest 
du dir vorher noch überlegen, was für Datenraten du haben willst und 
ob die HW wirklich selber an der CPU vorbei in den Speicher schreiben 
muss. Bis zu ein paar 100K pro Sekunde wäre es wohl deutlich einfacher, 
das Zeug in ein FIFO zu bekommen, das ab einem bestimmten Füllstand 
(+Timeout) einen Interrupt auslöst. Die UART macht es ja nicht anders.

Wenn es um MB/s pro Sekunde geht, kommst du um DMA nicht herum, ist aber 
auch kein Hexenwerk.

Der MPMC heisst ausgeschrieben "Multi-Port Memory Controller". Von den 
Ports werden ein paar (typ. 3) für den Microblaze gebraucht. Du kannst 
noch einen dazukonfigurieren und mit der in der Doku beschriebenen Art 
auf dem Port Speicherzugriffe durchführen. Es gab früher mal einen 
DMA-Controller, weiss nicht, ob der noch existiert. Der könnte dir etwas 
Arbeit abnehmen. So ganz ohne eigenen Code wird das aber auch nicht 
gehen.

BTW, noch ein Fallstrick: Der Microblaze hat kein Cachekohärenzprotokoll 
für DMA. Wenn der per DMA beschriebene Speicher im cachebaren Bereich 
ist (wird xps per Default so machen), bekommt der MB nichts von einer 
externen Änderung mit, liest also keine neuen Daten. Entweder nimmt man 
den Bereich dann im Cachecontroller raus oder der MB muss vor jedem 
Zugriff auf den Bereich den Cache invalidieren (__invalidate_icache).

von Jannulis T. (tembridis)


Lesenswert?

Markus schrieb:
> HAb jedoch momentan kein ansatz wie ich Daten direkt vom GPIO in SDRAM
> schreibe. Hab Ihr einen Ansatz? Benötigt man einen DMA-Zugriff? So wie
> das sehe, muss dies doch komplett in VHDL geschehen, oder?

Moin,

für dich könnte das NPI Interface (manchmal auch PIM genannt) 
interessant sein. In unserem Projekt benutzen wir dieses auch. Das 
Protokoll ist einfach gehalten und erlaubt sowohl SingleBeat- als auch 
Burst-Zugriffe. Man kann mit wenigen Handgriffen im MPMC IP Dialog ein 
NPI Port freischalten und dann in der Portliste nach draussen führen.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.