mikrocontroller.net

Forum: FPGA, VHDL & Co. Zählerabhängige Operationen im CPLD


Autor: Benedikt (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Ich versuche gerade einen einfachen 640*400 VGA Controller in VHDL für
einen XC95xx zu programmieren, aber ich komme mit den Pixelzählern/Sync
Signalen nicht weiter:
Wie schreibe ich folgende Operationen:
Pixelzähler < 50: Ausgang=0
Pixelzähler >=50, <690: Ausgang=RAMInhalt
Pixelzähler >=690, <700: Ausgang=0
Pixelzähler >=700: Ausgang=0, HSync=1

Wie kann ich also die kleiner, größer Operatoren in VHDL einbinden ?

Autor: OTobias (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Pixelzähler muss natürlich Integer oder Natural Format sein
ansonsten hilft auch bei so einer einfachen Problemstellung jedes
VHDL Buch


U1 : process (Pixelzähler) is
begin

if (Pixelzähler < 50) then
 Ausgang <= '0';
else if (Pixelzähler >= 50) and Pixelzäler < 690) then
Ausgang <= RamInhalt ;

--Hier deine Restlichen Bedingungen Bla Bla Bla
end if;
end process U1;

Autor: tobias hofer (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Ausgang <= (others => '0') when (pixelzähler < 50) else
           RAMInhalt when (pixelzähler >=50) and (pixelzähler <690)
else ...usw.

das '0' in der others anweisung muss natürlich mit dem datentyp
RAMInhalt übereinstimmen.


das ganze geschieht natürlich asynchron sonst mit einem prozess lösen.
in einem process kannst du dann aber die obige anweisung nicht
gebrauchen dann eben

vga: process(CLK)
     begin
        if reset = '1' then
         --hier reset
        else clk'event and clk = '1' then
          if pixelzähler < 50 then
          --hier singanl zuweisung
        end if
     end process vga;

in etwa so

gruss tobias

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.