From cf1594fbd42ec9f9d15e6c4d629d70e97c676229 Mon Sep 17 00:00:00 2001 From: Carlos Galindo Date: Wed, 4 Dec 2019 15:53:32 +0000 Subject: [PATCH] added missing files --- Secciones/conclusion.tex | 7 ++ Secciones/problem_solution.tex | 113 +++++++++++++++++++++++++++++++ img/nested-unconditional-cfg.dot | 22 ++++++ img/nested-unconditional-cfg.pdf | Bin 0 -> 16724 bytes img/nested-unconditional-pdg.dot | 23 +++++++ img/nested-unconditional-pdg.pdf | Bin 0 -> 16253 bytes 6 files changed, 165 insertions(+) create mode 100644 Secciones/conclusion.tex create mode 100644 Secciones/problem_solution.tex create mode 100644 img/nested-unconditional-cfg.dot create mode 100644 img/nested-unconditional-cfg.pdf create mode 100644 img/nested-unconditional-pdg.dot create mode 100644 img/nested-unconditional-pdg.pdf diff --git a/Secciones/conclusion.tex b/Secciones/conclusion.tex new file mode 100644 index 0000000..a661a47 --- /dev/null +++ b/Secciones/conclusion.tex @@ -0,0 +1,7 @@ +% !TEX encoding = UTF-8 +% !TEX spellcheck = en_GB +% !TEX root = ../paper.tex + +\chapter{Conclusion} + +\carlos{todo} \ No newline at end of file diff --git a/Secciones/problem_solution.tex b/Secciones/problem_solution.tex new file mode 100644 index 0000000..8e585a1 --- /dev/null +++ b/Secciones/problem_solution.tex @@ -0,0 +1,113 @@ +% !TEX encoding = UTF-8 +% !TEX spellcheck = en_GB +% !TEX root = ../paper.tex +\chapter{Proposed solution} +\label{cha:solution} + +This solution is an extension of Allen's \cite{AllH03}, with some modifications to solve the problem found \josep{el problem found no ha quedado claro. Se ha diluido entre la maraña abrumadora de casos. debes formular y dejar nitido cristalino cual es el problema y por qué no lo solucinan las dsemás aproximaciones, y poner un ejempllo concreto.}. Before starting, we need to split all instructions in three categories: + +\begin{description} + \item[statement] non-branching instruction, e.g. an assignment or method call. + \item[predicate] conditional branch, e.g. if statements and loops. + \item[pseudo-predicate] unconditional jump, e.g. break, continue, return, goto and throw instructions. +\end{description} + +Pseudo-predicates have been previously use to model unconditional jumps with a counter-intuitive reasoning: the next statement that would be executed were the pseudo-predicate not there would be executed, therefore it is control dependent on it. Going back to the definition of control dependency, one could argue that the real control dependency is on the conditional branch that lead to the \josep{???} + +\begin{figure} +\centering +\begin{lstlisting} +if (a) { + return a; +} +print(a); +\end{lstlisting} +\begin{lstlisting} +if (a) { + +} +print(a); +\end{lstlisting} +\caption{Example of pseudo-predicates control dependencies \josep{no se referencia a esta figura desde ningún sitio}} +\end{figure} + +This is the process used to build the Program Dependence Graph. \josep{Todo lo que sigue es demasiado verbose. No hay definiciones concretas. Es todo muy informal, y no hay un ongoing example que permita ver como las fases van evolucionando paso a paso. Nos reunimos para hablar de esta sección antes de reescribirla...} + +\begin{description} + \item[Step 1 (static analysis):] Identify for each instruction the variables read and defined. Each method is annotated with the global variables that they access or modify. + \item[Step 2 (build CFGs):] Build a CFG for each method of the program. The start of all methods is a vertex labeled \textsl{enter}, which also contains the assignments for parameters and global variables used (\texttt{var = var\_in}). The \textsl{enter} node is connected to the first instruction of the method. In a similar fashion, all methods end in an \textsl{exit} vertex with the corresponding output variables. There exists one \textsl{normal exit} to which the last instruction and all return instructions are connected. If the method can throw any exceptions, there exists one \textsl{error exit} for each type of exception that may be thrown. The normal and erroneous exits are connected to the \textsl{exit} node. + + Every normal statement is connected to the subsequent one by an unlabeled edge. Predicates have two outgoing edges, labeled \textsl{true} and \textsl{false}. Pseudo-predicates also have two outgoing edges. The \textsl{true} edge is connected to the destination of the jump (\textsl{normal exit} in the case of return, the begin or end of the loop in the case of continue and break, etc.). The \textsl{false} edge is a non-executable edge, marked with a dashed line, and it is connected to the next instruction that would be executed if the pseudo-predicate was a \textsl{nop}. + + Nodes that represent a call to a method $M$ include the transfer of parameters and variables that may be read or written to, then execute the call, and finally the extraction of modified variables. Call nodes are an exception to the previous paragraph, as they can have an unlimited amount of outgoing edges. Each outgoing edge lands on a pseudo-predicate which indicates if the execution was correct or an exception was raised. The executable edge of each pseudo-predicate will lead to the next instruction to be executed, whereas the non-executable one will lead to the end of the try-catch block. All call nodes can lead to a \textsl{normal return} node, which is linked to the next instruction, and one error node for each type of exception that may be thrown. The erroneous returns are labeled \textsl{catch ExType}, and lead to the first instruction in the corresponding catch block\footnotemark. Any exception that may not be caught will lead to the erroneous exit node of the method it's in. See the example for more details. + + \footnotetext{A problem presents itself here, as some exceptions may be able to trigger different catch blocks, due to the secuential nature of catches and polymorphism in Java. A way to fix this is to make catch blocks behave as a switch.}. %TODO + + \item[Step 3 (compute dependences):] For each node in the CFG, compute the control and data dependencies. Non-executable edges are only included when computing control dependencies.\\ + \carlos{put inside definition} + A node $a$ is \textsl{control dependent} on node $b$ iff $a$ post-dominates one but not all of $b$'s successors.\\ + A node $a$ is \textsl{data dependent} on node $b$ iff $b$ defines or may define a variable $x$, $a$ uses or may use $x$, and there is an $x$-definition-free path in the CFG from $b$ to $a$.\\ + \item[Step 4 (convert each CFG into a PDG):] each node of the CFG is one node of the PDG, with two exceptions. The first are the \textsl{enter}, \textsl{exit} and method call nodes, where the variable input and output assignments are split and placed as control-dependent on their original node. The second is the \textsl{exit} node, which is to be removed (the control-dependencies from \textsl{exit} to the variable outputs is transferred to the \textsl{enter} node). Then all the dependencies computed in the previous step are drawn. + \item[Step 5 (connect PDGs to form a SDG):] each method call to $M$ must be connected to the \textsl{enter} node in $M$'s PDG, as a control dependence. Each variable input from the method call is connected to a variable input of the method definition via a data dependence. Each variable output from the method definition is connected to the variable output of the method call via a data dependence. Each method exit is connected \carlos{complete}. +\end{description} + +\begin{itemize} + \item An extra type of control dependency represented by an ``exception edge''. It will represent the need to include a \textsl{catch} clause when an exception can be thrown. It is represented with a dotted line (dashed line is for data dependency). These edges have a special characteristic: when one is traversed, only ``exception edges'' may be traversed from the new nodes included in the slice. If the same node is reached by another kind of edge, the restriction is lifted. The behavior is documented in algorithm \ref{alg:2pass}, with changes from the original algorithm are \underline{underlined}. + \item Add an extra ``exception edge'' from each ``exit with exception of type T'' node, where the type of the exception is \texttt{t} to all the corresponding ``\texttt{throw e}'', such that \texttt{e} is or inherits from \texttt{T}. + \item Add an extra ``exception edge'' from each catch statement to every statement that can throw that error. + \item The exception edges will only be placed when the method or the try-catch statement are loop-carrier\footnote{Loop-carrier, when referring to a statement, is the property that in a CFG for the complete program, the node representing the statement is part of a loop, meaning that it could be executed again once it is executed.}. +\end{itemize} + +\begin{algorithm} % generate slice +\caption{Two-pass algorithm to obtain a backward static slice with exceptions} +\label{alg:2pass} +\begin{algorithmic}[1] + \REQUIRE SDG $\mathcal{G}$ representing program P. $\mathcal{G} = \{\mathcal{S}, \mathcal{E}\}$, where $\mathcal{S}$ is a set of states (some are statements) connected by a set of edges $\mathcal{E}$. Each edge, is a triplet composed of the type of edge (control, data or \underline{exception} dependency, summary, param-in, param-out), the source and destination of the edge. + \REQUIRE A slicing criterion, composed of a statement $s \in \mathcal{S}$ and a variable $v$. + \ENSURE $\mathcal{S}' \subseteq \mathcal{S}$, representing the slice of P according to the criterion provided. + + \medskip + \COMMENT{First pass (do not traverse output parameter edges).} + \STATE{$\mathcal{S}' \Leftarrow \emptyset$ (slice), $\mathcal{Q}\Leftarrow\{s\}$ (queue), $\mathcal{S}\Leftarrow \mathcal{S} - \{s\}$ (not visited), $\mathcal{R}\Leftarrow \emptyset$ (only visited via exception edge)} + \WHILE{$\mathcal{Q} \neq \emptyset$} + \STATE{$a \in \mathcal{Q}$} \COMMENT{Select an element from $\mathcal{Q}$} + \STATE{$\mathcal{Q} \Leftarrow \mathcal{Q} - \{a\}$} + \STATE{$\mathcal{S}' \Leftarrow \mathcal{S}' + \{a\}$} + \FORALL{$\mathcal{A}$ in $\{\{type, origin, a\} \in \mathcal{E}\}$} + \IF{$type \neq$ param-out \AND ($origin \notin \mathcal{S}'$ \OR ($origin \in \mathcal{R}$ \AND $a \notin \mathcal{R}$))} \label{line:param-out} + \IF{\underline{$a \in \mathcal{R}$}} + \IF{\underline{$type =$ exception}} + \STATE{\underline{$\mathcal{Q} \Leftarrow \mathcal{Q} + \{origin\}$}} + \STATE{\underline{$\mathcal{R} \Leftarrow \mathcal{R} + \{origin\}$}} + \ENDIF + \ELSE + \STATE{$\mathcal{Q} \Leftarrow \mathcal{Q} + \{origin\}$} + \ENDIF + \ENDIF + \ENDFOR + \ENDWHILE + \\ + \medskip + \COMMENT{Second pass (very similar, do not traverse input parameter edges).} + \STATE $\mathcal{Q} \Leftarrow \mathcal{S}'$ + \WHILE{$\mathcal{Q} \neq \emptyset$} + \STATE{$a \in \mathcal{Q}$} \COMMENT{Select an element from $\mathcal{Q}$} + \STATE{$\mathcal{Q} \Leftarrow \mathcal{Q} - \{a\}$} + \STATE{$\mathcal{S}' \Leftarrow \mathcal{S}' + \{a\}$} + \FORALL{$\mathcal{A}$ in $\{\{type, origin, a\} \in \mathcal{E}\}$} + \IF{$type \neq$ param-in \AND ($origin \notin \mathcal{S}'$ \OR ($origin \in \mathcal{R}$ \AND $a \notin \mathcal{R}$))} + \IF{\underline{$a \in \mathcal{R}$}} + \IF{\underline{$type =$ exception}} + \STATE{\underline{$\mathcal{Q} \Leftarrow \mathcal{Q} + \{origin\}$}} + \STATE{\underline{$\mathcal{R} \Leftarrow \mathcal{R} + \{origin\}$}} + \ENDIF + \ELSE + \STATE{$\mathcal{Q} \Leftarrow \mathcal{Q} + \{origin\}$} + \ENDIF + \ENDIF + \ENDFOR + \ENDWHILE +\end{algorithmic} +\end{algorithm} + +% vim: set noexpandtab:ts=2:sw=2:wrap diff --git a/img/nested-unconditional-cfg.dot b/img/nested-unconditional-cfg.dot new file mode 100644 index 0000000..b213404 --- /dev/null +++ b/img/nested-unconditional-cfg.dot @@ -0,0 +1,22 @@ +digraph cfg { + start -> while [label = T]; + while -> "if (Y)" [label = "T"]; + while -> D [label = "F"]; + D -> end; + "if (Y)" -> "if (Z)" [label=T]; + "if (Y)" -> C [label=F]; + "if (Z)" -> A [label=T]; + "if (Z)" -> B [label=F]; + //node [color="red"]; + A -> break1; + B -> break2; + break1 -> D [label = T]; + break2 -> D [label = T]; + while [label="while (X)"]; + break1 [label = "break"]; + break2 [label = "break"]; + break1 -> B [style=dashed, label = F]; + break2 -> C [style=dashed, label = F]; + C -> while; + start -> end [label = F, style = dashed]; +} \ No newline at end of file diff --git a/img/nested-unconditional-cfg.pdf b/img/nested-unconditional-cfg.pdf new file mode 100644 index 0000000000000000000000000000000000000000..f58a8651d022176c1abcce8e01ff6b95f23ca8ed GIT binary patch literal 16724 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 {while; D}; + entry [style = filled]; + while [label = "while (X)", style = filled]; + while -> {"if (Y)" C}; + C [style = "bold,filled"]; + "if (Y)" -> C [label = 2]; + "if (Y)" [style = filled]; + "if (Y)" -> {"if (Z)" B break2}; + "if (Z)" -> {A break1}; + "if (Z)" [style = filled, color = lightblue]; + "if (Z)" -> {B break2} [label = 1]; + break1 -> {B break2} [label = 1]; + break2 -> {C while} [label = 2]; + {rank=same; A break1 B break2} + break1 [label = "break 1", style = filled, color = lightblue]; + break2 [label = "break 2", style = filled]; + {rank=same; "if (Z)" C} + {rank=same; while D} + {edge [style=invis]; + A -> break1 -> B -> break2; + } +} \ No newline at end of file diff --git a/img/nested-unconditional-pdg.pdf b/img/nested-unconditional-pdg.pdf new file mode 100644 index 0000000000000000000000000000000000000000..a2b82fd53a3f933f8c692a0ae785c0aca0b5cae9 GIT binary patch literal 16253 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