annotate seminar/seminar2012/20130122.html @ 3:fea44bb81877 default tip

many change
author taiki
date Tue, 10 Dec 2013 15:31:33 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3
fea44bb81877 many change
taiki
parents:
diff changeset
1 <!DOCTYPE html>
fea44bb81877 many change
taiki
parents:
diff changeset
2
fea44bb81877 many change
taiki
parents:
diff changeset
3 <!--
fea44bb81877 many change
taiki
parents:
diff changeset
4 Google HTML5 slide template
fea44bb81877 many change
taiki
parents:
diff changeset
5
fea44bb81877 many change
taiki
parents:
diff changeset
6 Authors: Luke Mahé (code)
fea44bb81877 many change
taiki
parents:
diff changeset
7 Marcin Wichary (code and design)
fea44bb81877 many change
taiki
parents:
diff changeset
8
fea44bb81877 many change
taiki
parents:
diff changeset
9 Dominic Mazzoni (browser compatibility)
fea44bb81877 many change
taiki
parents:
diff changeset
10 Charles Chen (ChromeVox support)
fea44bb81877 many change
taiki
parents:
diff changeset
11
fea44bb81877 many change
taiki
parents:
diff changeset
12 URL: http://code.google.com/p/html5slides/
fea44bb81877 many change
taiki
parents:
diff changeset
13 -->
fea44bb81877 many change
taiki
parents:
diff changeset
14
fea44bb81877 many change
taiki
parents:
diff changeset
15 <html>
fea44bb81877 many change
taiki
parents:
diff changeset
16 <head>
fea44bb81877 many change
taiki
parents:
diff changeset
17 <title>Presentation</title>
fea44bb81877 many change
taiki
parents:
diff changeset
18 <link src='../styles.css'>
fea44bb81877 many change
taiki
parents:
diff changeset
19 <meta charset='utf-8'>
fea44bb81877 many change
taiki
parents:
diff changeset
20 <script
fea44bb81877 many change
taiki
parents:
diff changeset
21 src='../slides.js'></script>
fea44bb81877 many change
taiki
parents:
diff changeset
22 </head>
fea44bb81877 many change
taiki
parents:
diff changeset
23
fea44bb81877 many change
taiki
parents:
diff changeset
24 <style>
fea44bb81877 many change
taiki
parents:
diff changeset
25 /* Your individual styles here, or just use inline styles if that’s
fea44bb81877 many change
taiki
parents:
diff changeset
26 what you want. */
fea44bb81877 many change
taiki
parents:
diff changeset
27
fea44bb81877 many change
taiki
parents:
diff changeset
28
fea44bb81877 many change
taiki
parents:
diff changeset
29 </style>
fea44bb81877 many change
taiki
parents:
diff changeset
30 <body style='display: none'>
fea44bb81877 many change
taiki
parents:
diff changeset
31
fea44bb81877 many change
taiki
parents:
diff changeset
32 <section class='slides layout-regular template-default'>
fea44bb81877 many change
taiki
parents:
diff changeset
33
fea44bb81877 many change
taiki
parents:
diff changeset
34 <!-- Your slides (<article class='nobackground'>s) go here. Delete or comment out the
fea44bb81877 many change
taiki
parents:
diff changeset
35 slides below. -->
fea44bb81877 many change
taiki
parents:
diff changeset
36
fea44bb81877 many change
taiki
parents:
diff changeset
37 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
38 <h1>CbC による OS の実装</h1>
fea44bb81877 many change
taiki
parents:
diff changeset
39 <p>Taiki Taira / Jan 22 2013</p>
fea44bb81877 many change
taiki
parents:
diff changeset
40 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
41
fea44bb81877 many change
taiki
parents:
diff changeset
42 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
43 <h3>研究目的[1/2]</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
44 <p>
fea44bb81877 many change
taiki
parents:
diff changeset
45 本研究では code segment ,datasegment に沿った OS を実装することを目的とする。<br>
fea44bb81877 many change
taiki
parents:
diff changeset
46 その実装には、本研究室で開発された Continuation based C (CbC)を用いる。<br>
fea44bb81877 many change
taiki
parents:
diff changeset
47 CbC は C 言語よりも低くアセンブラより高い層で記述できる言語である。C の仕様からループ制御や関数コールを取り除いている。これによりスタックの操作やループ、関数呼び出しなどのより低レベルでの最適化をソースコードレベルで行うことができる。<br>
fea44bb81877 many change
taiki
parents:
diff changeset
48 </p>
fea44bb81877 many change
taiki
parents:
diff changeset
49 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
50
fea44bb81877 many change
taiki
parents:
diff changeset
51 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
52 <h3>研究目的[2/2]</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
53 <p>
fea44bb81877 many change
taiki
parents:
diff changeset
54 Codesegment, Datasegment を意識した設計にし、メモリ外へのアクセスを制限しセキュリティの向上と、malloc/free などのメモリ管理を OS に行わせ、プログラマの負担を減らす。<br>
fea44bb81877 many change
taiki
parents:
diff changeset
55 故障が発生した際に、機能を完全に喪失するのではなく、 可能な範囲で機能が維持されるようにすることを Graceful Degradation という。<br>
fea44bb81877 many change
taiki
parents:
diff changeset
56 この Graceful Degradation を目指して実装をすすめる。<br>
fea44bb81877 many change
taiki
parents:
diff changeset
57 </p>
fea44bb81877 many change
taiki
parents:
diff changeset
58 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
59
fea44bb81877 many change
taiki
parents:
diff changeset
60 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
61 <h3>
fea44bb81877 many change
taiki
parents:
diff changeset
62 設計[1/3]
fea44bb81877 many change
taiki
parents:
diff changeset
63 </h3>
fea44bb81877 many change
taiki
parents:
diff changeset
64 <img src='boot_process.png'>
fea44bb81877 many change
taiki
parents:
diff changeset
65 <img src='kernel.png'>
fea44bb81877 many change
taiki
parents:
diff changeset
66 <p>
fea44bb81877 many change
taiki
parents:
diff changeset
67 Datasegment Manager から Codesegment / Task / Datasegment を取り出して、Codesegment Manager へ投げる。
fea44bb81877 many change
taiki
parents:
diff changeset
68 </p>
fea44bb81877 many change
taiki
parents:
diff changeset
69 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
70
fea44bb81877 many change
taiki
parents:
diff changeset
71 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
72 <h3>
fea44bb81877 many change
taiki
parents:
diff changeset
73 設計[2/3] CodeSegment
fea44bb81877 many change
taiki
parents:
diff changeset
74 </h3>
fea44bb81877 many change
taiki
parents:
diff changeset
75 <img src='CodeSegment.png'>
fea44bb81877 many change
taiki
parents:
diff changeset
76 <p>Task で Codesegment に対応している Datasegment を InputDatasegment を通して Codesegment で実行する。
fea44bb81877 many change
taiki
parents:
diff changeset
77 <br>OutputDatasegment で Datasegment が正しいか確認する。
fea44bb81877 many change
taiki
parents:
diff changeset
78 <br>InputDatasegment と OutputDatasegment を CodeSegment で実行する結果が、Hoare Logic で証明できる?
fea44bb81877 many change
taiki
parents:
diff changeset
79 </p>
fea44bb81877 many change
taiki
parents:
diff changeset
80 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
81
fea44bb81877 many change
taiki
parents:
diff changeset
82 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
83 <h3>
fea44bb81877 many change
taiki
parents:
diff changeset
84 設計[3/3] DataSegment
fea44bb81877 many change
taiki
parents:
diff changeset
85 </h3>
fea44bb81877 many change
taiki
parents:
diff changeset
86 <img src='DataSegment.png'>
fea44bb81877 many change
taiki
parents:
diff changeset
87 <img src='Moving_DS_pointer.png'>
fea44bb81877 many change
taiki
parents:
diff changeset
88 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
89
fea44bb81877 many change
taiki
parents:
diff changeset
90 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
91 <h3>
fea44bb81877 many change
taiki
parents:
diff changeset
92 設計[3/3] DataSegment
fea44bb81877 many change
taiki
parents:
diff changeset
93 </h3>
fea44bb81877 many change
taiki
parents:
diff changeset
94 <p>
fea44bb81877 many change
taiki
parents:
diff changeset
95 Persistent Datasegment から key を参照してデータを取ってくることが基本になる。
fea44bb81877 many change
taiki
parents:
diff changeset
96 <br>PDS からコピーして Datasegment は Temporary Datasegment に。使い終わったら、さらに TDS をコピーして PDS へ戻す。
fea44bb81877 many change
taiki
parents:
diff changeset
97 <br>基本的には PDS から Task を参照して、CS と CS に必要な DS をコピーし、CS を CS Manager で実行。
fea44bb81877 many change
taiki
parents:
diff changeset
98 </p>
fea44bb81877 many change
taiki
parents:
diff changeset
99 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
100
fea44bb81877 many change
taiki
parents:
diff changeset
101 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
102 <h3>論文目次[1/2]</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
103 <ul>
fea44bb81877 many change
taiki
parents:
diff changeset
104 <li>研究目的/背景</li>
fea44bb81877 many change
taiki
parents:
diff changeset
105 <li>CbC<br>
fea44bb81877 many change
taiki
parents:
diff changeset
106 CbC で実装することの利点</li>
fea44bb81877 many change
taiki
parents:
diff changeset
107 <li>UEFI<br>
fea44bb81877 many change
taiki
parents:
diff changeset
108 UEFI でロードすることの利点</li>
fea44bb81877 many change
taiki
parents:
diff changeset
109 <li>64bit OS</li>
fea44bb81877 many change
taiki
parents:
diff changeset
110 <li>Page Table Entry<br>
fea44bb81877 many change
taiki
parents:
diff changeset
111 特権モード/ユーザーモード</li>
fea44bb81877 many change
taiki
parents:
diff changeset
112 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
113
fea44bb81877 many change
taiki
parents:
diff changeset
114 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
115 <h3>論文目次[2/2]</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
116 <ul>
fea44bb81877 many change
taiki
parents:
diff changeset
117 <li>Codesegment <br>
fea44bb81877 many change
taiki
parents:
diff changeset
118 Codesegment Manager</li>
fea44bb81877 many change
taiki
parents:
diff changeset
119 <li>Datasegment</li>
fea44bb81877 many change
taiki
parents:
diff changeset
120 Datasegment Manager</li>
fea44bb81877 many change
taiki
parents:
diff changeset
121 <li>Protocol <br>
fea44bb81877 many change
taiki
parents:
diff changeset
122 Protocol Manager</li>
fea44bb81877 many change
taiki
parents:
diff changeset
123 <li>今後の課題<br>
fea44bb81877 many change
taiki
parents:
diff changeset
124 device driver</li>
fea44bb81877 many change
taiki
parents:
diff changeset
125 </ul>
fea44bb81877 many change
taiki
parents:
diff changeset
126 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
127
fea44bb81877 many change
taiki
parents:
diff changeset
128 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
129 <h3>
fea44bb81877 many change
taiki
parents:
diff changeset
130 今週の作業 [ ~ 2013/01/22 ]
fea44bb81877 many change
taiki
parents:
diff changeset
131 </h3>
fea44bb81877 many change
taiki
parents:
diff changeset
132 <ul>
fea44bb81877 many change
taiki
parents:
diff changeset
133 <li>Mach-O loader を書いている最中</li>
fea44bb81877 many change
taiki
parents:
diff changeset
134 <li>Linux のメモリ管理を読む</li>
fea44bb81877 many change
taiki
parents:
diff changeset
135 </ul>
fea44bb81877 many change
taiki
parents:
diff changeset
136 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
137
fea44bb81877 many change
taiki
parents:
diff changeset
138 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
139 <h3>elilo</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
140 <p>Linux 用の bootloader。EFI の API を利用して、EFI からメモリの allocate や kernel のロード、kernel の実行などを行う。</p>
fea44bb81877 many change
taiki
parents:
diff changeset
141 <ul> elilo の使う filesystem
fea44bb81877 many change
taiki
parents:
diff changeset
142 <li>・Local filesystem</li>
fea44bb81877 many change
taiki
parents:
diff changeset
143 <li>・Net filesystem</li>
fea44bb81877 many change
taiki
parents:
diff changeset
144 <li>・Ext2 filesystem</li>
fea44bb81877 many change
taiki
parents:
diff changeset
145 </ul>
fea44bb81877 many change
taiki
parents:
diff changeset
146 <p>今回は Local filesystem を使う。</p>
fea44bb81877 many change
taiki
parents:
diff changeset
147 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
148
fea44bb81877 many change
taiki
parents:
diff changeset
149 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
150 <h3>efi application</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
151 <ul>
fea44bb81877 many change
taiki
parents:
diff changeset
152 <li>0x100000 へロードしboot へ、まだ firmware 上での実行</li>
fea44bb81877 many change
taiki
parents:
diff changeset
153 <li>Read, Open, Close</li>
fea44bb81877 many change
taiki
parents:
diff changeset
154 <li>realmode / protected mode を経由しなくても直接 boot できる……はず</li>
fea44bb81877 many change
taiki
parents:
diff changeset
155 </ul>
fea44bb81877 many change
taiki
parents:
diff changeset
156 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
157
fea44bb81877 many change
taiki
parents:
diff changeset
158 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
159 <h3>Linux memory management</h3>
fea44bb81877 many change
taiki
parents:
diff changeset
160 <ul> arch/x86/mm 以下の
fea44bb81877 many change
taiki
parents:
diff changeset
161 <li>tlb.c</li>
fea44bb81877 many change
taiki
parents:
diff changeset
162 <li>init.c / init_64.c</li>
fea44bb81877 many change
taiki
parents:
diff changeset
163 <li>pgtable.c</li>
fea44bb81877 many change
taiki
parents:
diff changeset
164 </ul>
fea44bb81877 many change
taiki
parents:
diff changeset
165 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
166
fea44bb81877 many change
taiki
parents:
diff changeset
167 <article>
fea44bb81877 many change
taiki
parents:
diff changeset
168 <h3>
fea44bb81877 many change
taiki
parents:
diff changeset
169 今後やること
fea44bb81877 many change
taiki
parents:
diff changeset
170 </h3>
fea44bb81877 many change
taiki
parents:
diff changeset
171 <ul>
fea44bb81877 many change
taiki
parents:
diff changeset
172 <li>引き続き elilo のソース読む</li>
fea44bb81877 many change
taiki
parents:
diff changeset
173 <li>Mach-O / ELF のローダを書く</li>
fea44bb81877 many change
taiki
parents:
diff changeset
174 <li>特権/ユーザーモードについて</li>
fea44bb81877 many change
taiki
parents:
diff changeset
175 </ul>
fea44bb81877 many change
taiki
parents:
diff changeset
176 </article>
fea44bb81877 many change
taiki
parents:
diff changeset
177
fea44bb81877 many change
taiki
parents:
diff changeset
178 </section>
fea44bb81877 many change
taiki
parents:
diff changeset
179
fea44bb81877 many change
taiki
parents:
diff changeset
180 </body>
fea44bb81877 many change
taiki
parents:
diff changeset
181 </html>