Forum: FPGA, VHDL & Co. VHDL - ModelSim Warning: NUMERIC_STD.TO_SIGNED: vector truncated


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.
von Christian (Gast)


Lesenswert?

1
cram_data : IN signed (17 downto 0);
2
cram_data <= to_signed(16#31415#, cram_data'length);

Diese Zeilen ergeben die folgende (korrekte) Warnung vom vsim:

Warning: NUMERIC_STD.TO_SIGNED: vector truncated

Das macht das Tool vmtl., weil die 5-stellige Integer Zahl als 20-bit 
(5x4-bit) Zahl interpretiert wird, sie aber einer 18-Bit Zahl zugewiesen 
wird.

Ich würde diese Warnung gerne verhindern, habe aber keine Idee wie ohne 
die Konstanten z.B. ins binär Format zu übersetzen.

Gibt es dazu eine Lösungsidee?

Es handelt sich hier um eine große Anzahl von Konstanten die in ein RAM 
geschrieben werden...

von einfach (Gast)


Lesenswert?

1
...
2
3
  SIGNAL cram_data_20bit : SIGNED(19 DOWNTO 0);
4
5
...
6
7
  cram_data_20bit <= to_signed(16#31415#, cram_data_20bit'LENGTH);
8
9
  cram_data       <= cram_data_20bit(cram_data'RANGE);

von Christian (Gast)


Lesenswert?

Funktioniert super, Danke!

von Christian (Gast)


Lesenswert?

(habe natürlich eine variable und kein Signal genommen)

von Testuser (Gast)


Lesenswert?

Christian schrieb:
> (habe natürlich eine variable und kein Signal genommen)

ARGH! Hoffentlich aus gutem Grund.

von Tippgeber (Gast)


Lesenswert?

Testuser schrieb:
> ARGH! Hoffentlich aus gutem Grund.

Macht an der Stelle kein Problem. Im Gegenteil: da das "signed20" nur 
ein Hilfskonstrukt ist, braucht es kein Signal.

@TE das ganze geht sauber auch gut mit "resize" ausgehend vom voll 
belegten Vektor.

von Blechbieger (Gast)


Lesenswert?

In VHDL-2008 sollte auch
1
cram_data <= signed(18x31415);

oder so ähnlich gehen.

https://www.doulos.com/knowhow/vhdl/vhdl-2008-easier-to-use/#bistring

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]
  • [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.

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