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>