annotate paper/anatofuz-sigos.tex @ 39:228d350be33e

update tex
author anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
date Wed, 06 May 2020 13:34:53 +0900
parents 9e40a7a00a02
children a91592fafeb1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 %%
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 %% 研究報告用スイッチ
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3 %% [techrep]
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 %%
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 %% 欧文表記無しのスイッチ(etitle,eabstractは任意)
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 %% [noauthor]
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 %%
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 %\documentclass[submit,techrep]{ipsj}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 \documentclass[submit,techrep,noauthor]{ipsj}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
23
2be09c284a2e add meta-cg-dg.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 22
diff changeset
14 \usepackage[dvips,dvipdfmx]{graphicx}
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 \usepackage{latexsym}
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
16 \usepackage{listings}
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
17 \lstset{
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
18 language=C,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
19 tabsize=2,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
20 frame=single,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
21 basicstyle={\tt\footnotesize}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
22 identifierstyle={\footnotesize}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
23 commentstyle={\footnotesize\itshape}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
24 keywordstyle={\footnotesize\ttfamily}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
25 ndkeywordstyle={\footnotesize\ttfamily}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
26 stringstyle={\footnotesize\ttfamily},
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
27 breaklines=true,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
28 captionpos=b,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
29 columns=[l]{fullflexible}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
30 xrightmargin=0zw, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
31 xleftmargin=1zw, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
32 aboveskip=1zw,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
33 numberstyle={\scriptsize}, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
34 stepnumber=1,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
35 numbersep=0.5zw, %
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
36 lineskip=-0.5ex,
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
37 }
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
38 \usepackage{caption}
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
39
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 \def\Underline{\setbox0\hbox\bgroup\let\\\endUnderline}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 \def\endUnderline{\vphantom{y}\egroup\smash{\underline{\box0}}\\}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 \def\|{\verb|}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 %
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
45
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 %\setcounter{巻数}{59}%vol59=2018
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 %\setcounter{号数}{10}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 %\setcounter{page}{1}
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
49 \renewcommand{\lstlistingname}{Code}
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 \begin{document}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 \title{xv6の構成要素の継続の分析}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 %\etitle{How to Prepare Your Paper for IPSJ SIG Technical Report \\ (version 2018/10/29)}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
57
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 \affiliate{KIE}{琉球大学大学院理工学研究科情報工学専攻}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 \affiliate{IE}{琉球大学工学部工学科知能情報コース}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 \author{清水 隆博}{Shimizu Takahiro}{KIE}[anatofuz@cr.ie.u-ryukyu.ac.jp]
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 \author{河野 真治}{Shinji Kono}{IE}[kono@ie.u-ryukyu.ac.jp]
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 \begin{abstract}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 OS自体そのものは高い信頼性が求められるが、 OSを構成するすべての処理をテストするのは困難である。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 テストを利用して信頼性を高めるのではなく、 OSの状態を状態遷移を基本としたモデルに変換し形式手法を用いて信頼性を高めたい。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 状態遷移単位での記述に適した言語であるCbCを用いて、小さなunixであるxv6 kernelの書き換えを行っている。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 このためには現状のxv6 kernelの処理がどのような状態遷移を行うのかを分析し、継続ベースでのプログラミングに変換していく必要がある。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 本稿ではxv6kernelの構成要素の一部に着目し、状態遷移系の分析と状態遷移系を元に継続ベースでxv6の再実装を行う。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 \end{abstract}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
73
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
74
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 \maketitle
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
76
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 \section{OSの信頼性}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 様々なアプリケーションはOSの上で動作するのが当たり前になってきた。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 アプリケーションの信頼性を向上させるのはもとより、 土台となるOS自体の信頼性は高く保証されていなければならない。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 OSそのものも巨大なプログラムであるため、 テストコードを用いた方法で信頼性を確保する事が可能である。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 しかし並列並行処理などに起因する動かしてみないと発見できないバグなどが存在するため、 テストで完全にバグを発見するのは困難である。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 また、OSを構成する処理も巨大であるため、 これら全てをテスト仕切るのも困難である。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 テスト以外の方法でOSの信頼性を高めたい。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
84
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 数学的な背景に基づく形式手法を用いてOSの信頼性を向上させることを検討する。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 OSを構成する要素をモデル検査してデッドロックなどを検知する方法や、 定理証明支援系を利用した証明ベースでの信頼性の確保などの手法が考えられる。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 形式手法で信頼性を確保するには、 まずOSの処理を証明などがしやすい形に変換して実装し直す必要がある。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 これに適した形として、 状態遷移モデルが挙げられる。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 OSの内部処理の状態を明確にし、 状態遷移モデルに落とし込むことでモデル検査などを通して信頼性を向上させたい。
22
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
90 既存のOSはそのままに処理を状態遷移モデルに落とし込む為には、 まず既存のOSの処理中の状態遷移を分析し、仕様記述言語などによる再実装が必要となる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
91 しかし仕様記述言語や定理証明支援系では、 実際に動くOSと検証用の実装が別の物となってしまうために、 C言語などでの実装の段階で発生するバグを取り除くことができない。
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 実装のソースコードと検証用のソースコードは近いセマンティクスでプログラミングする必要がある。
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
93
21
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
94 さらに本来行いたい処理の他に、メモリ管理やスレッド、 CPUなどの資源管理も行う必要がある。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
95 本来計算機で実行したい計算に必要な計算をメタ計算と呼び、 意図して行いたい処理をノーマルレベルの計算と呼ぶ。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
96 ノーマルレベル上での問題点をメタ計算上で発見し信頼性を向上させたい。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
97 プログラマからはノーマルレベルの計算のみ実装するが、整合性の確認や拡張を行う際にノーマルレベルと同様の記述力でメタ計算も実装できる必要がある。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
98
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
99 ノーマルレベルの計算とメタ計算の両方の実装に適した言語としてContinuation Based C(CbC)がある。
12
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
100 CbCはCと互換性のあるCの下位言語であり、 状態遷移をベースとした記述に適したプログラミング言語である。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
101 Cとの互換性のために、 CbCのプログラムをコンパイルすることで動作可能なバイナリに変換が可能である。
15
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
102 またCbCの基本文法は簡潔であるため、 Agdaなどの定理証明支援系との相互変換や、 CbC自体でのモデル検査が可能であると考えられる。
12
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
103 すなわちCbCを用いて状態遷移を基本とした単位でプログラミングをすると、 形式手法で証明が可能かつ実際に動作するコードを記述できる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
104
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
105 現在小さなunixであるxv6 kernelをCbCを用いて再実装している。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
106 再実装の為には、 既存のxv6 kernelの処理の状態遷移を分析し、継続を用いたプログラムに変換していく必要がある。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
107 本論文ではこの書き換えに伴って得られたxv6 kernelの継続を分析し、 現在のCbCによる書き換えについて述べる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
108
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
109
13
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
110
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
111 \section{Continuation Based C}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
112
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
113 Continuation Based C(CbC)とはC言語の下位言語であり、 関数呼び出しではなく継続を導入したプログラミング言語である。
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
114 CbCでは通常の関数呼び出しの他に、 関数呼び出し時のスタックの操作を行わず、次のコードブロックに\texttt{jmp}命令で移動する継続が導入されている。
13
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
115 この継続はSchemeなどの環境を持つ継続とは異なり、 スタックを持たず環境を保存しない継続である為に軽量である事から軽量継続と呼べる。
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
116 またCbCではこの軽量継続を用いた再帰呼び出しを利用することで\texttt{for}文などのループ文を廃し、 関数型プログラミングに近いスタイルでプログラミングが可能となる。
13
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
117 現在CbCはGCC及びLLVM/clang上にそれぞれ実装されている。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 12
diff changeset
118
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
119
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
120 CbCでは関数の代わりにCodeGearという単位でプログラミングを行う。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
121 CodeGearは通常のCの関数宣言の返り値の型の代わりに\texttt{\_\_code}で宣言を行う。
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
122 各CodeGearはDataGearと呼ばれるデータの単位で入力を受け取り、 その結果を別のDataGearに書き込む。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
123 入力のDataGearをInputDataGearと呼び、 出力のDataGearをOutputDataGearと呼ぶ。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
124 CodeGearがアクセスできるDataGearは、 InputDataGearとOutputDataGearに限定される。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
125 これらの関係図を図\ref{fig:cgdg}に示す。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
126
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
127 \begin{figure}[tb]
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
128 \begin{center}
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
129 \includegraphics[width=80mm]{fig/cgdg.pdf}
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
130 \end{center}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
131 \caption{CodeGearと入出力の関係図}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
132 \label{fig:cgdg}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
133 \end{figure}
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
134
15
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
135 CbCで階乗を求める例題をCode \ref{src:cbc_example}に示す。
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
136 例題ではCodeGearとして\texttt{factorial}を宣言している。
18
099e7864ee79 fix md2tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
137 \texttt{factorial}はCodeGearの引数として\texttt{struct F}型の変数\texttt{arg}を受け取り、\texttt{arg}のメンバー変数によって\texttt{factorial}の再帰呼び出しを行う。
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
138 CodeGearの呼び出しは\texttt{goto}文によって行われる。
25
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
139 この例題を状態遷移図にしたものを図\ref{fig:factorial_cbc}に示す。
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
140 図中の四角がDataGear、 円がCodeGearに対応する。
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
141
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
142
25
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
143 \begin{lstlisting}[frame=lrbt,label=src:cbc_example,caption={CbCで階乗を求める例題}]
15
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
144 __code factorial(struct F arg) {
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
145 if (arg.n<0) {
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
146 exit(1);
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
147 }
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
148 if (arg.n==0) {
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
149 goto arg.next(arg);
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
150 } else {
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
151 arg.r *= arg.n;
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
152 arg.n--;
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
153 goto factorial(arg);
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
154 }
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
155 }
15
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
156 \end{lstlisting}
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
157
25
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
158 \begin{figure}[tb]
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
159 \begin{center}
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
160 \includegraphics[width=80mm]{fig/factorial_cbc.pdf}
25
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
161 \end{center}
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
162 \caption{CbCで階乗を求める例題の状態遷移}
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
163 \label{fig:factorial_cbc}
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
164 \end{figure}
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
165
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
166 CodeGearは関数呼び出し時のスタックを持たない為、一度あるCodeGearに遷移してしまうと元の処理に戻ってくることができない。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
167 しかしCodeGearを呼び出す直前のスタックは保存されるため、 部分的にCbCを適用する場合はCodeGearを呼び出す\texttt{void}型などの関数を経由することで呼び出しが可能となる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
168
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
169 この他にCbCからCへ復帰する為のAPIとして、 環境付きgotoという機能がある。
18
099e7864ee79 fix md2tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
170 これはGCCでは内部コードを生成、 LLVM/clangでは\texttt{setjmp}と\texttt{longjmp}を使うことでCodeGearの次の継続対象として呼び出し元の関数を設定することが可能となる。
17
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
171 したがってプログラマから見ると、通常のCの関数呼び出しの返り値をCodeGearから取得する事が可能となる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 15
diff changeset
172
20
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 18
diff changeset
173 \section{CbCを用いたOSの実装}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 18
diff changeset
174
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 18
diff changeset
175 軽量継続を持つCbCを利用して、 証明可能なOSを実装したい。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 18
diff changeset
176 その為には証明に使用される定理証明支援系や、 モデル検査機での表現に適した状態遷移単位での記述が求められる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 18
diff changeset
177 CbCで使用するCodeGearは、 状態遷移モデルにおける状態そのものとして捉えることが可能である。
22
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
178 CodeGearを元にプログラミングをするにつれて、 CodeGearの入出力のDataも重要であることが解ってきた。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
179 CodeGearとその入出力であるDataGearを基本としたOSとして、 GearsOSの設計を行っている。
25
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
180 現在のGearsOSは並列フレームワークとして実装されており、 実用的なOSのプロトタイプ実装として既存のOS上への実装を目指している。
22
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
181
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
182 GearsOSでは、 CodeGearとDataGearを元にプログラミングを行う。
21
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 20
diff changeset
183 遷移する各CodeGearの実行に必要なデータの整合性の確認などのメタ計算は、 MetaCodeGearと呼ばれる各CodeGearごと実装されたCodeGearで計算を行う。
22
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
184 このMetaCodeGearの中で参照されるDataGearをMetaDataGearと呼ぶ。
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
185 また、 対象のCodeGearの直前で実行されるMetaCodeGearをStubCodeGearと呼ぶ。
36
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 35
diff changeset
186 MetaCodeGearやMetaDataGearは、プログラマが直接実装することはなく、 現在はPerlスクリプトによってGearsOSのビルド時に生成される。
26
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 25
diff changeset
187 CodeGearから別のCodeGearに遷移する際のDataGearなどの関係性を、図\ref{meta-cg-dg}に示す。
25
87813fb8542c add factorial_cbc.pdf
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 24
diff changeset
188
24
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
189 \begin{figure}[tb]
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
190 \begin{center}
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
191 \includegraphics[width=80mm]{./fig/meta-cg-dg.pdf}
24
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
192 \end{center}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
193 \caption{CodeGearとMetaCodeGear}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
194 \label{meta-cg-dg}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 23
diff changeset
195 \end{figure}
26
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 25
diff changeset
196
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
197 通常のコード中では入力のDataGearを受け取りCodeGearを実行、 結果をDataGearに書き込んだ上で別のCodeGearに継続する様に見える。
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
198 この流れを図\ref{meta-cg-dg}の上段に示す。
26
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 25
diff changeset
199 しかし実際はCodeGearの実行の前後に実行されるMetaCodeGearや入出力のDataGearを保存場所から取り出すMetaDataGearなどのメタ計算が加わる。
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
200 これは図\ref{meta-cg-dg}の下段に対応する。
26
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 25
diff changeset
201
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 25
diff changeset
202 遷移先のCodeGearとMetaCodeGearの紐付けや、 計算に必要なDataGearを保存や管理を行うMetaDataGearとしてcontextがある。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 25
diff changeset
203 contextは処理に必要なCodeGearの番号とMetaCodeGearの対応表や、 DataGearの格納場所を持つ。
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
204 計算に必要なデータ構造と処理を持つデータ構造であることから、 contextは従来のOSのプロセスに相当するものと言える。
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
205 cotnextと各データ構造の関わりを図\ref{fig:context_ref}に示す。
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
206 \begin{figure}[tb]
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
207 \begin{center}
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
208 \includegraphics[width=80mm]{fig/Context_ref.pdf}
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
209 \end{center}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
210 \caption{Contextと各データの関係図}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
211 \label{fig:context_ref}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
212 \end{figure}
18
099e7864ee79 fix md2tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
213
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
214 コード上では別のCodeGearに直接遷移している様に見えるが、 実際はcontext内の遷移先のCodeGearに対応するスロットから、対応するMetaCodeGearに遷移する。
36
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 35
diff changeset
215 MetaCodeGear中で、次に実行するCodeGearで必要なDataGearをcontextから取り出し、 実際の計算が行われる。
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
216
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
217
22
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
218 \section{xv6 kernel}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
219
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
220 xv6とはマサチューセッツ工科大学でv6 OSを元に開発された教育用のUNIX OSである。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
221 xv6はANSI Cで実装されており、 x86アーキテクチャ上で動作する。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
222 Raspberry Pi上での動作を目的としたARMアーキテクチャのバージョンも存在する。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
223 本論文では最終的にRaspberry Pi上での動作を目指しているために、 ARMアーキテクチャ上で動作するxv6を扱う。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
224
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
225 xv6は小規模なOSだがファイルシステム、 プロセス、システムコールなどのUNIXの基本的な機能を持つ。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
226 またユーザー空間とカーネル空間が分離されており、 シェルやlsなどのユーザーコマンドも存在する。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
227
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
228 本論文ではxv6のファイルシステム関連の内部処理と、システムコール実行時に実行される処理について分析を行う。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
229 xv6 kernelのファイルシステムは階層構造で表現されており、 最も低レベルなものにディスク階層、 抽象度が最も高いレベルのものにファイル記述子がある。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 21
diff changeset
230
36
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 35
diff changeset
231 本論文ではxv6の継続の分析をシステムコール部分とファイルシステム、 仮想メモリなどのOSの根幹部分でそれぞれ行った。
32
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
232
18
099e7864ee79 fix md2tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 17
diff changeset
233
30
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
234 \section{xv6のシステムコールの継続の分析}
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
235 xv6の処理を継続を中心とした記述で再実装を行う。
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
236 この際に、 xv6のどの処理に着目するかによって継続の実装が異なっていくことが実装につれてわかった。
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
237
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
238 まずxv6の\texttt{read} システムコールに着目し、 システムコール内部でどのような状態を遷移するかを分析した。
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
239 分析結果をCbCのCodeGearに変換し、 状態遷移図におこしたものを図\ref{fig:cbc_readsyscall}に示す。
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
240
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
241 \begin{figure}[tb]
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
242 \begin{center}
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
243 \includegraphics[width=80mm]{fig/readsyscall_state.pdf}
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
244 \end{center}
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
245 \caption{readシステムコールの状態遷移}
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
246 \label{fig:cbc_readsyscall}
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
247 \end{figure}
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
248
30
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
249 CbCで再実装した\texttt{read}システムコールは、 xv6の\texttt{read}システムコールのディスパッチ部分から、 \texttt{cbc\_read}CodeGearに\texttt{goto}文で軽量継続される。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
250 継続後はreadする対象によって\texttt{cbc\_readi}や、 \texttt{cbc\_consoleread}などに状態が変化していく。
32
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
251 各CodeGearの遷移時にはDataGearがやり取りされる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
252 DataGearはxv6のプロセス構造体に埋め込まれたcontextを経由してCodeGearに渡される。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
253
30
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
254 この実装の利点として、 CodeGearの命名と状態が対応しており、 状態遷移図などに落としても自然言語で説明が可能となる点が挙げられる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
255 しかし実際には\texttt{cbc\_readi}の状態はさらに複数のCodeGearに分離しており、 実際に\texttt{read}システムコールを実装するCodeGearの数は図の状態より多い。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
256 この事から、 複数のCodeGearを1つにまとめた上で見た状態と、 各CodeGearそれぞれの状態の2種類の状態があるといえる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
257
34
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 33
diff changeset
258 複数のCodeGearをまとめた状態は、 抽象化したAPIの操作時におけるアルゴリズム上の問題が無いかの確認として使用出来る。
30
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
259 対して各CodeGearそれぞれはモデル検査や、 特定の関数の中の処理が適しているかどうかの検査として見ることが出来ると考えられる。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
260
32
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
261 この事からGearsOSでは、 各CodeGearのモジュール化の仕組みであるInterface機能を導入している。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
262 Interfaceの導入によってCodeGearを定義することで状態数を増やしても、 抽象化されたAPIを利用することで細部の状態まで意識する必要が無くなった。
33
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 32
diff changeset
263 xv6の処理をCbCで再実装する際には、 対象の継続のAPIをまず決定しモジュール化を図る必要がある。
30
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
264
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
265 \section{xv6のシステムコール以外の継続の分析}
33
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 32
diff changeset
266 xv6はシステムコール以外に、 ファイルシステムの操作やページテーブルの管理などの処理も存在している。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 32
diff changeset
267 これらはOSの立ち上げ時やシステムコールの中で、ファイルシステムの操作に対応した関数や構造体などのAPIを通して操作される。
35
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
268 システムコールの一連の流れに着目するのではなく、 特定の対象のAPIに着目して継続の分析を検討した。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
269
39
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
270 xv6のファイルシステムに関する関数などのAPIは主に\texttt{fs.c}中に記述されている。
37
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
271 Code\ref{src:fs_interface}に示す様に、 \texttt{fs.c}中に定義されているAPIを抜き出し、 CbCのInterfaceとして定義した。
36
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 35
diff changeset
272 \texttt{\_\_code}から始まるCodeGearの名前が、 それぞれ抽象化されたCodeGearの集合の最初の継続となる。
35
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
273
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
274
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
275 \begin{lstlisting}[frame=lrbt,label=src:fs_interface,caption={ファイルシステム操作のAPIの一部}]
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
276 typedef struct fs<Type,Impl> {
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
277 __code readsb(Impl* fs, uint dev, struct superblock* sb, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
278 __code iinit(Impl* fs, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
279 __code ialloc(Impl* fs, uint dev, short type, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
280 __code iupdate(Impl* fs, struct inode* ip, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
281 __code idup(Impl* fs, struct inode* ip, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
282 __code ilock(Impl* fs, struct inode* ip, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
283 __code iunlock(Impl* fs, struct inode* ip, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
284 __code iput(Impl* fs, struct inode* ip, __code next(...));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
285 ....
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
286 } fs;
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
287 \end{lstlisting}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
288
37
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
289 Code\ref{src:fs_interface}内の \texttt{readsb}などは\texttt{fs.c}内で定義されているCの関数名と対応している。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
290 このCの関数を更に継続ごと分割するために、 関数内のif文などの分岐を持たない基本単位であるBasic Blockに着目した。
30
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 29
diff changeset
291
15
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
292 CbCのCodeGearの粒度はCの関数とアセンブラの中間であるといえるので、 BasicBlockをCodeGearに置き換える事が可能である。
35
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 34
diff changeset
293 したがって特定の関数内の処理のBasicBlockを分析し、 BasicBlockに対応したCodeGearへ変換することが可能となる。
39
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
294 実際にBasicBlock単位で切り分ける前の処理と、切り分けたあとの処理の一部を示す。
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
295 例としてinodeのアロケーションを行うAPIでる\texttt{ialloc}の元のコードをCode\ref{src:ialloc_origin}に示す。
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
296
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
297 \begin{lstlisting}[frame=lrbt,label=src:ialloc_origin,caption={iallocの元のソースコード}]
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
298 struct inode* ialloc (uint dev, short type)
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
299 {
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
300 readsb(dev, &sb);
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
301 for (inum = 1; inum < sb.ninodes; inum++) {
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
302 bp = bread(dev, IBLOCK(inum));
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
303 dip = (struct dinode*) bp->data + inum % IPB;
37
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 36
diff changeset
304
39
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
305 if (dip->type == 0) { // a free inode
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
306 memset(dip, 0, sizeof(*dip));
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
307 // omission
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
308 return iget(dev, inum);
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
309 }
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
310 brelse(bp);
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
311 }
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
312 panic("ialloc: no inodes");
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
313 }
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
314 \end{lstlisting}
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
315
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
316 \texttt{ialloc}はループ条件である \texttt{inum < sb.ninodes}が成立しなかった場合は\texttt{panic}へと状態が遷移する。
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
317 この\texttt{for}文での状態遷移をCodeGearに変換したものをCode\ref{src:allocinode_loopcheck}に示す。
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
318
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
319
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
320 \begin{lstlisting}[frame=lrbt,label=src:allocinode_loopcheck,caption={ループ条件を確認するCodeGear}]
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
321 __code allocinode_loopcheck(struct fs_impl* fs_impl, uint inum, uint dev, struct superblock* sb, struct buf* bp, struct dinode* dip, __code next(...)){
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
322 if( inum < sb->ninodes){
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
323 goto allocinode_loop(fs_impl, inum, dev, type, sb, bp, dip, next(...));
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
324 }
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
325 char* msg = "failed allocinode...";
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
326 struct Err* err = createKernelError(&proc->cbc_context);
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
327 goto err->panic(msg);
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
328 }
228d350be33e update tex
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 37
diff changeset
329 \end{lstlisting}
15
875bf4bc5059 fix example code
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 14
diff changeset
330
29
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
331
5dbe39f52406 add readsyscall_state
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 28
diff changeset
332 \section{CbCを用いた部分的なxv6の書き換え}
28
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
333
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
334 CbCではCodeGear、 DataGearからなる単位を基本とし、 それぞれにメタなGearが付随する。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
335 また実行に必要なCodeGearとDataGearをまとめたcontextというMetaDataGearが存在する。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
336 この機能を元にxv6の書き換えを検討した。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
337
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
338 xv6内でCbCの軽量継続に突入する際は、 元の処理関数に通常の方法では戻ってくることができず、部分的に書き換えていくのが困難である。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
339 今回は呼び出し関数に戻れるスタックフレームを操作したい為に、 ダミーの\texttt{void}関数を用意した。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
340 この関数内でCodeGearに\texttt{goto}文を用いて遷移することで、 CbCから帯域脱出した際に\texttt{void}関数の呼び出し元から処理を継続し、部分的にCbCに書き換えることが可能となった。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
341 Code\ref{src:dumy_function_cbc}では、 \texttt{userinit}関数へ戻るために、 \texttt{cbc\_init\_vmm\_dumy}を経由している。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
342
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
343 \begin{lstlisting}[frame=lrbt,label=src:dumy_function_cbc,caption={部分的にCbCを適応する例}]
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
344 void cbc_init_vmm_dummy(struct Context* cbc_context, struct proc* p, pde_t* pgdir, char* init, uint sz)
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
345 {
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
346 struct vm* vm = createvm_impl(cbc_context);
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
347 goto vm->init_vmm(vm, pgdir, init, sz , vm->void_ret);
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
348 }
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
349
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
350 void userinit(void)
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
351 {
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
352 // omission
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
353
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
354 if((p->pgdir = kpt_alloc()) == NULL) {
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
355 panic("userinit: out of memory?");
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
356 }
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
357
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
358 cbc_init_vmm_dummy(&p->cbc_context, p, p->pgdir, _binary_initcode_start, (int)_binary_initcode_size);
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
359
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
360 p->sz = PTE_SZ;
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
361 memset(p->tf, 0, sizeof(*p->tf));
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 26
diff changeset
362 \end{lstlisting}
14
dff5f09c28c7 use listings
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 13
diff changeset
363
31
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
364
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
365 \section{xv6の今後の再実装}
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
366
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
367 xv6ではカーネルパニックの発生時や、 inodeのキャッシュなどをグローバル変数として利用している。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
368 グローバル変数を使用してしまうと、 CodeGearで定義した状態がDataGear以外のグローバル変数によって変更されてしまう。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
369 グローバル変数を極力使わず継続を中心とした実装を行いたい。
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
370
36
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 35
diff changeset
371 contextは現在プロセス構造体に埋め込まれており、 kernelそのものの状態を制御するためには各contextを管理する機能が必要であると考えられる。
31
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents: 30
diff changeset
372
10
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
373 \nocite{*}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 \bibliographystyle{ipsjunsrt}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
375 \bibliography{anatofuz-bib}
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
376
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
377
d43b107ad199 fix new line encode
anatofuz <anatofuz@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
378 \end{document}