Forum: FPGA, VHDL & Co. Zähler in VHDL


von Tom (Gast)


Lesenswert?

hi!

ich möchte in Quartus2 einen Zähler in VHDL realisieren (cyclone3 fpga). 
nun gibt es folgendes problem:

ab einer bestimmten registerbreite funktioniert der zähler nicht mehr 
richtig.

es beispielsweise bis 4000000 gezählt werden. geht aber nicht. 4000 
funktioniert.


eigentlich sollte das doch gehen, oder ist eine beschränkung des 
zahlenbereichs vorgesehen?

danke und gruß

von Lothar M. (Firma: Titel) (lkmiller) (Moderator) Benutzerseite


Lesenswert?

> eigentlich sollte das doch gehen,
Ja.
> oder ist eine beschränkung des zahlenbereichs vorgesehen?
Nur, wenn du z.B. einen integer selber einschränkst (z.B. mit range 0 to 
10000), oder wenn die Breite deines Zählregisters nicht ausreicht (z.B. 
std_logic_vector(10 downto 0)).

Welchen Datentyp hat der Zähler?

von Tom (Gast)


Lesenswert?

der zahlenbereich ist ausreichend groß gewählt.

habs als integer und std versucht. echt seltsam.

von Iulius (Gast)


Lesenswert?

Probiers mal mit :

counter : unsigned (31 downto 0) := (others => '0');


Oder aber du resettest den Zähler eventuell irgentwo ohne das es dir 
auffällt.

von Thomas R. (Firma: abaxor engineering) (abaxor)


Lesenswert?

Tom schrieb:
> hi!
>
> ich möchte in Quartus2 einen Zähler in VHDL realisieren (cyclone3 fpga).
> nun gibt es folgendes problem:
>
> ab einer bestimmten registerbreite funktioniert der zähler nicht mehr
> richtig.
In der Simulation oder im FPGA

>
> es beispielsweise bis 4000000 gezählt werden. geht aber nicht. 4000
> funktioniert.

Zur Darstellung von 4.000.000 brauchst du 22 Bit, je nach Taktfrequenz 
und FPGA kann die Zeit, die der Übertrag vom LSB ins MSB braucht, zu 
lang (länger als eine Periode) sein. Dann zählt der Zähler nicht mehr 
richtig.

Tom

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.