Mercurial > hg > Members > taiki > slides
view seminar/seminar2013/0723.html @ 3:fea44bb81877 default tip
many change
author | taiki |
---|---|
date | Tue, 10 Dec 2013 15:31:33 +0900 |
parents | |
children |
line wrap: on
line source
<!-- Google IO 2012 HTML5 Slide Template Authors: Eric Bidelman <ebidel@gmail.com> Luke Mahé <lukem@google.com> URL: https://code.google.com/p/io-2012-slides --> <!DOCTYPE html> <html> <head> <title>Presentation</title> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="chrome=1"> <!--<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0">--> <!--<meta name="viewport" content="width=device-width, initial-scale=1.0">--> <!--This one seems to work all the time, but really small on ipad--> <!--<meta name="viewport" content="initial-scale=0.4">--> <meta name="apple-mobile-web-app-capable" content="yes"> <link rel="stylesheet" media="all" href="css/default.css"> <link rel="stylesheet" media="only screen and (max-device-width: 480px)" href="../io2012slides/theme/css/phone.css"> <base target="_blank"> <!-- This amazingness opens all links in a new tab. --> <script data-main="../io2012slides/js/slides" src="../io2012slides/js/require-1.0.8.min.js"></script> </head> <body style="opacity: 0"> <slides class="layout-widescreen"> <!-- <slide class="logoslide nobackground"> <article class="flexbox vcenter"> <span><img src="../io2012slides/images/google_developers_logo.png"></span> </article> </slide> --> <slide class="title-slide segue nobackground"> <aside class="gdbar"><img src="../images/concurrent.png"></aside> <!-- The content of this hgroup is replaced programmatically through the slide_config.json. --> <hgroup class="auto-fadein"> <h1 data-config-title><!-- populated from slide_config.json --></h1> <h2 data-config-subtitle><!-- populated from slide_config.json --></h2> <p data-config-presenter><!-- populated from slide_config.json --></p> </hgroup> </slide> <slide> <hgroup> <h2>研究目的</h2> </hgroup> <article> <ul> <li>ブートが高速で、コンパクトなカーネルを実装する。</li> <li>Codesegment と Datasegment をカーネルに実装するにあたって、メモリ管理の役割とどう合致するのかを検証する。</li> <li>上記を確認したら CbC を用いて、動作が軽く落ちにくいカーネルを実装する。</li> <li>モデル検証に対応し、エラー予測を可能にする</li> <li>カーネルパニックをなくす</li> <li>Mach-O を ELILO でロードし、64bit で動作可能にする</li> </ul> </article> </slide> <slide> <hgroup> <h2>ELILO</h2> </hgroup> <article> <h3>現状</h3> <img src="images/flowchart.png"> </article> </slide> <slide> <hgroup> <h2>ELILO</h2> </hgroup> <article> <h3>目標</h3> <ul> <li>Page Table を初期化</li> <li>一度 Paging を disable </li> <li>CR3 レジスタに初期化した Page Table を登録</li> <li>再度 Paging を enable</li> </ul> <h4>目標 [EFI version]</h4> <ul> <li>memmap を設定</li> <li>新しく仮想メモリ用に memmap を作る</li> <li>irq をセーブして、pgd を作る[TLB をフラッシュ]</li> <li>UEFI API SetVirtualAddressMap を call</li> <li>pgd を登録して、irq をリストア[TLB をフラッシュ]</li> </ul> <h3>どちらかの方法で、ELILO 内に Page table を作る</h3> </article> </slide> <slide> <hgroup> <h2>Linux カーネル内の 64bit ページング</h2> </hgroup> <article> <ul> <li>UEFI 関係の関数とは別に、paging_init() がある</li> <li> <ul> <li>sparse_memory_present_with_active_regions()</li> <li>sparse_init()</li> <li>node_clear_state()</li> <li>zone_size_init()</li> </ul> </li> <li>ページそれぞれに、他と重複しないページフレーム番号(PFN)が割り振られる</li> <li>ちなみに、page size は $pagesize コマンドで見ることができる(単位は byte)</li> </ul> </article> </slide> <slide> <hgroup> <h2>paging_init</h2> </hgroup> <article> <pre> void __init paging_init(void) { sparse_memory_present_with_active_regions(MAX_NUMNODES); sparse_init(); /* * clear the default setting with node 0 * note: don't use nodes_clear here, that is really clearing when * numa support is not compiled in, and later node_set_state * will not set it back. */ node_clear_state(0, N_MEMORY); if (N_MEMORY != N_NORMAL_MEMORY) node_clear_state(0, N_NORMAL_MEMORY); zone_sizes_init(); } </pre> </article> </slide> <slide class="backdrop"></slide> </slides> <script> var _gaq = _gaq || []; _gaq.push(['_setAccount', 'UA-XXXXXXXX-1']); _gaq.push(['_trackPageview']); (function() { var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true; ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s); })(); </script> <!--[if IE]> <script src="http://ajax.googleapis.com/ajax/libs/chrome-frame/1/CFInstall.min.js"></script> <script>CFInstall.check({mode: 'overlay'});</script> <![endif]--> </body> </html>