160 likes | 325 Views
Koncepcja refaktoryzacji kodu w języku VHDL. V I II Krajowa Konferencja Naukowa. RUC'200 5 REPROGRAMOWALNE UKŁADY CYFROWE. Przemysław Sołtan e-mail: kerk @ ie.tu.koszalin.pl. Wprowadzenie. Koncepcja refaktoryzacji Przykład prostego przekształcenia Model dokumentu (drzewo AST)
E N D
Koncepcja refaktoryzacji kodu w języku VHDL VIII Krajowa Konferencja Naukowa RUC'2005REPROGRAMOWALNE UKŁADY CYFROWE Przemysław Sołtan e-mail: kerk@ie.tu.koszalin.pl
Wprowadzenie • Koncepcja refaktoryzacji • Przykład prostego przekształcenia • Model dokumentu (drzewo AST) • Złożona refaktoryzacja kodu • Platforma ECLIPSE i projekt VDT (Vhdl Development Toolkit) • Kierunki rozwoju projektu • Podsumowanie
Przebieg procesu projektowego granica spełnienia zadanej funkcjonalność Automatyzacja niektórych czynności może wpłynąć na skrócenie czasu modyfikacji kodu funkcjonalność czas Obszary czasu przeznaczane na modyfikację kodu bez rozszerzania jego funkcjonalności
Koncepcja refaktoryzacji • Termin refaktoryzacjadefiniuje się jako mechanizm zmiany struktury kodu bez zmiany jego zachowania(funkcjonalności) • ułatwienie pielęgnacji kodu projektu(modyfikacje) • sprawdzanie integralności zawartych danych i ich zgodności z semantyką języka na poziomie edycji kodu • mechanizmy automatycznego generowania dodatkowego kodu
Koncepcja refaktoryzacji Mechanizmy: • analiza kodu źródłowego (parser) do budowy modelu (drzewa AST) • edytor wraz z widokami do komunikacji z użytkownikiem • biblioteka do kontroliprocesu refaktoryzacji Projekt VHDL (przed refaktoryzacją) PARSER (drzewo AST) Biblioteka do refaktoryzacji Projekt VHDL (po refaktoryzacji) Aktualizacja widoku Polecenie refaktoryzacji Model View Controller Widok Użytkownika Edytor
Refaktoryzacja i język VHDL • Języki obiektowe (Java, C++) operują na podstawowych elementach jak: zmienne, funkcje i klasy. • Języki obiektowe (Java, C++) złożone mechanizmy: dziedziczenia, poliformizmu, ... • VHDL dużo większa liczba elementarnych typów: zmienne, sygnały, porty, entity, architektury, ... (złożoność mechanizmów modyfikacji nazw) • VHDL przekształcenia uwzględniające współbieżność (procesy), operacje na pakietach oraz konfiguracjach kodu (do ustalenia i realizacji).
entityNewName ENTITY ARCHITECTURE ... ARCHITECTURE COMPONENT PORT MAP ... Przykład prostego przekształcenia entity entityOldName is port(in1 : in bit; out1 : out bit); end entityOldName ; architecture architectureName1 of entityOldName is begin -- code end architectureName1; architecture architectureName2 of entityOldName is begin -- code end architectureName2; entity entityTestName is port(in1 : in bit; out1 : out bit); end entityTestName; architecture architectureTestName ofentityTestName is component entityOldName port(in1 : in bit; out1 : out bit); end component ; begin comp1: entityOldName port map (in1,out1); -- rest of port map component end architectureTestName; Przykładowy kod VHDL
entityNewName ENTITY ARCHITECTURE ... ARCHITECTURE COMPONENT PORT MAP ... Przykład prostego przekształcenia Proces zmiany nazwy entity wymusza realizację kilku elementarnych operacji: • wskazanie elementu określającego starą nazwę entity (entityOldName) i podania nowej nazwy (entityNewName); • sprawdzenie, czy nowa nazwa nie koliduje z już istniejącymi nazwami; • wyszukanie bloku danego entity (zmiana nazwy); • wyszukanie architektur dla danego entity (zmiana nazwy); • wyszukanie w blokach architektur komponentów danego entity (zmiana nazwy); • wyszukanie wszystkich mapowań komponentów danego entity (zmiana nazwy).
Model dokumentu drzewo AST (Abstract Syntax Tree) AST ENTITY (name: entityOldName ) E PORT (name:in1,type:in,type2:bit) P PORT (name:out1,type:out,type2:bit) P ARCHITECTURE (name:architectureName1,entity: entityOldName ) A ARCHITECTURE (name:architectureName2,entity: entityOldName ) A ENTITY (name:entityTestName) E PORT (name:in1,type:in,type2:bit) P P PORT (name:out1,type:out,type2:bit) A ARCHITECTURE (name:architectureTestName,entity:entityTestName) COMPONENT (name: entityOldName ) C PORT (name:in1,type:in,type2:bit) P entityNewName PORT (name:out1,type:out,type2:bit) P INSTANCE (name:comp1, type: entityOldName ) I Przy wyszukiwaniu wystarczy analizować tylko określone węzły drzewa MAP (from:in1, to:in1) M MAP (from:out1, to:out1) M
Złożona refaktoryzacja kodu EDYTOR Projekt VHDL PLIK1.vhd MODEL AST BIBLIOTEKI PLIK2.vhd STANDARD PLIK3.vhd IEEE mała Złożoność przekształceń: elementarne metody przeszukiwania drzewa elementarne przekształcenia (rename, move, delete, insert) złożone przekształcenia realizowane na bazie sekwencji prostych przekształceń (transakcje i praca na kopii roboczej) duża
Katalog wzorców VHDL?! Podstawowym celem jest selekcja i wybór takich rozwiązań, które zostaną zaimplementowane w aplikacji do refaktoryzacji kody VHDL Opis wzorca powinien zawierać (motywację, mechanizm oraz przykłady) Przykłady do ewentualnej implementacji: • Zamiana instrukcji if na case i na odwrót; • Wyszukiwanie nieużywanych fragmentów kodu (np. zbędnych sygnałów) • Podział komponentu (ekstrakcja części kodu do nowego komponentu) • Wstawianie/ modyfikacja portów w blokach entity (automatyczna aktualizacja bloków component i port map) • Generacja/aktualizacja testbenchy • Wstrzykiwanie kodu asercji i ich automatyczne usuwanie
Platforma ECLIPSE ECLIPSE – darmowe narzędzie projektowe IDE • Bogactwo projektów i wtyczek (plug-ins) • Darmowe rozwiązanie nawet do zastosowań komercyjnych. • Rewelacyjne mechanizmy refaktoryzacji dostępne dla języków obiektowych: Java i C++ • Integracja różnego typu technologii w jednym narzędziu: J2EE, XML, PHP, Perl, Python, ... • VERILOG http://veditor.sourceforge.net/ • VHDL brak??! • Potężne wsparcie przemysłu $$$ - projekt jest rozwijany przez etatowych programistów
Kto „lubi” ECLIPSE? Embedded Development Kit (EDK) Nios II Embedded Processors
VDT - architektura VDT PROJECT ECLIPSE PLATFORM CORE SCANNER PARSER AST MODEL WORKBENCH PDE UI EDITOR OUTLINE Platforma ECLIPSE modułowa budowa (Plug-ins): wtyczki JDT, CDT, PyDEV do refaktoryzacji kodu określonych języków (java, C++, python) VDT – wtyczka do refaktoryzacji kodu VHDL (pakiety CORE oraz UI) licencja CPL - http://www.eclipse.org/legal/cpl-v10.html
VDT - rozwój biblioteki • Integracja z biblioteką LTK (Eclipse Language Toolkit) wspierającą mechanizmy refaktoryzacji • Opracowanie zestawu testów (przykłady do katalogu wzorców) • Generacja dokumentacji (HTML) na podstawie modelu (na wzór JavaDoc) • Integracja narzędzia z zewnętrznym symulatorem VHDL (FreeVHDL?!) • Wydanie stabilnej wersji projektu – aktualnie jest to wersja eksperymentalna http://kik.ie.tu.koszalin.pl/mvl/vdt