source: trunk/IPs/systemC/processor/Morpheo/Documentation/doc/document-morpheo-input_files/tex/generator_configuration_file-fr.tex @ 91

Last change on this file since 91 was 91, checked in by rosiere, 15 years ago

Documentation

  • Property svn:executable set to *
File size: 13.5 KB
Line 
1%------------------------------------------------------------------------------
2% $Id$
3%------------------------------------------------------------------------------
4
5\Section{Fichier de configuration du générateur}
6
7\subSection{Description}
8
9Ce fichier contient la liste des paramètres et de leur évolution. C'est-à-dire les valeurs minimales, maximales... Ce fichier n'est utilisé qu'en lecture par les différents outils de \cpu.
10
11Si un concepteur modifie le générateur \cpu et ajoute des paramètres, il devra rajouter une entrée dans ce fichier.
12
13Ce fichier est écrit au format XML.
14
15\subSection{Syntaxe}
16
17\verbatiminput{\dirroot/syntax.gen}
18
19\begin{description}
20\item[balise parameters :] {\it (Obligatoire et unique)} Balise englobante.
21  \begin{description}
22  \item[balise parameter :] {\it (Nombre quelconque d'occurrences)} Décris un paramètre du générateur.
23    \begin{description}
24    \item[attribut name        :] {\it (Obligatoire)} Nom du paramètre.
25    \item[attribut min         :] {\it (Obligatoire si attribut max ou step est présent)} Valeur minimale du paramètre.
26    \item[attribut max         :] {\it (Obligatoire si attribut min ou step est présent)} Valeur maximale du paramètre.
27    \item[attribut step        :] {\it (Obligatoire si attribut min ou max  est présent)} Pas entre deux valeurs de paramètres (par exemple +1 ou *2).
28    \item[attribut default     :] {\it (Obligatoire)} Valeur par défaut de ce paramètre.
29    \item[attribut level       :] {\it (Optionnel  )} Niveau requis pour que l'utilisateur puisse voir ce paramètre. Le niveau varie de 0 (paramètre jamais affiché) 1 (affichage de presque aucun des paramètres (mode néophyte) à 5 (affichage de tous les paramètres (mode expert)). La valeur par défaut de cet attribut est 3.
30    \item[attribut description :] {\it (Optionnel  )} Description du paramètre. La valeur par défaut de cet attribut est une chaîne vide.
31    \end{description}
32  \item[balise link :] {\it (Nombre quelconque d'occurrences)} Lien entre deux composants du processeur.
33    \begin{description}
34    \item[attribut name        :] {\it (Obligatoire)} Nom du paramètre.
35    \item[attribut src         :] {\it (Obligatoire)} Source du lien.
36    \item[attribut dest        :] {\it (Optionnel  )} Destination du lien. La destination ne doit pas apparaître si c'est un lien binaire (lien présent ou non).
37    \item[attribut description :] {\it (Optionnel  )} Description du paramètre.
38    \end{description}
39  \end{description}
40\end{description}
41
42Si une balise {\it parameter} n'a pas les attributs {\it min}, {\it max} et {\it step}, alors il s'agit d'un paramètre qui a une valeur binaire. Ceci ce traduit comme un paramètre classique avec min=''0'', max=''1'' et step=''+ 1''.
43
44\subSection{Paramètres}
45
46\begin{description}
47\item[size\_data                                       :] 
48\item[dispatch\_priority                               :]~\\
49  \begin{description}
50  \item[PRIORITY\_STATIC                               :] Les priorités sont fixes.
51  \item[PRIORITY\_ROUND\_ROBIN                         :] L'entité la plus prioritaire devient au cycle suivant l'entité la moins prioritaire.
52  \end{description}
53\item[dispatch\_load\_balancing                        :]~\\
54  \begin{description}
55  \item[LOAD\_BALANCING\_BALANCE                       :] Un élément de l'entité la plus prioritaire est servi, suivit des autres entités par ordre de priorité.
56  \item[LOAD\_BALANCING\_MAXIMUM\_FOR\_PRIORITY        :] Tous les éléments de l'entité la plus prioritaire sont servis, suivirent des autres entités par ordre de priorité.
57  \end{description}
58\item[nb\_icache\_port                                 :] 
59\item[icache\_access\_priority                         :] 
60\item[icache\_access\_load\_balancing                  :] 
61\item[nb\_dcache\_port                                 :] 
62\item[dcache\_access\_priority                         :] 
63\item[dcache\_access\_load\_balancing                  :] 
64\item[nb\_thread                                       :] 
65\item[size\_ifetch\_queue                              :] 
66\item[nb\_inst\_fetch                                  :] 
67\item[implement\_group                                 :] 
68\item[ras\_size\_queue                                 :] 
69\item[upt\_size\_queue                                 :] 
70\item[nb\_decod\_bloc                                  :] 
71\item[size\_decod\_queue                               :] 
72\item[nb\_inst\_decod                                  :] 
73\item[nb\_context\_select                              :] 
74\item[context\_select\_priority                        :] 
75\item[context\_select\_load\_balancing                 :] 
76\item[nb\_rename\_bloc                                 :] 
77\item[nb\_inst\_insert                                 :] 
78\item[nb\_inst\_retire                                 :] 
79\item[rename\_select\_priority                         :] 
80\item[rename\_select\_load\_balancing                  :] 
81\item[rename\_select\_nb\_front\_end\_select           :] 
82\item[nb\_general\_register                            :] 
83\item[nb\_special\_register                            :] 
84\item[nb\_reg\_free                                    :] 
85\item[nb\_rename\_unit\_bank                           :] 
86\item[size\_read\_counter                              :] 
87\item[nb\_read\_bloc                                   :] 
88\item[size\_read\_queue                                :] 
89\item[size\_reservation\_station                       :] 
90\item[nb\_inst\_retire\_reservation\_station           :] 
91\item[nb\_write\_bloc                                  :] 
92\item[size\_write\_queue                               :] 
93\item[size\_execute\_queue                             :] 
94\item[nb\_bypass\_write                                :] 
95\item[nb\_load\_store\_unit                            :] 
96\item[size\_store\_queue                               :] 
97\item[size\_load\_queue                                :] 
98\item[size\_speculative\_access\_queue                 :] 
99\item[nb\_port\_check                                  :] 
100\item[speculative\_load                                :]~\\
101  \begin{description}
102  \item[NO\_SPECULATIVE\_LOAD                          :] Chaque lecture mémoire attend que toutes les écritures mémoires antérieures soient connues avant d'accéder au cache.
103  \item[SPECULATIVE\_LOAD\_ACCESS                      :] Chaque lecture mémoire attend que toutes les écritures mémoires antérieures soient connues avant d'écrire le résultat dans le banc de registre. L'accès au cache est préventif.
104  \item[SPECULATIVE\_LOAD\_COMMIT                      :] Les instructions mémoires n'attendent pas que toutes les écritures mémoires antérieures soient connues avec d'accéder au cache et d'écrire le résultat dans le banc de registres.
105  \item[SPECULATIVE\_LOAD\_BYPASS                      :] Les instructions mémoires n'attendent pas que toutes les écritures mémoires antérieures soient connues avec d'accéder au cache, d'écrire le résultat dans le banc de registres et de transmettre la donnée lue sur le réseau de bypass.
106  \end{description}
107\item[nb\_bypass\_memory                               :] 
108\item[nb\_cache\_port                                  :] 
109\item[nb\_inst\_memory                                 :] 
110\item[nb\_functionnal\_unit                            :] 
111\item[nb\_inst\_functionnal\_unit                      :] 
112\item[nb\_front\_end                                   :] 
113\item[nb\_context                                      :] 
114\item[nb\_decod\_unit                                  :] 
115\item[nb\_inst\_branch\_predict                        :] 
116\item[nb\_inst\_branch\_decod                          :] 
117\item[nb\_inst\_branch\_update                         :] 
118\item[btb\_size\_queue                                 :] 
119\item[btb\_associativity                               :] 
120\item[btb\_size\_counter                               :] 
121\item[btb\_victim\_scheme                              :]~\\
122  \begin{description}
123  \item[VICTIM\_RANDOM                                 :] La victime est choisie de façon aléatoire.
124  \item[VICTIM\_ROUND\_ROBIN                           :] La victime est choisie de façon circulaire.
125  \item[VICTIM\_NLU                                    :] La victime est choisie de façon aléatoire. Le dernier élément utilisé est un choix invalide.
126  \item[VICTIM\_PSEUDO\_LRU                            :] La victime suivant un schéma presque LRU.
127  \item[VICTIM\_LRU                                    :] Les éléments sont classés par date d'utilisation. La victime choisie est la moins récemment utilisée.
128  \item[VICTIM\_FIFO                                   :] Les éléments sont classés par ordre d'arrivée. La victime choisie est la plus ancienne.
129  \end{description}
130\item[dir\_predictor\_scheme                           :]~\\
131  \begin{description}
132  \item[PREDICTOR\_NEVER\_TAKE                         :] Le branchement n'est jamais pris.
133  \item[PREDICTOR\_ALWAYS\_TAKE                        :] Le branchement est toujours pris.
134  \item[PREDICTOR\_STATIC                              :] Si la destination du branchement se situe avant l'instruction du branchement, alors le branchement est pris.
135  \item[PREDICTOR\_LAST\_TAKE                          :] La direction sera la même que la fois précédente. Si c'est la première fois que le branchement est rencontré, alors la prédiction suit le schéma statique.
136  \item[PREDICTOR\_COUNTER                             :] Table de compteur indexé par l'adresse du branchement. La direction du branchement est déterminée par le bit de poids fort du compteur.
137  \item[PREDICTOR\_LOCAL                               :] Table de compteur indexé par une table d'historique qui est lui-même indexé par l'adresse du branchement.
138  \item[PREDICTOR\_GLOBAL                              :] Table de compteur indexé par une table d'historique à une entrée qui est lui-même indexé par l'adresse du branchement.
139  \item[PREDICTOR\_META                                :] 3 prédicteurs de branchement : une table de compteur va sélectionner entre la prédiction provenant du prédicteur local ou du prédicteur global. C'est trois prédicteurs sont indexés par l'adresse du branchement.
140  \item[PREDICTOR\_CUSTOM                              :] Il s'agit d'un méta prédicteur. Mais les 3 prédicteurs internes sont paramétrables. C'est trois prédicteurs sont indexés par l'adresse du branchement.
141  \end{description}
142\item[dir\_have\_bht                                   :] 
143\item[dir\_bht\_size\_shifter                          :] 
144\item[dir\_bht\_nb\_shifter                            :] 
145\item[dir\_have\_pht                                   :] 
146\item[dir\_pht\_size\_counter                          :] 
147\item[dir\_pht\_nb\_counter                            :] 
148\item[dir\_pht\_size\_address\_share                   :] 
149\item[nb\_ooo\_engine                                  :] 
150\item[nb\_rename\_unit                                 :] 
151\item[nb\_inst\_issue                                  :] 
152\item[nb\_inst\_reexecute                              :] 
153\item[nb\_inst\_commit                                 :] 
154\item[nb\_inst\_branch\_complete                       :] 
155\item[nb\_rename\_unit\_select                         :] 
156\item[nb\_execute\_loop\_select                        :] 
157\item[size\_re\_order\_buffer                          :] 
158\item[nb\_re\_order\_buffer\_bank                      :] 
159\item[commit\_priority                                 :] 
160\item[commit\_load\_balancing                          :] 
161\item[size\_issue\_queue                               :] 
162\item[nb\_issue\_queue\_bank                           :] 
163\item[issue\_priority                                  :] 
164\item[issue\_load\_balancing                           :] 
165\item[size\_reexecute\_queue                           :] 
166\item[reexecute\_priority                              :] 
167\item[reexecute\_load\_balancing                       :] 
168\item[nb\_execute\_loop                                :] 
169\item[nb\_read\_unit                                   :] 
170\item[nb\_execute\_unit                                :] 
171\item[nb\_write\_unit                                  :] 
172\item[nb\_gpr\_bank                                    :] 
173\item[nb\_gpr\_port\_read\_by\_bank                    :] 
174\item[nb\_gpr\_port\_write\_by\_bank                   :] 
175\item[nb\_spr\_bank                                    :] 
176\item[nb\_spr\_port\_read\_by\_bank                    :] 
177\item[nb\_spr\_port\_write\_by\_bank                   :] 
178\item[execution\_unit\_to\_write\_unit\_priority       :] 
179\item[read\_unit\_to\_execution\_unit\_priority        :] 
180\item[link\_context\_with\_thread                      :] 
181\item[link\_decod\_unit\_with\_decod\_bloc             :] 
182\item[link\_rename\_unit\_with\_rename\_bloc           :] 
183\item[link\_read\_unit\_with\_read\_bloc               :] 
184\item[link\_write\_unit\_with\_write\_bloc             :] 
185\item[link\_execute\_unit\_with\_functionnal\_unit     :] 
186\item[link\_execute\_unit\_with\_load\_store\_unit     :] 
187\item[link\_decod\_bloc\_with\_thread                  :] 
188\item[link\_rename\_bloc\_with\_front\_end             :] 
189\item[table\_dispatch                                  :] 
190\item[link\_read\_bloc\_and\_load\_store\_unit         :] 
191\item[link\_read\_bloc\_and\_functionnal\_unit         :] 
192\item[link\_write\_bloc\_and\_load\_store\_unit        :] 
193\item[link\_write\_bloc\_and\_functionnal\_unit        :] 
194\item[link\_load\_store\_unit\_with\_thread            :] 
195\item[link\_thread\_and\_functionnal\_unit             :] 
196\item[link\_icache\_port\_with\_thread                 :] 
197\item[link\_dcache\_port\_with\_load\_store\_unit      :] 
198\end{description}
199
200%\subSection{Exemples}
201
Note: See TracBrowser for help on using the repository browser.