Hallo, Ich möchte mit einen gemultiplexten 8-Bit Bus ansteuern. Die entity hat 4 Eingänge und 1 Ausganung, und den IO-Bus (inout). Die 4 Eingänge werden nacheinander am IO Bus ausgegeben, dann soll der IO-Bus an den Ausgang gelegt werden. Mein Problem ist der Ausgang. Ich möchte keinen Process oder gar Statemaschine verwenden. Eine MUX mit einer with - select Anweisung ist klar. Nur wie behandle ich den Fall wenn der MUX den IO-Bus an den Ausgang leiten soll? iobus<=in0 when mux="000" else iobus<=in1 when mux="001" else out<=iobus when else; das funktioniert ja nicht..... währe über jede Hilfe dankbar
> iobus<=in0 when mux="000" else > iobus<=in1 when mux="001" else > out<=iobus when else; Wenn Du das letzte "when else" weglässt passt das doch.
iobus<=in0 when mux="000" else
in1 when mux="001" else
in2 when mux="010" else
in3 when mux="011";
out<=iobus when mux="1--";
dieser code läst sich compilieren, wird er bei der synthese die
gewünschte funktion erzeugen?
Gehts auch mit with-select?
MFG Matthias
So stimmt's (noch) nicht.
- Wenn der Multiplexer "0--" ist, dann werden die Eingänge in0..in3 an
den iobus gelegt -> iobus ist dann für Deine entity ein Ausgang. In
diesem Fall wird der Bus getrieben, ansonsten muß der Ausgang der entity
hochohmig sein, sonst würdest Du ja die Daten stören, die von außen
kommen.
DataOut <=in0 when mux="000" else
in1 when mux="001" else
in2 when mux="010" else
in3;
iobus <= DataOut when mux="0--" else "ZZZZZZZZ";
- Wenn der Multiplexer "1--" ist, dann werden die Daten des iobus an den
Ausgang gelegt.
Wenn Du schreibst
out<=iobus when mux="1--";
dann wird ein Latch erzeugt, weil sich der Ausgang out den letzten
gültigen Wert merken muß. Dieses Latch kann unter Umständen sogar
schlecht funktionieren, weil Glitches am mux-Signal auftreten können.
Besser ist es out fest mit iobus zu verbinden ( lesen darf man immer)
das Signal synchron zu einem Taktsignal abzutakten wenn der Multiplexer
"1--" ist.
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.