Forum: FPGA, VHDL & Co. Syntax frage


von René D. (Firma: www.dossmatik.de) (dose)


Lesenswert?

constant tick : unsigned := 434;

Ich bekomme error
 Type of tick is incompatible with type of 434.

Wie ist der Ausdruck korrekt?

Danke

von Andreas S. (andreas) (Admin) Benutzerseite


Lesenswert?

Beim nächsten Mal bitte im Betreff angeben um welche Sprache es geht.

Der Typ "unsigned" ist in VHDL nicht einfach ein Integer-Typ wie in C, 
sondern ein Vektor aus std_logic. Direkte Zuweisung von Integern 
funktioniert da nicht, man braucht eine Konvertierungsfunktion:
1
constant tick : unsigned := to_unsigned(434, tick'length);

Außerdem sollte man die Länge des Vektors vorgeben, sonst wird das 
Maximum verwendet.

Eine flexiblere und bessere Alternative wäre die Variable als Integer zu 
definieren und erst bei Verwendung zu konvertieren.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.