Forum: FPGA, VHDL & Co. Deserializer


von joe (Gast)


Lesenswert?

Hallo zusammen,

meine Aufgabe ist, einen Deserializer auf 24 bit parallel zu 
programmieren.
Im Ruhezustand ist das serielle Eingangssignal = '1', es folgt ein 
Startbit ('0') und darauf die Bitfolge '1', '0', '1'... bis zum Stoppbit 
('1'), wonach wieder Ruhe folgt.

Wie schaffe ich es, mit dem Startbit einen Counter loslaufen zu lassen, 
der dann 24 CLK-Cycles zählt, um die aufgelaufenen Bit parallel auf den 
Output zu schieben?

Viele Grüße,
joe

von Panzer H. (panzer1)


Lesenswert?

Flankenerkennung startet Zähler. Zähler wird bei 23 zurückgesetzt.
Zähler zählt und referenziert die einzelnen Bits eines 24-Bit-Registers, 
um dorthin die Bits zu schreiben. Wenn Zähler zurückgesetzt wird, wird 
parallel auf Output geschoben. Oder das register wird direkt auf Ausgang 
gelegt.

Das genaue Timing musst Dir nochmal überlegen...

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


Lesenswert?

joe schrieb:
> Im Ruhezustand ist das serielle Eingangssignal = '1', es folgt ein
> Startbit ('0') und darauf die Bitfolge '1', '0', '1'... bis zum Stoppbit
> ('1'), wonach wieder Ruhe folgt.
Mal abgesehen von der bisher undefinierten Bitdauer ist das bis hierher 
ein abgewandeltes RS232-Protokoll...

Hast du zu deinen Daten noch einen Takt oder läuft das Ganze asynchron?
Wie schnell kommen die Bits?

von joe (Gast)


Lesenswert?

Die Bits kommen mit halber CLK-Frequenz.
Eines meiner Probleme ist folgendes..
Mit Auftreten des Startbits soll der Zählvorgang gestartet werden, darf 
aber von keiner weiteren Änderung des seriellen Input-Stroms abhängig 
sein.
Ab dem Moment sollen der Takt den Zähler bestimmen.
An diesem Punkt hänge ich und finde keinen Ausweg...

von joe (Gast)


Lesenswert?

Danke für eure Hilfe, mit einem counter_enable Signal gehts...

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.