view 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
line wrap: on
line source

<!DOCTYPE html>
<html>
  <head>
    <meta charset='utf-8'>
    
    <script
       src='./trunk/slides.js'></script>
  </head>

  <body style='display: none'>
    <section class='slides layout-regular template-default'>

      <article>
	<h1>CbCコンパイラのLLVM3.4上での実装</h1>
        <p><br>Kaito Tokumori<br>June 11, 2013</p>
      </article>

      <article>
	<br> 
	<h3>
	  研究目的
	</h3>
	<ul>
	  <li>当研究室で開発しているContinuation based C(CbC)によるtail call eliminationの強制。</li>
	  <li>Micro-C,GCC版に次ぐllvmを使用したコンパイラの実装。</li>
	</ul>
<!--
	<p>
	   当研究室ではcode segment単位で処理を記述するContinuation based C(以下CbC)というプログラミング言語を開発している。Cからループ制御と関数コールを取り除いたもので、C言語よりも細かく、アセンブリより高級なプログラミングが可能である。
	</p>
	<p>
	  また、CbCはcode segment間の移動をcall命令でなくjmp命令で行うという特性を持っており、これにより余分なreturnを減らすことができる。これはtail call eliminationのによって実現されるので、CbCを利用することでtail call eliminationを強制し、プログラムをより最適化できるとも言える。
	</p>
	<p>
	   現在CbCのコンパイルはMicro-C版、GCC版がある。今回の研究ではさらにllvm,clangを用いたコンパイラの実装を行う。
	</p>
-->
      </article>

      <article>
	<br> 
	<h3>
	  今週したこと
	</h3>
	<ul>
	  <li>goto cs();のparse</li>
	</ul>
	<br>
      </article>

      <article>
	<br> 
	<ul>
	  <li>goto が来た時の処理はParseStatementOrDeclarationAfterAttributes関数で行われる</li>
	  <li>goto の次のトークンがidentifierでさらにその次がl_parenの時にCbCのgotoと判断</li>
	  <li>今はただのcall</li>
	  <li>やっぱりpassを通るようにしないといけない</li>
	</ul>
	<br>
      </article>

<!--
      <article>
	<br> 
	<h3>
	  次したいこと
	</h3>
	<ul>
	  <li>うごくようにする。</li>
	</ul>
	<br>
      </article>
-->
    </section>
  </body>
</html>