Sophie

Sophie

distrib > Mageia > 5 > i586 > by-pkgid > 14f6355e37a58ea3391d7ec0af20c6b0 > files > 6

frama-c-doc-1.10-0.20140301Neons.4.mga5.noarch.rpm

@ignore                                                                        
@ignore                                                                        
@ignore  This file is part of Frama-C.                                         
@ignore                                                                        
@ignore  Copyright (C) 2007-2014                                               
@ignore    CEA (Commissariat à l'énergie atomique et aux énergies              
@ignore         alternatives)                                                  
@ignore                                                                        
@ignore  you can redistribute it and/or modify it under the terms of the GNU   
@ignore  Lesser General Public License as published by the Free Software       
@ignore  Foundation, version 2.1.                                              
@ignore                                                                        
@ignore  It is distributed in the hope that it will be useful,                 
@ignore  but WITHOUT ANY WARRANTY; without even the implied warranty of        
@ignore  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         
@ignore  GNU Lesser General Public License for more details.                   
@ignore                                                                        
@ignore  See the GNU Lesser General Public License version 2.1                 
@ignore  for more details (enclosed in the file licenses/LGPLv2.1).            
@ignore                                                                        
@ignore                                                                        

{2 Overview}

The main modules are :

- {!module: PdgIndex} that can be used to store different kind of information related to a function (not only related to PDG)

- the types are defined in {!module: PdgTypes}.

- the PDG computation is done in {!module: Build}.  It also use the lexical successor graph, which is computed in {!module:Lexical_successors}.  

- {!module:Sets} provides functions to read a PDG.

- {!module:Print} provides functions to print a PDG either in textual form or in
  a dot file (See {i "How to see a PDG"} below).
  
 
{2 What is a PDG ?}

A {b Program Dependences Graph} represent the dependences between the
statements of a function. So the nodes of the graph mainly represent the
statements (some more nodes are used to represents things like declarations,
inputs, outputs, etc.) and the edges represent the dependences.

[Y -> X] means that the computation of the statement Y depend on (the result of)
the statement X. Example :
{C {v X : x = a + b; Y : y = x + 1; v}}

There are three kinds of dependencies :

- a {b data} dependency : the simpler one, illustrated by the above example,

- a {b control} dependency : 
{C Example : {v if (c) X : x = a + b; v}}
X is control dependent on (c) because the statement will be executed or not
according to the evaluation of the condition, 
- an {b address} dependency : dependencies on the elements that are used to
  compute the left part of an assignment, ie that decide which data will be
modified.
{C Example : {v t[i] = 3; v}}
We say that this statement have address dependencies on the declaration of [tab]
and the computation of [i].

A dependency between two nodes can have any combination of these kinds.

You can find more documentation, particularly on how this graph is built,
in this {{:../../pdg/index.html}report} (in French).


{2 Dynamic dependencies}

After having built the PDG for a function, there is a way of adding dynamically
some dependencies to it. There are not stored directly in the PDG so they can be
cleared later on.

As PDG doesn't interpret the annotations of the code,
this feature can for instance be used to add dependencies on assertions.

To see an example of how to use it, please have a look at
[tests/pdg/dyn_dpds.ml].

{2 How to see a PDG ?}

Please, use the [-help] option of the tool to get the PDG options names.

The PDG of a function can be seen either in textual form 
or exported in a {b dot} file
which is the format of the {{:http://www.graphviz.org/}Graphviz}
tool set.
They can be viewed using
  {{:http://zvtm.sourceforge.net/zgrviewer.html}zgrviewer}
or exported in SVG format to be seen with some browser 
or {{:http://www.inkscape.org/}Inkscape}.

The graph is unfortunately generated with the output of the function at the top
and its inputs at the bottom. If you find it uncomfortable to read,
just change [TB] by [BT] in the [rankdir] property at the beginning of the
dot file before viewing it. 

The color and the shape of the nodes are used to make it easier to read the
graph, but add no more meaning. 

For the edges : 
- the color (blue) represent the {b data} dependency,
- the shape of the arrow (circled) represent the {b control} dependency,
- and the kind of line (dotted) represent the {b address} dependency.

So a solid blue edge with a circle arrow represent a data+control dependency for
instance, while a dotted black edge with a triangle arrow represent a address
dependency.

You are invited to look at 
{{:../../../tests/pdg/doc.g.svg}a simple example}
to see the different kinds of dependencies.