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
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...
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?
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...
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.