Changes between Version 8 and Version 9 of ToolsCourseTp10


Ignore:
Timestamp:
Jun 15, 2007, 5:25:58 PM (18 years ago)
Author:
anne
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • ToolsCourseTp10

    v8 v9  
    11{{{
    22#!html
    3 <h1> TP11 VLSI : Analyse de timing</h1>
     3<h1> TP10 VLSI : Vue physique de l'AMD2901</h1>
    44}}}
    55[[PageOutline]]
    66== Objectifs ==
    7  * Utiliser les outils d'analyse statique de ''timing''.
    8  * Optimisation de votre circuit
     7 * Utiliser les outils de placement et routage.
     8 * Vérifier la validité du routage.
    99== Exercice(s) ==
    10 === Exercice 1-Analyse temporelle du bloc "Accu" ===
    11 En partant du fichier ''accu.ap '' fourni en annexe, vous allez effectuer différentes étapes pour obtenir l'analyse temporelle de ce bloc.
    12 
    13 Dans un premier temps , il est nécessaire d'avoir la 'vue logique' au niveau transistors de votre circuit. On spécifie la technologie utilisée par
     10=== Exercice 1-Placement ===
     11La première étape consiste à placer les plots puis le coeur.
     12==== Question 1 ====
     13Exécutez le script suivant amd_chip.py en ayant pris soin de comprendre le contenu de ce fichier
    1414{{{
    15 >export RDS_TECHNO_NAME=/users/soft/techno/labo/035/extract/prol0.35.rds
     15#!/usr/bin/python
     16
     17from stratus import *
     18
     19class amd_chip ( Model ) :
     20
     21  def Interface ( self ) :
     22
     23    self.cke     = CkIn       ( "cke")
     24    self.cin     = SignalIn  ( "cin",   1 )
     25    self.cout    = SignalOut  ( "cout",  1 )
     26    self.np      = SignalOut      ( "np",    1 )
     27    self.ng      = SignalOut      ( "ng",    1 )
     28    self.ovr     = SignalOut      ( "ovr",   1 )
     29    self.zero    = SignalOut      ( "zero",  1 )
     30    self.signe   = SignalOut  ( "signe", 1 )
     31    self.r0      = TriState  ( "r0",    1 )
     32    self.r3      = TriState  ( "r3",    1 )
     33    self.q0      = TriState  ( "q0",    1 )
     34    self.q3      = TriState  ( "q3",    1 )
     35    self.a       = SignalIn       ( "a",     4 )
     36    self.b       = SignalIn       ( "b",     4 )
     37    self.d       = SignalIn       ( "d",     4 )
     38    self.i       = SignalIn       ( "i",     9 )
     39    self.noe     = SignalIn       ( "noe",   1 )
     40    self.y       = TriState  ( "y",     4 )
     41
     42    self.vdd     = VddIn ( "vdd"  )
     43    self.vss     = VssIn ( "vss"  )
     44    self.vdde    = VddIn ( "vdde" )
     45    self.vsse    = VssIn ( "vsse" )
     46
     47
     48  def Netlist ( self ) :
     49
     50    cin_from_pads    = Signal ( "cin_from_pads",    1 )
     51    cout_to_pads     = Signal ( "cout_to_pads",     1 )
     52    np_to_pads       = Signal ( "np_to_pads",       1 )
     53    ng_to_pads       = Signal ( "ng_to_pads",       1 )
     54    ovr_to_pads      = Signal ( "ovr_to_pads",      1 )
     55    zero_to_pads     = Signal ( "zero_to_pads",     1 )
     56    shift_r          = Signal ( "shift_r",          1 )
     57    shift_l          = Signal ( "shift_l",          1 )
     58    signe_to_pads    = Signal ( "signe_to_pads",    1 )
     59    r0_to_pads       = Signal ( "r0_to_pads",       1 )
     60    r3_to_pads       = Signal ( "r3_to_pads",       1 )
     61    r0_from_pads     = Signal ( "r0_from_pads",     1 )
     62    r3_from_pads     = Signal ( "r3_from_pads",     1 )
     63    q0_to_pads       = Signal ( "q0_to_pads",       1 )
     64    q3_to_pads       = Signal ( "q3_to_pads",       1 )
     65    q0_from_pads     = Signal ( "q0_from_pads",     1 )
     66    q3_from_pads     = Signal ( "q3_from_pads",     1 )
     67    ck_ring          = Signal ( "ck_ring",          1 )
     68    a_from_pads      = Signal ( "a_from_pads",      4 )
     69    b_from_pads      = Signal ( "b_from_pads",      4 )
     70    d_from_pads      = Signal ( "d_from_pads",      4 )
     71    i_from_pads      = Signal ( "i_from_pads",      9 )
     72    y_to_pads        = Signal ( "y_to_pads",        4 )
     73    noe_from_pads    = Signal ( "noe_from_pads",    1 )
     74    y_oe             = Signal ( "y_oe",             1 )
     75    self.ckc         = Signal ( "ckc",              1 )
     76
     77
     78    self.coeur = Inst ( "coeur"
     79                     , "coeur"
     80                     , map = { 'cin_from_pads' : cin_from_pads
     81                             , 'cout_to_pads'  : cout_to_pads
     82                             , 'np_to_pads'    : np_to_pads
     83                             , 'ng_to_pads'    : ng_to_pads
     84                             , 'ovr_to_pads'   : ovr_to_pads
     85                             , 'signe_to_pads' : signe_to_pads
     86                             , 'zero_to_pads'  : zero_to_pads
     87                             , 'shift_r'       : shift_r
     88                             , 'shift_l'       : shift_l
     89                             , 'r0_to_pads'    : r0_to_pads
     90                             , 'r3_to_pads'    : r3_to_pads
     91                             , 'r0_from_pads'  : r0_from_pads
     92                             , 'r3_from_pads'  : r3_from_pads
     93                             , 'q0_to_pads'    : q0_to_pads
     94                             , 'q3_to_pads'    : q3_to_pads
     95                             , 'q0_from_pads'  : q0_from_pads
     96                             , 'q3_from_pads'  : q3_from_pads
     97                             , 'ck'            : self.ckc
     98                             , 'a_from_pads'   : a_from_pads
     99                             , 'b_from_pads'   : b_from_pads
     100                             , 'd_from_pads'   : d_from_pads
     101                             , 'i_from_pads'   : i_from_pads
     102                             , 'y_to_pads'     : y_to_pads
     103                             , 'noe_from_pads' : noe_from_pads
     104                             , 'y_oe'          : y_oe
     105                             , 'vdd'           : self.vdd
     106                             , 'vss'           : self.vss
     107                             }
     108                     )
     109
     110    self.p_ck = Inst ( "pck_px", "p_ck"
     111         , map = { 'pad'  : self.cke
     112                 , 'ck'   : ck_ring
     113                 , 'vddi' : self.vdd
     114                 , 'vssi' : self.vss
     115                 , 'vdde' : self.vdde
     116                 , 'vsse' : self.vsse
     117                 }
     118         )
     119
     120    self.p_cin = Inst ( "pi_px", "p_cin"
     121         , map = { 'pad'  : self.cin
     122                 , 't'    : cin_from_pads
     123                 , 'ck'   : ck_ring
     124                 , 'vddi' : self.vdd
     125                 , 'vssi' : self.vss
     126                 , 'vdde' : self.vdde
     127                 , 'vsse' : self.vsse
     128                 }
     129         )
     130
     131    self.p_noe = Inst ( "pi_px", "p_noe"
     132         , map = { 'pad'  : self.noe
     133                 , 't'    : noe_from_pads
     134                 , 'ck'   : ck_ring
     135                 , 'vddi' : self.vdd
     136                 , 'vssi' : self.vss
     137                 , 'vdde' : self.vdde
     138                 , 'vsse' : self.vsse
     139                 }
     140         )
     141
     142    self.p_a = {}
     143    self.p_b = {}
     144    self.p_d = {}
     145    for i in range ( 4 ) :
     146      self.p_a[i] = Inst ( "pi_px", "p_a%d" % i
     147           , map = { 'pad'  : self.a[i]
     148                   , 't'    : a_from_pads[i]
     149                   , 'ck'   : ck_ring
     150                   , 'vddi' : self.vdd
     151                   , 'vssi' : self.vss
     152                   , 'vdde' : self.vdde
     153                   , 'vsse' : self.vsse
     154                   }
     155           )
     156
     157      self.p_b[i] = Inst ( "pi_px", "p_b%d" % i
     158           , map = { 'pad'  : self.b[i]
     159                   , 't'    : b_from_pads[i]
     160                   , 'ck'   : ck_ring
     161                   , 'vddi' : self.vdd
     162                   , 'vssi' : self.vss
     163                   , 'vdde' : self.vdde
     164                   , 'vsse' : self.vsse
     165                   }
     166           )
     167
     168      self.p_d[i] = Inst ( "pi_px", "p_d%d" % i
     169           , map = { 'pad'  : self.d[i]
     170                   , 't'    : d_from_pads[i]
     171                   , 'ck'   : ck_ring
     172                   , 'vddi' : self.vdd
     173                   , 'vssi' : self.vss
     174                   , 'vdde' : self.vdde
     175                   , 'vsse' : self.vsse
     176                   }
     177           )
     178
     179    self.p_i = {}
     180    for i in range ( 9 ) :
     181      self.p_i[i] = Inst ( "pi_px", "p_i%d" % i
     182           , map = { 'pad'  : self.i[i]
     183                   , 't'    : i_from_pads[i]
     184                   , 'ck'   : ck_ring
     185                   , 'vddi' : self.vdd
     186                   , 'vssi' : self.vss
     187                   , 'vdde' : self.vdde
     188                   , 'vsse' : self.vsse
     189                   }
     190           )
     191
     192    self.p_cout = Inst ( "po_px", "p_cout"
     193         , map = { 'i'    : cout_to_pads
     194                 , 'pad'  : self.cout
     195                 , 'ck'   : ck_ring
     196                 , 'vddi' : self.vdd
     197                 , 'vssi' : self.vss
     198                 , 'vdde' : self.vdde
     199                 , 'vsse' : self.vsse
     200                 }
     201         )
     202
     203    self.p_np = Inst ( "po_px", "p_np"
     204         , map = { 'i'    : np_to_pads
     205                 , 'pad'  : self.np
     206                 , 'ck'   : ck_ring
     207                 , 'vddi' : self.vdd
     208                 , 'vssi' : self.vss
     209                 , 'vdde' : self.vdde
     210                 , 'vsse' : self.vsse
     211                 }
     212         )
     213
     214    self.p_ng = Inst ( "po_px", "p_ng"
     215         , map = { 'i'    : ng_to_pads
     216                 , 'pad'  : self.ng
     217                 , 'ck'   : ck_ring
     218                 , 'vddi' : self.vdd
     219                 , 'vssi' : self.vss
     220                 , 'vdde' : self.vdde
     221                 , 'vsse' : self.vsse
     222                 }
     223         )
     224
     225    self.p_ovr = Inst ( "po_px", "p_ovr"
     226         , map = { 'i'    : ovr_to_pads
     227                 , 'pad'  : self.ovr
     228                 , 'ck'   : ck_ring
     229                 , 'vddi' : self.vdd
     230                 , 'vssi' : self.vss
     231                 , 'vdde' : self.vdde
     232                 , 'vsse' : self.vsse
     233                 }
     234         )
     235
     236    self.p_zero = Inst ( "po_px", "p_zero"
     237         , map = { 'i'    : zero_to_pads
     238                 , 'pad'  : self.zero
     239                 , 'ck'   : ck_ring
     240                 , 'vddi' : self.vdd
     241                 , 'vssi' : self.vss
     242                 , 'vdde' : self.vdde
     243                 , 'vsse' : self.vsse
     244                 }
     245         )
     246
     247    self.p_signe = Inst ( "po_px", "p_signe"
     248         , map = { 'i'    : signe_to_pads
     249                 , 'pad'  : self.signe
     250                 , 'ck'   : ck_ring
     251                 , 'vddi' : self.vdd
     252                 , 'vssi' : self.vss
     253                  , 'vdde' : self.vdde
     254                  , 'vsse' : self.vsse
     255                  }
     256         )
     257
     258    self.p_y = {}
     259    for i in range ( 4 ) :
     260      self.p_y[i] = Inst ( "pot_px", "p_y%d" % i
     261           , map = { 'i'    : y_to_pads[i]
     262                   , 'b'    : y_oe
     263                   , 'pad'  : self.y[i]
     264                   , 'ck'   : ck_ring
     265                   , 'vddi' : self.vdd
     266                   , 'vssi' : self.vss
     267                   , 'vdde' : self.vdde
     268                   , 'vsse' : self.vsse
     269                   }
     270           )
     271
     272    self.p_q0 = Inst ( "piot_px", "p_q0"
     273         , map = { 'i'    : q0_to_pads
     274                 , 'b'    : shift_r
     275                 , 't'    : q0_from_pads
     276                 , 'pad'  : self.q0
     277                 , 'ck'   : ck_ring
     278                 , 'vddi' : self.vdd
     279                 , 'vssi' : self.vss
     280                 , 'vdde' : self.vdde
     281                 , 'vsse' : self.vsse
     282                 }
     283         )
     284
     285    self.p_q3 = Inst ( "piot_px", "p_q3"
     286         , map = { 'i'    : q3_to_pads
     287                 , 'b'    : shift_l
     288                 , 't'    : q3_from_pads
     289                 , 'pad'  : self.q3
     290                 , 'ck'   : ck_ring
     291                 , 'vddi' : self.vdd
     292                 , 'vssi' : self.vss
     293                 , 'vdde' : self.vdde
     294                 , 'vsse' : self.vsse
     295                 }
     296         )
     297
     298    self.p_r0 = Inst ( "piot_px", "p_r0"
     299         , map = { 'i'    : r0_to_pads
     300                 , 'b'    : shift_r
     301                 , 't'    : r0_from_pads
     302                 , 'pad'  : self.r0
     303                 , 'ck'   : ck_ring
     304                 , 'vddi' : self.vdd
     305                 , 'vssi' : self.vss
     306                 , 'vdde' : self.vdde
     307                 , 'vsse' : self.vsse
     308                 }
     309         )
     310
     311    self.p_r3 = Inst ( "piot_px", "p_r3"
     312         , map = { 'i'    : r3_to_pads
     313                 , 'b'    : shift_l
     314                 , 't'    : r3_from_pads
     315                 , 'pad'  : self.r3
     316                 , 'ck'   : ck_ring
     317                 , 'vddi' : self.vdd
     318                 , 'vssi' : self.vss
     319                 , 'vdde' : self.vdde
     320                 , 'vsse' : self.vsse
     321                 }
     322         )
     323
     324    self.p_vddick0 = Inst ( "pvddick_px", "p_vddick0"
     325         , map = { 'cko'  : self.ckc
     326                 , 'ck'   : ck_ring
     327                 , 'vddi' : self.vdd
     328                 , 'vssi' : self.vss
     329                  , 'vdde' : self.vdde
     330                  , 'vsse' : self.vsse
     331                  }
     332         )
     333
     334    self.p_vssick0 = Inst ( "pvssick_px", "p_vssick0"
     335         , map = { 'cko'  : self.ckc
     336                 , 'ck'   : ck_ring
     337                 , 'vddi' : self.vdd
     338                 , 'vssi' : self.vss
     339                 , 'vdde' : self.vdde
     340                 , 'vsse' : self.vsse
     341                 }
     342         )
     343
     344    self.p_vddeck0 = Inst ( "pvddeck_px", "p_vddeck0"
     345         , map = { 'cko'  : self.ckc
     346                 , 'ck'   : ck_ring
     347                 , 'vddi' : self.vdd
     348                 , 'vssi' : self.vss
     349                 , 'vdde' : self.vdde
     350                 , 'vsse' : self.vsse
     351                 }
     352         )
     353
     354    self.p_vddeck1 = Inst ( "pvddeck_px", "p_vddeck1"
     355         , map = { 'cko'  : self.ckc
     356                 , 'ck'   : ck_ring
     357                 , 'vddi' : self.vdd
     358                 , 'vssi' : self.vss
     359                 , 'vdde' : self.vdde
     360                 , 'vsse' : self.vsse
     361                 }
     362         )
     363
     364    self.p_vsseck0 = Inst ( "pvsseck_px", "p_vsseck0"
     365         , map = { 'cko'  : self.ckc
     366                 , 'ck'   : ck_ring
     367                 , 'vddi' : self.vdd
     368                 , 'vssi' : self.vss
     369                  , 'vdde' : self.vdde
     370                  , 'vsse' : self.vsse
     371                  }
     372         )
     373
     374    self.p_vsseck1 = Inst ( "pvsseck_px", "p_vsseck1"
     375         , map = { 'cko'  : self.ckc
     376                 , 'ck'   : ck_ring
     377                 , 'vddi' : self.vdd
     378                 , 'vssi' : self.vss
     379                 , 'vdde' : self.vdde
     380                 , 'vsse' : self.vsse
     381                 }
     382         )
     383
     384
     385  def Layout ( self ) :
     386
     387    ##### A COMLPETER #####
     388    DefAb(XY(0,0),XY(3000,3000))
     389
     390    PlaceCentric(self.coeur)
     391
     392    PadNorth(self.p_i[3],self.p_i[4],self.p_i[5],self.p_b[0],self.p_b[1],self.p_b[2],self.p_b[3]
     393                ,self.p_q0,self.p_q3,self.p_i[6],self.p_i[7])
     394
     395
     396    PadWest(self.p_ck,self.p_d[0],self.p_d[1],self.p_d[2],self.p_zero,self.p_vsseck0,self.p_ovr
     397                ,self.p_d[3],self.p_i[0],self.p_i[1],self.p_i[2])
     398
     399
     400    PadSouth(self.p_cin,self.p_np,self.p_ng,self.p_vssick0,self.p_vddeck0,self.p_vsseck1,self.p_vddeck1
     401                ,self.p_cout,self.p_y[0],self.p_y[1],self.p_y[2])
     402
     403
     404    PadEast(self.p_y[3],self.p_signe,self.p_noe,self.p_a[0],self.p_a[1],self.p_vddick0
     405                ,self.p_a[2],self.p_a[3],self.p_r0,self.p_r3,self.p_i[8])
     406
     407
     408
     409
     410
     411    PowerRing(3)
     412
     413    PlaceGlue(self.coeur)
     414
     415    FillCell(self.coeur)
     416
     417    RouteCk(self.ckc)
     418
     419
     420mon_chip = amd_chip ( "amd_2901_dpt" )
     421
     422mon_chip.Interface ()
     423mon_chip.Netlist ()
     424#mon_chip.Layout ()
     425mon_chip.View ()
     426mon_chip.Save (LAYOUT)
    16427}}}
    17 pour l'extraction on spécifie les formats désirés par
     428Quels sont les fichiers obtenus? regardez en utilisant ''' graal''' le résultat du placement.
     429==== Question 2 ====
     430Faites varier la taille de la boite d'aboutement, qu'observez-vous ? Avez vous rencontré une limite ? peut-on en déduire la largeur des plots.
     431=== Exercice 2-Routage ===
     432Cette seconde étape consiste à relier les cellulesdu coeur entre elles. Vous allez pour cela utiliser l'outil '''nero''' . Consultez le ''' man ''' de ''' nero'''
    18433{{{
    19 >export MBK_IN_PH=ap
    20 >export MBK_OUT_LO=al
    21 }}}
    22 l'extraction de ''netlist'' est obtenue en utilisant l'outil '''cougar''', n'oubliez pas de consulter le man !
    23 {{{
    24 >cougar -v -t -ar accu accu
    25 }}}
    26 Vous devez alors obtenir le fichier accu.al (au format texte, analysez ce que contient ce fichier).
    27  Pour réaliser l'analyse de timing nous allons utiliser les outils de la société '''Avertec'''. Pour pouvoir utiliser ces outils, vous devez exécuter le script fourni par
    28 {{{
    29 >source avt_env.sh
    30 }}}
    31 Il est nécessaire de spécifier la '''technologie''' utilisée ainsi que les '''formats''' de fichiers utilisés:
    32 {{{
    33 >export ELP_TECHNO_NAME=/users/soft/techno/labo/035/elp/prol035.elp
    34 >export MBK_IN_LO=al
    35 }}}
    36 Puis lancer l'analyse de timing avec '''tas''' par
    37 {{{
    38 >tas -nvx -t accu
     434>nero -v -3 -p amd_chip_pl amd amd_route
    39435}}}
    40436==== Question 1 ====
    41 Pourquoi est-il nécessaire de spécifier la technologie utilisée ''deux fois''?
     437A quoi correspondent les options utilisées dans la commande ci-dessus? Faites varier le nombre de couches de métal utilisés pour le routage.
     438=== Exercice 3-Validation du routage ===
     439Cette étape consiste à vérifier que le routage a été effectué sans erreur. Il y a deux types de vérifications à réaliser
     440 * Vérifier le respect des règles de dessin
     441 * Vérifier les interconnexions réalisées
     442==== Question 1 ====
     443Vérifiez le respect des règles de dessin en utilisant '''Druc''' . Vous aurez pris soin au préalable de vérifier que vous utilisez la technologie symbolique
    42444==== Question 2 ====
    43 En utilisant l'outil '''xtas''', déterminez le plus long chemin entre une entrée et un registre de votre circuit.
     445Utilisez l'outil '''cougar''' pour extraire la ''netlist ''de votre circuit au niveau "cellules de base ". Vous aurez au préalable pris soin de positionner la variable d'environnement '''MBK_OUT_LO''' au format '''al'''.
    44446==== Question 3 ====
    45 En utilisant '''xtas''', déterminez le plus long chemin entre deux registres.
    46 ==== Question 4 ====
    47 En utilisant '''xtas''', déterminez le plus long chemin entre un registre et une sortie.
    48 ==== Question 5 ====
    49 En utilisant '''xtas''', déterminez le plus court chemin ainsi que le plus long chemin entre l'entrée de l'horloge de votre circuit et un registre.
    50 ==== Question 6 ====
    51 Déduisez le temps nécessaire pendant lequel l'entrée '''alu_out''' doit être stable avant le front montant de l'horloge.
    52 ==== Question 7 ====
    53 Déduisez de la réponse à laquestion 6 le temps de cycle minimal du bloc accu.
    54 ==== Question 8 ====
    55 Indiquez à partir de combien de temps aprés le front montant de l'horloge, la sortie '''accu''' est stable (dans le pire cas )
    56 ==== Question 9 ====
    57 Existe t il un risque de ''chaine courte ''?
    58 === Exercice 2-Analyse temporelle du circuit complet ===
    59 ==== Question 1 ====
    60 En suivant la démarche explicitée pour le bloc accu, réalisez l'analyse temporelle de votre circuit complet
    61 ==== Question 2 ====
    62 Donner la valeur de la chaîne longue.
    63 ==== Question 3 ====
    64 Par où passe cette chaîne longue ? Quelle est la fréquence maximale de l'horloge pour votre circuit ?
    65 ==== Question 4 ====
    66 Est il possible d'optimiser votre circuit pour accroître votre fréquence de foctionnement ?
     447Comparez la ''netlist'' extraite à celle d'origine (avnt routage) en utilisant l'outil '''lvx'''
     448
     449