Add two more conclusions.
authorMatthijs Kooijman <matthijs@stdin.nl>
Mon, 4 Aug 2008 10:10:29 +0000 (12:10 +0200)
committerMatthijs Kooijman <matthijs@stdin.nl>
Mon, 4 Aug 2008 10:10:29 +0000 (12:10 +0200)
Report/Main/Conclusions.tex

index 53f5ba45148057b522a8be8f5e8f8b282f17e9f5..4d2585ae6865c8f37bbe96a79aaa0b44acc8c41c 100644 (file)
@@ -17,7 +17,7 @@ subsolutions in that perspective.
 During my (limited amount of) work with the new hardware design, it became
 quickly apparent that trying to design the hardware in an optimal way, was
 completely impossible (when trying to stay within area and power constraints).
-The most important issue in this design is finding the balance between two sides
+The most important issue here is finding the balance between two sides
 of a tradeoff, which was quite often hardware vs compiler complexity. Especially
 this last issue makes it very clear that when designing hardware, the supporting
 tooling should be designed in parallel, to prevent the tooling from needing to
@@ -30,6 +30,22 @@ to. Again, adapting the hardware to support the compiler, has the potential to
 make the compiler considerably less complex and more reliable, at the cost of
 larger hardware complexity, area and power consumption.
 
+However, when looking at the end result, I can conclude that the frontend has
+indeed improved a lot. Even though there are not as many features added to
+MontiumC as hoped, the existing features are more reliably supported now. The
+improvements in the frontend have allowed the backend to become simpler as
+well. Further improvement in this area is still possible, but there are a lot
+of things that the frontend simply cannot deal with, since it requires more
+hardware-specific knowledge or timing information, which the frontend does not
+have.
+
+Using the LLVM for developing the frontend has turned out to work quite well.
+It provides a lot of support code to simplify transforming of code. Also, the
+library-oriented architecture makes it easy to reuse (small) parts of the
+system, while leaving out other parts. In some cases the LLVM code is less
+suitable, but this is mostly solvable and should be less of an issue once the
+new hardware is finished.
+
 All in all, I feel that this internship has worked out quite well. The people
 were cooperating, the job was fun yet challenging and the result is
 well-received.