大学の専攻がコンピュータサイエンスでなかった筆者が3ヵ月システムプログラミングについて学んだことについてのまとめおよび紹介です。
使った資料
- ブログ
- 書籍
- 30日でできる! OS自作入門
- はじめてのOSコードリーディング ~UNIX V6で学ぶカーネルのしくみ
- プログラムはなぜ動くのか 第2版 知っておきたいプログラムの基礎知識
- オペレーティングシステムの仕組み
- Linuxのしくみ ~実験と図解で学ぶOSとハードウェアの基礎知識
- はじめて読む486―32ビットコンピュータをやさしく語る
- Linuxカーネル2.6解読室
- BareMetalで遊ぶ Raspberry Pi
- コンピュータの構成と設計 第5版 上 (途中まで)
- UNIXネットワークプログラミング〈Vol.1〉ネットワークAPI:ソケットとXTI (途中まで)
- Unix考古学 Truth of the Legend
- Raspberry Pi
- 書いたもの
- その他
おすすめ
低レイヤーの歩き方
すでに有名な記事ですが改めて紹介します。Turing Complete FMにも度々登場しているるくすさんの記事で、システムプログラミングについて学ぶ際の道しるべとなるものです。低レイヤーの概観と、それぞれどのように学習を進めていけばいいかがイメージできるようになります。(記事中には「ロードマップではなく辞書のようなもの」との但し書きがあります。実際3ヵ月間タブを開きっぱなしで事あるごとに参照していました。)この記事に背中を押されたのが今回システムプログラミングを学ぶきっかけでしたし、「よしがんばろう」と勇気付けてくれるブログなのでぜひ一読オススメします。
30日でできる! OS自作入門
ずっと気になっていた通称OS自作本です。本書の方針にある通りOSの仕組みや一般的な機能の説明は最小限に必要な知識だけを都度学んでいくため、体系的な知識を得ることはできませんが、OS開発を体験してみるという意味でとても貴重な本だと思います。解説は「中学生にもわかるように」の言葉通りとても丁寧で読みやすいです。一部理解に詰まる部分もありましたが、読み進めるあるいは他書に触れた後読み返すに従い徐々にわかるようになったので、筆者の言う通りわからないところがあってもとりあえず先に進むのがコツです。
またあとがきが非常に印象的でした。これからの展望––ツールチェインの移植からセルフホストまで––は読んでいてワクワクしましたし、OS開発の心得、とりあえず書いて動かして後から直すあるいは最初から書き直す、といったスクラップ&ビルドの精神は金言として心にとめておこうと思いました。
macOSでの開発環境を整える際に目にした三等兵さんのブログも読んでいて面白かったのでオススメです。
「30日でできる!OS自作入門」のHaribote OSをラズベリーパイに移植してみた
OS自作本を進めていくうちになにか形になるものを作りたいという気持ちが膨らんできました。Raspberry Piを使えば何か面白いことができるんじゃないかと思い立ち、調べたところ出会ったのがこの記事です。OS自作本のHariboteOSをRaspberry Piに移植したという内容で、参考にした資料から実際に必要だった変更まで詳しくまとめられています。またアーキテクチャの違いをどう吸収したかという技術的な詳細も別記事にまとめられており、とても勉強になりました。
実際にRaspberry Piを入手して各種チュートリアルを試したり最終的な目標として「xv6のRaspberry Pi移植」を目指したものの、結果としては挫折、というか全然形になるところまで行けませんでした。しかしOSがどういう要素で構成されるのか、どのように起動するのか、ハードウェアを制御するのがいかに大変か、といったことを実際に手を動かして学ぶことができたので挑戦した甲斐はありました。苦労してやっとディスプレイに"Hello, world"が表示された際の感動はなかなかのものです。
Unix考古学 Truth of the Legend
最後にこちらの本。2年前に出版された際に一度読みましたが、出てくる用語が全くわからなかったため「これはいずれ読み返そう」と寝かせておいた経緯があります。今回各書籍をバラバラにそして立て続けに読んだことの弊害として、時代順がこんがらがってしまうということがありました。最後にこの本に再挑戦することでリベンジを果たすとともに、OS(UNIX)の歴史・時代背景からWintel時代への流れを掴み、学んだ知識を整理することができました。
システムプログラミングを学ぶことの効能
最後にシステムプログラミングを学んで良かった点をいくつか紹介します。
- 情報収集の守備範囲が広がる
例えばTuringComplete FM。システムがメイントピックのポッドキャストです。もちろん全て理解できるようになった訳ではありませんが、少なくともついていける、最後まで興味を失わずに聞くことができるようになった、という意味で進歩したなと感じます。また、これまで理解できずにタブを開いたもののスクロールだけして閉じてきたニュースにもついていけるようになり、全く新しい分野から情報がとれるようになったのは非常に大きなメリットだと感じています。
- 基礎を身につければ素早く最新の技術へのキャチアップができる
これはいろんな場所で見聞きしたことがあり、今回システムの勉強をするに至った動機の一つでもあります。今のところ「まだわからない」というのが本音です。少なくとも実感はまだはありません。たった3ヵ月の表面を引っ掻いただけの勉強では足りないのかもしれないし、まだ学びたてでちゃんと最新技術をキャッチアップする機会がきてないだけかもしれません。これから検証していこうと思います。
- システムプログラミングは楽しい
もちろん主観的なものですが、システム関連の知識を得ること、実際にコードを書いてハードウェアを動かすことはとてもエキサイティングでした。これまでどういう理屈で動いているのかわからなかった部分がクリアになり、学習する以前にも増して興味が深まったように感じます。コンパイラなどまだ触れていないトピックがたくさんあるのでまだまだ興味が尽きることはなさそうです。
ということで「すヽめ」と言いながら説得できるだけの根拠だったかどうか怪しいですが、はっきり言えるのは「システムの勉強楽しかったよ」ということであり、るくすさんの記事と同様に、誰かの背中を押せれば大変嬉しいです。