Forum: FPGA, VHDL & Co. XC9572 Verschiedene Clocks und I²C


von tobias1503 (Gast)


Lesenswert?

Hallo,

hab da ein paar Fragen an euch.

Versuche derzeit einen Wandler von Analogaudio auf AES3 zu bauen. Ich 
habe nun vor mit einem Xilinx CPLD (XC9572) die Clocks für I²S zu 
generieren.
Da ich die Samplingfrequenz für die Wandler variabel gestalten will, 
habe ich vor den CPLD als Slave mit einem Atmega als Master zu 
verbinden. Habe da an I²C gedacht.
Wie kann ich nun zum einen die Taktteilung für I²S (Quarzoszillator 
49,152 MHz) und die I²C Übertragung (100 kHz) unter einen Hut bringen.

Mir ist aktuell nicht so ganz klar, ob ich einen der Clock Eingänge des 
CPLD`s für den Quarzoszillator und den anderen für die Clockleitung von 
I²S unabhängig voneinander verwenden kann.

Gruß,
Tobias

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


Lesenswert?

> Habe da an I²C gedacht.
Nimm SPI, das ist wesentlich einfacher zu implementieren, weil es 
eigentlich nur ein Schieberegister ist: 
http://www.lothar-miller.de/s9y/categories/26-SPI-Slave

> Wie kann ich nun zum einen die Taktteilung für I²S (Quarzoszillator
> 49,152 MHz) und die I²C Übertragung (100 kHz) unter einen Hut bringen.
Wenn dir ein eventuell auftretender Glitch in der Taktfrequenz beim 
Eintakten und Umschalten eines neuen Teilers nichts ausmacht, dann 
kannst du das ganz einfach asynchron zueinander machen.

Zudem hast du mit 72 FFs nicht sehr viel Platz im CPLD.... :-o

> Mir ist aktuell nicht so ganz klar, ob ich einen der Clock Eingänge des
> CPLD`s für den Quarzoszillator und den anderen für die Clockleitung von
> I²S unabhängig voneinander verwenden kann.
Du kannst sogar jeden x-beliebigen Eingang zum lokalen Takten der FFs 
nehmen.

von tobias1503 (Gast)


Lesenswert?

Hi,

Danke erstmal für deine Antwort. Werde mir deinen Vorschlag mit SPI mal 
ansehen.

Das mit dem Glitch während der Taktumschaltung ist kein Problem, da ich 
während des Umschaltvorgangs die Ausgänge der Wandler Mute.

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


Lesenswert?

> Das mit dem Glitch während der Taktumschaltung ist kein Problem
Dann kannst du sogar mit den SPI-FFs direkt auf den Vergleicher gehen 
und sparst dir so eine Registerebene.

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.