This shows you the differences between two versions of the page.
|
cpl:labs-draft:11 [2016/12/19 23:37] bogdan.nitulescu [Exercițiul 3] |
cpl:labs-draft:11 [2016/12/20 01:58] (current) bogdan.nitulescu [Exerciții de laborator (15p)] |
||
|---|---|---|---|
| Line 111: | Line 111: | ||
| [[http://llvm.org/docs/ProgrammersManual.html#dss-bitvector|Aici]] este o scurtă descriere a structurii de date BitVector folosită la exerciţiul 3. | [[http://llvm.org/docs/ProgrammersManual.html#dss-bitvector|Aici]] este o scurtă descriere a structurii de date BitVector folosită la exerciţiul 3. | ||
| - | ====== Exerciții de laborator (10p) ====== | + | ====== Exerciții de laborator (15p) ====== |
| <note> | <note> | ||
| Laboratorul este compus dintr-o exerciții practice care includ analiza formei SSA și implementarea unor optimizări. | Laboratorul este compus dintr-o exerciții practice care includ analiza formei SSA și implementarea unor optimizări. | ||
| - | Înainte de începerea exercițiilor downloadați arhiva de {{:cpl:labs:lab10.zip|aici}}. | + | Înainte de începerea exercițiilor downloadați arhiva de {{:cpl:labs:lab11_2016.zip|aici}}. |
| Compilati exercitiile cu -O0 pentru a nu lasa compilatorul sa aplice optimizari. | Compilati exercitiile cu -O0 pentru a nu lasa compilatorul sa aplice optimizari. | ||
| Line 152: | Line 152: | ||
| ===== Exercițiul 2 ===== | ===== Exercițiul 2 ===== | ||
| - | Folosind codul din fişierul ''Hello2.cpp'' din archiva laboratorului, urmăriţi modul în care pot fi implementată simple constant propagation în LLVM. | + | Scrieti un pass care optimizeaza cazuri de tipul jump to jump. Un caz de jump to jump avem in momentul in care singura intructiune dintr-un basic block este un salt neconditionat intr-un alt bloc. In acest caz toate instructiunile de salt din blocul initial pot fi optimizate pentru a duce direct la blocul destinatie. |
| - | * cum se obţine numele unui basic block? | + | Blocul initial este in acest moment dead code si poate fi eliminat cu pass-ul de la exercitiul anterior. |
| + | |||
| + | <file c jump_to_jump.c> | ||
| + | #include<stdio.h> | ||
| + | #include<time.h> | ||
| + | #include<stdlib.h> | ||
| + | |||
| + | void main(void) { | ||
| + | int x = rand() % 100 - 10; | ||
| + | |||
| + | if ( x < 0 ) { | ||
| + | return; | ||
| + | } else { | ||
| + | printf("Not negative\n"); | ||
| + | } | ||
| + | |||
| + | printf("End\n"); | ||
| + | } | ||
| + | |||
| + | </file> | ||
| + | |||
| + | ===== Exercițiul 3 ===== | ||
| + | |||
| + | Folosind codul din fişierul ''Hello.cpp'' din arhiva laboratorului, urmăriţi modul în care pot fi implementată simple constant propagation în LLVM. | ||
| * cum poate fi identificată o instrucţiune inutilă? | * cum poate fi identificată o instrucţiune inutilă? | ||
| * identificaţi metoda responsabilă pentru constant folding | * identificaţi metoda responsabilă pentru constant folding | ||
| * cum se înlocuiesc apariţiile viitoare ale variabilei în cauză cu o constantă? | * cum se înlocuiesc apariţiile viitoare ale variabilei în cauză cu o constantă? | ||
| * de ce se adaugă din nou în worklist unele instrucţiuni? | * de ce se adaugă din nou în worklist unele instrucţiuni? | ||
| - | * realizaţi un fişier de test (urmând paşii de la exerciţiul 1) pentru a ilustra beneficiile acestui pas. Rulaţi acest pas pe exemplul ales. | + | * Rulaţi acest pas folosind fisierul ''test.c'' din arhiva laboratorului. |
| - | ===== Exercițiul 3 ===== | + | |