Commit 41ca2d53 authored by Richard Torenvliet's avatar Richard Torenvliet

made changes to report, started with constant folding

parent 053da966
...@@ -105,18 +105,17 @@ addu $2,$4,$3 addu = $t1, $4, $3 ...@@ -105,18 +105,17 @@ addu $2,$4,$3 addu = $t1, $4, $3
... mov = $2, $t1 ... mov = $2, $t1
... -> ... ... -> ...
... ... ... ...
addu $5,$4,$3 mov = $4, $t1 addu $5,$4,$3 mov = $4, $t1
\end{verbatim} \end{verbatim}
A standard method for doing this is the creation of a DAG or Directed Acyclic A standard method for doing this is the creation of a DAG or Directed Acyclic
Graph. However, this requires a fairly advanced implementation. Our Graph. However, this requires a fairly advanced implementation. Our
implementation is a slightly less fancy, but easier to implement. implementation is a slightly less fancy, but easier to implement.
We search from the end of the block up for instructions that are eligible for We search from the end of the block up for instructions that are eligible for
CSE. If we find one, we check further up in the code for the same instruction, CSE. If we find one, we check further up in the code for the same instruction,
and add that to a temporary storage list. This is done until the beginning of and add that to a temporary storage list. This is done until the beginning of
the block or until one of the arguments of this expression is assigned. the block or until one of the arguments of this expression is assigned. The temporty storage is
We now add the instruction above the first use, and write the result in a new We now add the instruction above the first use, and write the result in a new
variable. Then all occurrences of this expression can be replaced by a move of variable. Then all occurrences of this expression can be replaced by a move of
...@@ -127,6 +126,7 @@ in general not very large and the execution time of the optimizer is not a ...@@ -127,6 +126,7 @@ in general not very large and the execution time of the optimizer is not a
primary concern, this is not a big problem. primary concern, this is not a big problem.
\subsubsection*{Fold constants} \subsubsection*{Fold constants}
Constant folding is an optimization where the outcome of arithmetics are calculated at compile time. If a value x is assigned to a certain value, let's say 10, than all next occurences of \texttt{x} are replaced by 10 until a redefinition of x. Arithmetics in Assembly are always preformed between two constants, if this is not the case the calculation is not possible. See the example for a more clear explanation of constant folding(will come). In other words until the current definition of \texttt{x} becomes dead. Therefore reaching definitions analysis is needed.
......
...@@ -110,8 +110,3 @@ class TestStatement(unittest.TestCase): ...@@ -110,8 +110,3 @@ class TestStatement(unittest.TestCase):
['$1']) ['$1'])
self.assertEqual(S('command','mov.d', '$1','$2').get_def(), ['$1']) self.assertEqual(S('command','mov.d', '$1','$2').get_def(), ['$1'])
self.assertEqual(S('command','dmfc1', '$1','$f0').get_def(), ['$1']) self.assertEqual(S('command','dmfc1', '$1','$f0').get_def(), ['$1'])
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment