Mercurial > hg > Members > kaito > slides
comparison 2013/old/2013_06_11.html @ 0:845ff8ff4fc9
1st
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 14 Jan 2014 01:31:42 +0900 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:845ff8ff4fc9 |
---|---|
1 <!DOCTYPE html> | |
2 <html> | |
3 <head> | |
4 <meta charset='utf-8'> | |
5 | |
6 <script | |
7 src='./trunk/slides.js'></script> | |
8 </head> | |
9 | |
10 <body style='display: none'> | |
11 <section class='slides layout-regular template-default'> | |
12 | |
13 <article> | |
14 <h1>CbCコンパイラのLLVM3.4上での実装</h1> | |
15 <p><br>Kaito Tokumori<br>June 11, 2013</p> | |
16 </article> | |
17 | |
18 <article> | |
19 <br> | |
20 <h3> | |
21 研究目的 | |
22 </h3> | |
23 <ul> | |
24 <li>当研究室で開発しているContinuation based C(CbC)によるtail call eliminationの強制。</li> | |
25 <li>Micro-C,GCC版に次ぐllvmを使用したコンパイラの実装。</li> | |
26 </ul> | |
27 <!-- | |
28 <p> | |
29 当研究室ではcode segment単位で処理を記述するContinuation based C(以下CbC)というプログラミング言語を開発している。Cからループ制御と関数コールを取り除いたもので、C言語よりも細かく、アセンブリより高級なプログラミングが可能である。 | |
30 </p> | |
31 <p> | |
32 また、CbCはcode segment間の移動をcall命令でなくjmp命令で行うという特性を持っており、これにより余分なreturnを減らすことができる。これはtail call eliminationのによって実現されるので、CbCを利用することでtail call eliminationを強制し、プログラムをより最適化できるとも言える。 | |
33 </p> | |
34 <p> | |
35 現在CbCのコンパイルはMicro-C版、GCC版がある。今回の研究ではさらにllvm,clangを用いたコンパイラの実装を行う。 | |
36 </p> | |
37 --> | |
38 </article> | |
39 | |
40 <article> | |
41 <br> | |
42 <h3> | |
43 今週したこと | |
44 </h3> | |
45 <ul> | |
46 <li>goto cs();のparse</li> | |
47 </ul> | |
48 <br> | |
49 </article> | |
50 | |
51 <article> | |
52 <br> | |
53 <ul> | |
54 <li>goto が来た時の処理はParseStatementOrDeclarationAfterAttributes関数で行われる</li> | |
55 <li>goto の次のトークンがidentifierでさらにその次がl_parenの時にCbCのgotoと判断</li> | |
56 <li>今はただのcall</li> | |
57 <li>やっぱりpassを通るようにしないといけない</li> | |
58 </ul> | |
59 <br> | |
60 </article> | |
61 | |
62 <!-- | |
63 <article> | |
64 <br> | |
65 <h3> | |
66 次したいこと | |
67 </h3> | |
68 <ul> | |
69 <li>うごくようにする。</li> | |
70 </ul> | |
71 <br> | |
72 </article> | |
73 --> | |
74 </section> | |
75 </body> | |
76 </html> |