You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

63 lines
2.8 KiB

10 years ago
os-tutorial
===========
10 years ago
How to create an OS from scratch!
10 years ago
10 years ago
**New lessons will be added about every week, at the same pace that I learn each concept**
10 years ago
I have always wanted to learn how to make an OS from scratch. In college I was taught
10 years ago
how to implement advanced features (pagination, semaphores, memory management, etc)
but:
- I never got to start from my own boot sector
- College is hard so I don't remember most of it.
10 years ago
- I'm fed up with people who think that reading an already existing kernel, even if small, is
a good idea to learn operating systems.
10 years ago
Inspired by [this document](http://www.cs.bham.ac.uk/~exr/lectures/opsys/10_11/lectures/os-dev.pdf)
and the [OSDev wiki](http://wiki.osdev.org/), I'll try to make short step-by-step READMEs and
10 years ago
code samples for anybody to follow. Honestly, this tutorial is basically the first document but
split into smaller pieces and without the theory.
10 years ago
10 years ago
10 years ago
Features
--------
10 years ago
- This course is a code tutorial aimed at people who are comfortable with low level computing. For example,
programmers who have curiosity on how an OS works but don't have the time or willpower to start reading the Linux kernel
top to bottom.
- There is little theory. Yes, this is a feature. Google is your theory lecturer. Once you pass college,
10 years ago
excessive theory is worse than no theory because it makes things seem more difficult than they really are.
10 years ago
- The lessons are tiny and may take 5-15 minutes to complete. Trust me and trust yourself. You can do it!
10 years ago
How to use this tutorial
------------------------
10 years ago
1. Start with the first folder and go down in order. They build on previous code, so if
10 years ago
you jump right to folder 05 and don't know why there is a `mov ah, 0x0e`, it's because you missed lecture 02.
Really, just go in order. You can always skip stuff you already know.
10 years ago
10 years ago
2. Open the README and read the first line, which details the concepts you should be familiar with
before reading the code. Google concepts you are not familiar with. The second line states the goals for each lesson.
Read them, because they explain why we do what we do. The "why" is as important as the "how".
3. Read the rest of the README. It is **very concise**.
10 years ago
4. (Optional) Try to write the code files by yourself after reading the README.
10 years ago
10 years ago
5. Look at the code examples. They are extremely well commented.
10 years ago
10 years ago
6. (Optional) Experiment with them and try to break things. The only way to make sure you understood something is
trying to break it or replicate it with different commands.
10 years ago
10 years ago
TL;DR: First read the README on each folder, then the code files. If you're brave, try to code them yourself.
10 years ago
Contributing
------------
I'm still learning this. For the moment, please restrict your contributions to fixing possible bugs
or improving existing documents. I'm not yet ready to accept enhancements.