www.mikrocontroller.net

Forum: FPGA, VHDL & Co. 2-dim Array initialisieren mit "others"


Autor: Hartmut (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo Leute,

ich habe ein zwei-dimensionales Array und moechte es moeglichst elegant
mit Nullen initialisieren. Am besten wie im folgenden Beispiel mit dem
others-operator fuer ein ein-dimensionales Array:
...
type MY_ARR is array(0 to 100) of integer;
variable test_arr : MY_ARR := (others=>0);
...

Autor: FPGA-User (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
wie ist Dein 2-dim Array deklariert ?

Autor: Hartmut (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hi,

ich moechte nach Moeglichkeit einen (x,y) Zugriff haben, daher habe ich
es so deklariert:
...
type IMAGE_MEM is array (0 to XSIZE-1, 0 to YSIZE-1) of PIXEL;
...

Autor: FPGA-User (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
wenn Du mit others arbeiten willst, solltest Du die Deklaration
ändern :

type ARRAY_1 is array (0 to XSIZE-1) of PIXEL;
type ARRAY_2 is array (0 to YSIZE-1) of ARRAY_1;

signal ar : ARRAY_2;

...

ar <= (others=> (others=> 0));

...

ar (X)(Y) <= PIXEL_VAL;

Autor: Hartmut (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo,

vielen Dank, das sieht sehr gut aus. Sorry fuer meine langen
Delayzeiten, aber ich arbeite in Bangalore, Indien.

Habe noch eine Frage. Ich habe das Spartan Starter Kit und moechet ein
auf das FPGA geladenes Programm auch nach dem Aussschalten nutzen
koennen. Was muss ich dafuer machen?

Vielen Dank und schoene Gruesse nach D-Land!

Autor: FPGA-User (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo Hartmut,

viele Grüße nach Indien 8-)

Kenne nicht genau die Hardware des Spartan-Kits, aber
prinzipiell brauchst Du ein Config-PROM oder einen
kleinen Controller, der das Programm nach dem Einschalten
aus einem Flash holt und ins FPGA schreibt.
Möglicherweise gibt es auf dem Board einen Config-PROM
und Du musst über Jumper o.ä. wählen, ob vom Config-PROM
oder von einem anderen Interface aus geladen werden soll.

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.