「30天自制操作系统」 Stop & 「OS67 」 Start

  

废话

  整个十月都没有再写一点什么, 其实没什么好写的, 把书里的东西码出来贴在博客里实在没什么意思, 况且书里已经写得够详细了.

  这本书给我最深刻的感觉是, 作者通过简化一些细节, 一步一步地模拟整个开发过程, 把做一个操作系统中最有趣的部分展示了出来. 最大的简化大概使用了他那一整套工具, 把编译出裸机可用C语言程序这一个麻烦给忽略了.

  经过一个多月的练习, 已经完成了700页中的300多页, 最后大概是停留day 12这里, 我开始有点厌倦. 从一开始完成一点功能就很兴奋, 到最后发现自己只是不停地抄实例代码, 所以我决定停下来, 这一停就是一个多月.

     

  我当然为自己这样做要找一个借口, 这本书固然是好书, 但以我的毅力和空余时间来看, 不适合从头到尾跟着做.

  虽然之前做了错误的决定, 这并不意味这我没有任何收获, 书里面有很多有趣的思路, 比如用循环队列+死循环来处理中断(类似Windows里面的消息泵), 如何绘制出鼠标, 用缓冲区来避免画面闪烁, 作者提供的方法不见得是最高效的做法, 但却让我知道这些东西可以这样实现, 这在动手做之前我是没有想过的, 作为一本讲操作系统的最简单的书籍, 它简化了硬件细节, 总还是能对整个计算机组成有个大概的把握.

  当然不止这些, 在这个过程中我还收集了很多零碎的知识, 就像点亮技能树一样, 在做这个项目的过程, 你感觉这样不方便, 于是去网上寻求一种更好的操作途径.

  • (最大的收获)我需要在Shell, Makefile, 汇编, C语言直接切换着编辑, 之前一直在用的Code::Blocks显然没有这个功能, 记事本又不能忍, 所以我就去学了vim, 从此再也离不开:w , 又顺手用了火狐的pentadactyl.
  • Makefile让我知道如果不借助IDE的话, 一个项目是怎么被编译的.
  • 我的代码放在一个目录, 书里的示例代码在另一个目录, 为了跳转方便又用了它Total Commander, 虽然只用了最简单的功能.
  • 每次打完代码把整个目录<c-c>再<c-v>一点都不Geek, 所以就开始用Github, 不得不说GitHub 的Windows客户端操作简便又直观, 后来环境换到了Linux每次add + commit + push总觉得好麻烦.

  其实上面这些只是花几天或者几个小时就能学会的小技能, 但如果不是做这个的话, 我想短期内我是不会有动力去学习的.

事实上我还得承认是我没有坚持做完它, 弃坑是一件挺丢人的事情, 但这并不是终点, 而是另一个开始.


  https://github.com/LastAvenger/OS67

  我想重新做一个OS, 和上次的区别是, 这次我用了现在流行的编译工具链, 在Linux下的make + gcc + nasm + ld, 结合网上的各种教程, (其实网上很多的, 尤其是国外, 只是一开始孤陋寡闻没有听说过, 当然现在也好不到那里去).

   不知道话会不会说太早? 前面有多少困难呢?

一些要注意的

      对一些不了解的人来说, 编写操作系统听起来很高大上,  网上充斥的各种操作系统教程也只是一个简单的bootsector, 无非是两个关键字: 0x7c00 和 0xAA55,  只能当做汇编的练习而已, 再进哪怕一步的, 如果有, 也都是按书上的做的(于渊的Orange's, 30 天, Liunx 0.11), 再发到博客上, 基本不能讲清楚问题(这里突然觉得我之前发的那些博客蠢到家了).  要想更好地了解, 直接看于渊的Orange's, 30 天, Liunx 0.11就好了.

     网上的资料当然不止这几本书, http://wiki.osdev.org/Main_Pagehttp://www.osdever.net/tutorials/是OS的Wiki网站, 

另外有一个教程叫 Bran's Kernel Development Tutorial写得简明易懂, 大概我会在里面抄很多代码, 而且国内竟然有完整的翻译版, 感谢译者huigezi.

「x86汇编语言 从实模式到保护模式」 这本书也是值得借鉴的.

以上的书我没有完全看完, 但里面确实涵盖了全部的知识, 问题在于看得懂看不懂而已.

     有了教程, 就可以着手制作了, 你需要了解一点汇编语言和C语言. 一开始比较重要的是保护模式和C语言的编译链接.

比如分段有什么用, GDT IDT里面放的是什么, CPL, DPL, RPL 的不同作用, 特权级的转移,  个人认为这是一个接受与否而非理解与否的问题, 有时候真不明白为什么CPU里面要加入这些奇奇怪怪的规则, 但实际上除去历史原因, intel的设计者们肯定是比我等厉害得多, 先接受它这种奇怪的机制, 慢慢的就会理解保护模式了. (当然细枝末节我还是记不住的.

     如何用C语言写内核? 一开始这真的无法想象的, 而且我百度了好久都无果, 我看到的几乎所有中文教程都忽略了这一步, 而偏偏Orange's的内核是先用汇编解析ELF,再用C编译出ELF格式的内核的, 而我需要的是一个纯二进制的内核, 当然最终我求助于知乎的某个前辈, 从他提供的Bran's 的教程里面找到了答案, 在此表示感谢.

  要生成一个二进制的内核, 你需要在汇编写的loader里面指定C语言里面的入口函数, 并在合适的时候跳转到他, 比较重要的地方是C编译器的编译选项,(之前我不知道有那么多的选项, 做题的时候一律gcc -o), 你要对程序编译的流程有一点点的了解, 你才能理解这个过程, -> 指定参数让gcc不引用任何标准库, 使用自己的头文件, 而且只生成目标文件(你还可以生成一份gas的汇编文件用以对照), 然后在链接的时候合并好loader与kernel的各个段, 具体的做法参见: https://github.com/LastAvenger/OS67/blob/master/makefile https://github.com/LastAvenger/OS67/blob/master/kern/link.ld

说实话我也不能完全理解, 但至少程序跑起来了.

贴一张图吧?

 

 

posted @ 2014-11-22 20:36  谷月轩  阅读(12806)  评论(10编辑  收藏  举报