mikrocontroller.net

Forum: FPGA, VHDL & Co. Simulation Fehler: Aggregate with multiple choices has a non-static or null choice


Announcement: there is an English version of this forum on EmbDev.net. Posts you create there will be displayed on Mikrocontroller.net and EmbDev.net.
Autor: Fpga I. (fpga-ing)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Hallo zusammen,

ich habe mir in einer Testbench folgendes konstrukt gebaut:
signal InjectError : std_logic_vector(31 downto 0);

myProcess:process
begin
...
  for i in 0 to 31 loop
    InjectError <= (i => '1', others => '0');
    wait for 1 us;
    InjectError <= (others => '0');
    -- auswertung...
  end loop;
...
end process;

Die Zeile InjectError <= (i => '1', others => '0'); gibt mir dabei die 
Fehlermeldung "Aggregate with multiple choices has a non-static or null 
choice. Use -relax to compile aggregates composed of one non-static or 
null choice and choice others."
Natürlich kann ich mit der relax Option die Simulation starten, jedoch 
möchte ich zunächst die Warning genauer verstehen.
Warum führt das potenziell zu Problemen, diese Zuweisung mit mit einem 
Schleifenindex i vorzunehmen? Ersetze ich das i durch eine 1, tritt der 
Fehler nicht mehr auf (statischer Wert).
Wird das others bereits beim kompilieren / elaborieren aufgelöst?
Wie würdet Ihr die InjectError Zuweisung vornehmen? Mir fällt spontan 
folgendes ein:
...
  sInjectError <= (others => '0');
  for i in 0 to 31 loop
    sInjectError(i) <= '1';
    wait for 1 us;
    sInjectError(i) <= '0';
    -- auswertung...
  end loop;
...

Autor: Markus F. (mfro)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
eine "non locally-static choice" ist nur ohne "others" erlaubt.
  for i in 0 to 31 loop
    InjectError <= (others => '0');
    InjectError(i) <= '1';
    wait for 1 us;
    InjectError <= (others => '0');
    -- auswertung...
  end loop;

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.