www.mikrocontroller.net

Forum: FPGA, VHDL & Co. Serielle Schnittstelle für PC <-> FPGA Kommunikation


Autor: MIcha (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo,

ich bin auf der Suche nach einer Lösung für das folgende Problem:

Ein FPGA soll eine Messung machen und das Ergebnis über die serielle
Schnittstelle an den PC senden. Die Messung wird auch vorgenommen,
allerdings weiß ich noch nicht, wie ich die VErbindung PC-Com-Portt
herstellen soll.

Zur VErfügung steht das Quartus II Software PAket von Altera und das
CycloneII Dev Kit.
Hier habe ich schon versucht, den SOPC-Builder einzusetzen was aber
nicht geglückt ist.

Wie ist denn das Standard Vorgehen bei solchen Sachen?
Vielleicht hat ja jemand eine Lösung oder eine gute Hilfe parat.

Gruß Micha

Autor: Jürgen Schuhmacher (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Eine UART in HDL schreiben oder eine vorhandene (opencores) anpassen. Du
lernst aber am meisten, wenn Du die UART selber schreibst. Im
einfachsten Fall ist das ein 4-Bit Zähler mit 2400 Hz, der bis 15 zählt
und dann einfach einen Port i.A. der Zählerstandes bedient:

Zähler = 1 -> Port = '1'
Zähler = 2 -> Port = '1'
Zähler = 3 -> Port = '1'
Zähler = 4 -> Port = '0'  <- Start-Bit
Zähler = 5 -> Port = Bit7  <- wort(7)
....
Zähler = 12 -> Port = Bit 0
Zähler = 13 -> Port = Parity
Zähler = 14 -> Port = '1' <- Stopp-bit
Zähler = 15 -> Port = '1'; wort <= datain;

Beim Zählerstand 15 wird ein eventuell am "datain" liegender neuer
Wert in den Puffer "Wort" übernommen, sodaß "wort" zu beliebiger
Zeit aktualisiert werden kann.

Autor: Dirk (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo,

als Anfänger kann der UART Core sehr schwierig sein. In diesem Logic
Analyzer http://www.mikrocontroller.net/forum/read-4-376571.html#new
befindet sich zwei Module: Receiver und Transmitter. Schau es Dir ruhig
an.

Gruß,
Dirk

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [vhdl]VHDL-Code[/vhdl]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.