source: trunk/IPs/systemC/processor/Morpheo/Documentation/Source/Documents/document-morpheo-new_component/fr/root.tex @ 2

Last change on this file since 2 was 2, checked in by kane, 17 years ago

Import Morpheo

File size: 6.9 KB
Line 
1Nous allons détailler les étapes qui doivent être suivit afin de créer un Component du nom de XXX localiser dans le répertoire YYY. Ce dernier étant un sous répertoire de Morpheo/Behavioural. A la fin de chaque étape, il est conseillé de faire des tests.
2
3Tous les tests sont contenus dans le répertoire ./SelfTest. Les fichiers contenus dans ./SelfTest/main sont des jeux de paramètres. Ils sont le points d'entrées de la fonction test contenus dans ./SelfTest/src/test.cpp
4
5\begin{enumerate}
6\item 
7{\bf Initialisation}
8\begin{enumerate}
9\item {\it Morpheo/Behavioural}, éxècutez la commande ./New\_component.sh YYY XXX, puis aller dans le répertoire YYY.
10\end{enumerate}
11\item 
12{\bf Paramètres}
13\begin{enumerate}
14\item {\it ./include/Parameters.h}, définition des constantes définissant les paramètres. (Ne pas oublier les paramètres du constructeur)
15\item {\it ./src/Parameters.cpp}, constructeur et constructeur par copie.
16\item {\it ./src/Parameters\_msg\_error.cpp}, énumérer les conditions d'erreurs.
17\end{enumerate}
18\item 
19{\bf Interfaces}
20\begin{enumerate}
21\item {\it ./include/XXX.h}, Ajout de l'interface.
22\item {\it ./include/Types.h}, Ajout des types composants l'interface.
23\item {\it ./src/Parameters\_msg\_error.cpp}, Ajouter si non effectuer dans l'étape précedente, les erreurs pouvant survenir pour une erreur d'encodage des types.
24\item {\it ./src/XXX\_allocation.cpp}, Allocation des ports d'interface (en fonction des paramètres).
25\item {\it ./src/XXX\_desallocation.cpp}, Désallocation des ports d'interface.
26\item {\it ./SelfTest/src/test.h}, Ajout des signaux interne et instanciation avec l'instance du modèle.
27\end{enumerate}
28\item 
29{\bf SystemC}
30\begin{enumerate}
31\item {\it ./SelfTest/src/test.h}, Ecriture du test en lui même pour les tests combinatoires, ne pas oublier de faire avancer le delta cycle en utilisant sc\_start(0). L'écriture des tests est plus difficle à faire avant l'écriture du code, mais cela ne supposeras alors aucun apriori et permet se baser uniquement sur l'interface vut dans l'étape précedente.
32\item {\it ./include/XXX.h}, Ajout des prototypes des fonctions de Mealy et de Moore. (Prenez comme exemple la fonction ``transition'')
33\item {\it ./include/XXX.cpp}, Ajout de la liste de sensibilité des fonctions de Mealy et de Moore. (Prenez comme exemple la fonction ``transition'')
34\item {\it ./include/transition.cpp}, Ajouter le corps de la fonction de transition. Créez un fichier par fonctions de Mealy et Moore contenus dans le modèle (Prenez comme exemple la fonction ``transition''). Note pour la compatibilité systemCass : un signal ne doit être affecté qu'un seul fois.
35\end{enumerate}
36\item 
37{\bf Statistics}
38\begin{enumerate}
39\item {\it ./include/Statistics.h}, Ajouter les variables qui vont servir de sondes, et pour la fonction ``add'' ajouter également autant de paramètres que de sondes. Si vous devez sonder un ensemble d'élément (port, file, banc de registres), et déterminer l'utilisation moyenne, nous vous proposer la classe Statistics contenus dans {\it Behavioural/Generic/Group/include/Statistics.h}
40\item {\it ./src/Statistics.cpp}, Remplir le corps du constructeur et du destructeur de la classe Statistics.
41\item {\it ./src/Statistics\_print.cpp}, Ajouter le corps de la fonction print contenus dans ce fichier. Son but étant d'imprimer au format XML.
42\item {\it ./src/Statistics\_add.cpp}, Implémentation de la fonction add de la classe Statistics. (Son but étant d'incrémenter les variables de la classe)
43\item {\it ./src/XXX\_transition.cpp}, Dernière étape pour l'ajout des statistics : à la fin de la fonction de transition, faire un appel à la méthode add de la classe statistics. Il peut être utile d'ajouter des variables local à la classe XXX dans ./include/XXX.h, mais n'oubliez pas de les protéger par un \#ifdef STATISTICS
44\end{enumerate}
45\item 
46{\bf Vhdl}
47\begin{enumerate}
48\item {\it ./src/XXX\_vhdl.cpp} Normalement vous n'avez pas à modifier ce fichier. Mais si bloc est structurelle et ne contient pas des sous bloc définit par d'autre composant, alors fonction vhdl de la classe XXX doit s'occuper d'appeler les bonnes fonctions pour les généreés. (prenez exemple sur {\it ./Behavioural/Predictor/Branch\_Target\_Buffer/Sort/src/Sort\_vhdl.cpp}
49\item {\it ./src/XXX\_vhdl\_declaration.cpp} Enumeration des types nécessaires pour le corps du code VHDL.
50\item {\it ./src/XXX\_vhdl\_port.cpp} Listes des ports du composants. Attention, les types des ports doivent être des types simples. (De préférence pas les types définitions dans le fichier {\it ./src/XXX\_vhdl\_type.cpp}).
51\item {\it ./src/XXX\_vhdl\_declaration.cpp} Définitions des signaux internes aux composants.
52\item {\it ./src/XXX\_vhdl\_body.cpp} Corps du composant... Amusez vous bien :)
53\end{enumerate}
54\item 
55{\bf Vhdl - TestBench}
56\begin{enumerate}
57\item {\it ./src/XXX.cpp} Dans le constructeur, on définit l'horloge interne du testBench. A la ligne {\bf \_vhdl\_testbench->set\_clock("in\_CLOCK",true);} le premier argument de {\it set\_clock} est le nom du port de l'horloge. Le deuxième argument est un booléen qui indique si le modèle à tester possède une horloge ou pas. Modifier cette ligne pour être en adéquation avec votre composant.
58\item {\it ./src/XXX\_vhdl\_testbench\_port.cpp} Enumaration des ports du modèle. Il s'agit en générale d'une bête recopie du fichier {\it ./src/XXX\_vhdl\_port.cpp} avec quelques petites retouches.
59\item {\it ./src/XXX\_vhdl\_testbench\_transition.cpp} Ajout dans le testbench des valeurs des entrées et des sorties du modèles. Les ports doivent être listé dans le même ordre que celui du fichier {\it ./src/XXX\_vhdl\_testbench\_port.cpp}.
60\end{enumerate}
61\end{enumerate}
62
63       
64%%+-------------------------------+---------------------------------------------------------------+
65%%|     List of flags           |       exemple ( component : RegisterFile )                    |
66%%+-------------------------------+---------------------------------------------------------------+
67%%|                             |                                                               |
68%%|     @DIR_MORPHEO            |       ../..                                                   |
69%%|                             |                                                               |
70%%|     @COMPONENT              |       RegisterFile                                            |
71%%|                             |                                                               |
72%%|     Behavioural/@DIRECTORY          |       Behavioural/Generic/RegisterFile                        |
73%%|                             |                                                               |
74%%|     behavioural_@DEFINE                     |       behavioural_generic_registerfile                        |
75%%|                             |                                                               |
76%%|     namespace behavioural {
77%%@NAMESPACE_BEGIN      |       namespace behavioural                {                  |
78%%|                             |       namespace generic                    {                  |
79%%|                             |       namespace registerfile               {                  |
80%%|                             |                                                               |
81%%|     @NAMESPACE_END
82%%}; // end namespace behavioural               |       }; // end namespace registerfile                        |
83%%|                             |       }; // end namespace generic                             |
84%%|                             |       }; // end namespace behavioural                         |
85%%|                             |                                                               |
86%%|     behavioural::@NAMESPACE_USE             |       behavioural::generic::registerfile                      |
87%%|                             |                                                               |
88%%|     using namespace morpheo::behavioural;
89%%@NAMESPACE_USING      |       using namespace morpheo::behavioural;                   |
90%%|                             |       using namespace morpheo::behavioural::generic;          |
91%%|                             |                                                               |
92%%+-------------------------------+---------------------------------------------------------------+
Note: See TracBrowser for help on using the repository browser.