150 likes | 296 Views
IPGen: un framework per la generazione automatica di IP-Core per FPGA. Relatore: Prof. Donatella SCIUTO Correlatore: Ing. Marco D. SANTAMBROGIO. Tesi di Laurea di: Matteo Murgida Alessandro Panella. Sommario. Obiettivi e motivazioni Dal core all’IP-Core IPGen nel flusso di Caronte
E N D
IPGen: un framework per la generazione automatica di IP-Core per FPGA Relatore: Prof. Donatella SCIUTO Correlatore: Ing. Marco D. SANTAMBROGIO Tesi di Laurea di: Matteo Murgida Alessandro Panella
Sommario • Obiettivi e motivazioni • Dal core all’IP-Core • IPGen nel flusso di Caronte • Approcci precedenti • Infrastrutture di comunicazione • Struttura dell’IP-Core generato • Struttura del framework e flusso operativo • Convenzioni di utilizzo • Risultati sperimentali • Conclusioni e sviluppi futuri
Obiettivi e motivazioni OBIETTIVO GENERALE • Realizzare un programma in grado di generare automaticamente IP-Core partendo da core forniti in input dall’utente. OBIETTIVI SPECIFICI • Supporto a CoreConnect OPB; • supporto a Wishbone. MOTIVAZIONI • Ridurre il tempo di sviluppo di componenti hardware per architetture modulari; • generare istantaneamente i moduli riconfigurabili nel flusso di Caronte; • incrementare il riuso dei core.
Dal core all’IP-Core • L’interfacciamento avviene “incapsulando” il core all’interno di una struttura contenente: • l’interfaccia di comunicazione; • il supporto a tale interfaccia. • Il risultato viene chiamato IP-Core.
IPGen nel flusso di Caronte • Caronte permette di creare sistemi dinamicamente riconfigurabili partendo da specifiche di alto livello. • IPGen si colloca nella fase di generazione di HW-SSP del flusso di Caronte.
Approcci precedenti Impulse CoDeveloper Interface Adaptor Logic Sintesi di sistemi partendo da specifiche di alto livello Supporto per molti bus Si conoscono a priori le porte dei core da interfacciare Propone un nuovo standard Più leggero di OCP Progetto abbandonato OCP Socket Propone un nuovo standard Descritto dettagliatamente Organizzazione consolidata Bus Wrapper Difficile da utilizzare EDK Create/Import Peripheral Wizard Serve per importare IP-Core in EDK connessi a OPB o PLB Genera i file MHS e PAO Fornisce il template da “riempire” Interface Adaptor Logic OCP Socket Propone un nuovo standard Descritto dettagliatamente Organizzazione consolidata Bus Wrapper Difficile da utilizzare Propone un nuovo standard Più leggero di OCP Progetto abbandonato Impulse CoDeveloper EDK Create/Import Peripheral Wizard Sintesi di sistemi partendo da specifiche di alto livello Supporto per molti bus Si conoscono a priori le porte dei core da interfacciare Serve per importare IP-Core in EDK connessi a OPB o PLB Genera i file MHS e PAO Fornisce il template da “riempire”
Infrastrutture di comunicazione • IPGen supporta due tipi di bus: • CoreConnect OPB, mediante due interfacce: • PSelect • IPIF • Wishbone, non necessita di alcuna interfaccia da istanziare.
Struttura dell’IP-Core generato • In generale tre livelli logici: • Core: funzionalità fornita dall’utente • Stub: logica di comunicazione tra core e interfaccia • IP-Core: top level della struttura • Nel caso Wishbone struttura degenere: • Lo stub coincide con l’IP-Core
Struttura del framework e flusso operativo (1) • Due classi principali: READER e WRITER • Una classe di supporto: CLEANER • READER: • riceve in input il core; • ottiene una stringa contenente l’entity del core pulita dai commenti; • esegue un parsing della stringa; • crea le liste dei segnali di I/O e dei generic.
Struttura del framework e flusso operativo (2) • WRITER: • pulisce il core dai valori di default dei generic; • riceve dal reader le liste dei signali di I/O e dei generic; • crea le descrizioni VHDL dello stub e dell’IP-Core.
Convenzioni di utilizzo • Principio fondamentale: il core non deve contenere alcun riferimento alla logica di comunicazione. La non osservanza di ciò implica: • inutili e dannose ridondanze nell’IP-Core generato; • non riusabilità del core. • Requisiti pratici: • convenzioni di nomenclatura necessarie affinché IPGen riconosca segnali standard: • i segnali di Clock, di Interrupt e di Reset vanno denominati rispettivamente clk, intr e reset; • sono supportati solamente segnali di tipo std_logic e std_logic_vector.
Risultati sperimentali (1) • Due parametri: occupazione e tempo di esecuzione • L’occupazione della IPIF non mostra correlazioni con la dimensione dell’IP-Core; • l’occupazione relativa diminuisce al crescere delle dimensioni del core; • il tempo di esecuzione è sostanzialmente costante.
Risultati sperimentali (2) • Utilizzo di “DUMMY CORE” • core “vuoti” atti a testare le prestazioni di IPGen in particolari situazioni; • RISULTATI SIGNIFICATIVI: occupazione dello stub e tempo di esecuzione aumentano all’aumentare di: • numero di porte del core; • dimensioni delle porte, soprattutto in ingresso.
Conclusioni e sviluppi futuri • Conclusioni: • il framework funziona correttamente; • prestazioni soddisfacenti; • consistente risparmio di tempo in fase di progettazione; • Fast IP-Core Generation in a Partial Dynamic Reconfiguration Workflow, VLSI-SoC 2006 • Sviluppi futuri: • rendere robusta e flessibile la versione attuale del tool; • espandere ad altre interfacce e bus; • supporto per IP-Core di tipo master; • integrare il tool nel flusso di Earendil; • GUI.
FINE PRESENTAZIONE Domande?