Documente Academic
Documente Profesional
Documente Cultură
Fig.5.18 Accesul direct la memorie utiliznd o configuraie master - slave Dup ce controlul a fost preluat de master, circuitul slave rspunde cu HOLDA. Acest semnal poate aprea pe pinul BIO al lui TMS320C2x. Pinul XF al circuitului slave poate fi utilizat pentru a indica master-ului c i-a terminat sarcinile i trebuie reprogramat cu date suplimentare pentru a-i continua lucrul.
13
n schemele cu mai multe circuite slave, prioritile acestora sunt determinate de aplicarea semnalului XF pe una din intrrile INT(2-0) de pe master-ul TMS320C2x. Implementrile n mediul PC constituie un alt exemplu unde magistrala sistem este folosit pentru transfer de date. Aici, circuitul CPU sau controlerul de disc poate plasa datele pe magistrala de date de unde se pot transfera n memoria local a circuitului TMS320C2x. n aceast configuraie, TMS320C2x joac mai mult rolul unui procesor periferic cu funcii multiple. De exemplu, n aplicaii de analiz vocal, TMS320C2x poate fi ncrcat de ctre master cu algoritmi de analiz, sintez i recunoatere de sunete. n alte situaii, TMS320C2x poate lucra cu un controler grafic dedicat. Programele pot fi depozitate n circuitul ROM de pe TMS320C2x sau pot fi ncrcate prin magistrala sistem n RAM. Datele pot proveni de pe hard-disk sau direct din CPU master. Fig.5.19 arat utilizarea DMA ntr-un mediu bazat pe un PC. n aceast configuraie, decoderul i arbitrul de logic este utilizat pentru controlul DMA. Cnd adresa de pe magistral este decodificat n memoria local a perifericului TMS320C2x, logica plaseaz HOLD n "1". Circuitul transmite master-ului un semnal de ateptare. Dup ce TMS320C2x recunoate DMA prin setarea HOLDA, se genereaz READY, apoi se transfer informaiile.
14
Fig.5.20 Comunicaia prin memorie global Dimensiunea memoriei globale este programabil ntre 256 i 32K locaii n memoria de date prin ncrcarea registrului de memorie global (GREG). Dup ce memoria global a fost definit n GREG, circuitul TMS320C2x trimite o cerere de magistral BR naintea fiecrui acces la memoria global. Procesorul insereaz stri de ateptare pn cnd se permite accesul prin generarea READY. Fig.5.20 ilustreaz o asemenea interfa la o memorie global. Procesorul poate fi sincronizat cu SYNC, logica poate fi simplificat, iar transferul pe magistralele de date, respectiv adrese, poate fi fcut mai eficient.
15
Interfaa combo-codec este legat la TMS320C2x prin portul serial i asigur o reprezentare n cod numeric a intrrii analogice. Acest cod PCM poate fi uor translatat ntr-o form liniar n TMS320C2x pentru a fi utilizat n procesare. n schema din Fig.5.21 este utilizat circuitul codec TCM29C16 interfaat pe portul serial al procesorului TMS320C25. 5.5.2 Interfaa la circuite de tip AIC Pentru aplicaii de voce, n modemuri, control, instrumentaie i alte interfee analogice pentru DSP, este necesar o pereche A/D i D/A complet. Circuitul de interfa analogic (AIC - Analogic Interface Circuit) TLC32040 are ncorporat ntr-un singur circuit monolitic CMOS un filtru trece-band, un condensator de netezire, un filtru de intrare i unul de ieire cu capaciti comutate. Acest circuit ofer numeroase alternative posibile pentru frecvena ceasului master, care poate fi modificat de procesorul care l controleaz. Patru porturi seriale ale acestui circuit pot fi folosite ca interfa pentru TMS320C2x. Deoarece seciunile de transmisie i recepie ale circuitului AIC lucreaz sincron, ele se pot interfaa cu dou registre de deplasare serie - paralel SN74299 care la rndul lor pot fi legate paralel la TMS320C25. Sunt emise impulsuri corespunztoare pentru a informa procesorul c transmisia este ncheiat, sau pentru a diferenia doi octei de date consecutivi.
Fig.5.23 Diagramele sincronizrii TLC32040 cu TMS320C2x Aa cum se arat n Fig.5.22, circuitul AIC se poate interfaa cu procesorul TMS320C2x; ele pot comunica sincron sau asincron, aceasta depinznd de
Procesoare numerice de semnal - Cap. 5 17
coninutul registrului de control. Pentru comunicarea sincron, secvena de funcionare este urmtoarea: 1) FSX sau FSR este trecut n "0" 2) Este transmis / recepionat un cuvnt pe 16 bii 3) FSX sau FSR trec n "1" 4) Pe EODX sau EODR se emite un impuls de "0" Pentru comunicaii asincrone, secvena este identic, dar FSX i FSR nu se genereaz n acelai timp (Fig.5.24). Pentru o funcionare corect, TxM din registrul de control poate fi trecut n "0", deci FSX devine intrare, bitul de format (FO) trecut n "0" i AIC WORD/BYTE n nivel ridicat. Dup fiecare operaie serial cu AIC se genereaz o ntrerupere intern RINT sau XINT, care pot fi folosite pentru controlul execuiei programului.
Fig.5.24 Comunicaia asincron TLC32040 i TMS320C2x 5.5.3 Interfaa la convertoare D/A Funcionarea la o vitez ridicat a logicii interne a circuitului TLC7524 de 8 bii permite o interfaare la TMS320C2x cu un numr minim de circuite externe.
Fig.5.26 Diagramele interfarii TLC7524 cu TMS32020 Cnd TMS32020 execut o instruciune OUT, pe magistrala de adrese este plasat adresa perifericului i linia IS trece n "0". Acest nivel pe IS valideaz 74ALS138 care decodific adresa de pe magistral la ieirea Y0. Cnd Y0 va fi trecut n "0", este validat TLC7524, iar datele care apar pe magistrala de date sunt trecute n convertorul D/A de ctre semnalul STRB. 5.5.4 Interfaa la convertoare A/D Circuitul TMS320C2x poate fi interfaat cu un convertor A/D de 8 bii, de exemplu TLC0820. n acest caz, deoarece circuitul de control al acestui circuit opereaz mult mai lent ca TMS32020, el nu poate fi conectat direct, necesitnd stri de ateptare (Fig.5.27 i Fig.5.28).
Fig.5.28 Diagramele interfarii TLC0820 cu TMS32020 Circuitul 74LS138 decodeaz adresa pentru TLC0820. Una dintre adrese este utilizat cnd se execut operaia de scriere, cealalt la citire. Cele dou adrese diferite sunt necesare pentru a asigura folosirea unui numr corect de stri de ateptare pentru cele dou operaii. Dac TMS320C2x funcioneaz cu 20 MHz i TLC0820 este configurat ca o memorie lent, sunt necesare 3 stri de ateptare pentru a realiza un ciclu de scriere. Dup ce conversia a nceput cu WR, procesorul trebuie s atepte cel puin 600ns nainte ca rezultatul conversiei s poat fi citit. 5.5.5 Porturi de I/O Aceste porturi sunt tratate de TMS320C2x n mod identic cu memoria, distincia fcndu-se prin semnalul IS care devine "0" la nceputul unui ciclu de acces. Procesorul poate avea acces la 16 porturi de intrare i ieire. Cei 4 bii mai puin semnificativi ncepnd cu LSB specific adresa unui port. O pereche de circuite 74AS138 se pot utiliza pentru decodarea acestor bii de adres (Fig.5.29).
O interfa simpl ntre dou procesoare poate fi implementat utiliznd pn la 16 porturi bidirecionale I/O conectate la TMS320C2x. n aceast manier, procesorul poate fi conectat cu convertoare paralele A/D, registre, FIFO, memorii dublu-port sau alte periferice. Utilizarea unui microcontroler pe 8 bii cum este TMS70C42 proiectat pentru control de claviatur este artat n Fig.5.30. Semnalele schimbate de procesor i TMS320C2x arat cnd datele sunt valide la citire. Aceast comunicare ntre procesoare este facilitat de utilizarea pinilor de intrare i ieire ai lui TMS70C42. ntr-o configuraie multiprocesor spaiul de memorie pentru adrese este relativ limitat, iar transferul datelor este relativ lent n comparaie cu DMA sau n configuraia cu memorie global.
de 32ms) fr memorie de date sau de program extern. Fig.5.31 arat o aplicaie unde un eliminator de diafonie utilizeaz circuitul de interfa de tip codec TMS29C16.
Fig.5.31 Eliminator de ecou 5.6.2 Modem de vitez ridicat n aceste modemuri, procesorul de semnal este utilizat pentru a realiza funcii ca: modulare / demodulare, egalizare adaptiv i eliminarea diafoniei. Spaiul larg de memorie asigurat de TMS320C2x permite implementarea a multiple standarde ca: Bell 103, Bell 212A, V.22bis, V.29, V.32 i V.33 ca i algoritmi proprii. Modemul prezentat n Fig.5.32 este format n principal din interfaa la gazd, controler, DSP i interfaa analogic.
Fig.5.32 Modem de vitez ridicat 5.6.3 Codor de voce Tehnicile avansate de prelucrare ca: modulaia diferenial a impulsurilor n cod full-duplex de 32 Kbps (definite de CCITT G.721), codarea sub-band de 16 Kbps i codarea predictiv liniar, sunt frecvent utilizate n transmisia i stocarea de voce. Viteza de lucru a TMS320C2x permite aceste prelucrri de obicei prin program, fr a se apela la alte resurse externe. Fig.5.33 prezint un sistem codor de voce.
22
Fig.5.33 Codor de voce 5.6.4 Grafic i procesare de imagine n aceste aplicaii, posibilitatea de interfaare cu un procesor gazd este important. TMS320C2x poate fi utilizat ntr-o mare varietate de scheme tip gazd / coprocesor (Fig.5.34). Aceste aplicaii pot utiliza spaiul larg de memorie de date i capacitatea memoriei globale de a permite depozitarea n memorie a imaginilor grafice, ceea ce reduce volumul de date manipulate n sistem.
Fig.5.34 Sistem grafic cu DSP Folosirea modurilor de adresare indirecte sau indexate ale TMS320C2x permite procesarea matricilor, iar multiplicarea matricilor este folosit pentru rotaii i translaii de imagini bidimensionale. 5.6.5 Controlul proceselor rapide Aplicaiile de mare vitez, cum este robotica, utilizeaz aceste circuite pentru manipularea biilor, operaii logice, sincronizare i transfer rapid de date (10 mil.
Procesoare numerice de semnal - Cap. 5 23
De cuvinte pe 16 bii / secund). n afar de controlul numeric intensiv, TMS320C2x apare ca o interfa gazd ori de cte ori robotul vrea s comunice cu un procesor central (Fig.5.35). TMS320C2x se mai utilizeaz n sisteme de control n bucl nchis, n drivere de disc, pentru condiionarea semnalelor, filtrare i multiplexare multici.
Fig.5.35 Subsistem pentru controlul unui bra robot 5.6.6 Instrumentaie cu procesare numeric Instrumentaia de precizie, cum este cazul unui analizor de spectru, necesit un spaiu de memorie de date larg, i un procesor TMS320C2x care poate s realizeze transformate FFT de lungime mare, sau generare de funcii de nalt precizie folosind echipament extern minim. Fig.5.36 arat un astfel de exemplu de sistem de instrumentaie.
24