updated readme

This commit is contained in:
Carlos Fenollosa 2014-10-05 18:22:18 +02:00
parent cdddc184b2
commit f67abb437d

View File

@ -1,9 +1,9 @@
os-tutorial os-tutorial
=========== ===========
How to create an OS from scratch How to create an OS from scratch!
I have always wanted to learn how to make an OS from scratch. In college they taught us I have always wanted to learn how to make an OS from scratch. In college I was taught
how to implement advanced features (pagination, semaphores, memory management, etc) how to implement advanced features (pagination, semaphores, memory management, etc)
but: but:
@ -14,40 +14,34 @@ Inspired by [this document](http://www.cs.bham.ac.uk/~exr/lectures/opsys/10_11/l
and the [OSDev wiki](http://wiki.osdev.org/), I'll try to make short step-by-step READMEs and and the [OSDev wiki](http://wiki.osdev.org/), I'll try to make short step-by-step READMEs and
code samples for anybody to follow. code samples for anybody to follow.
**The tutorial will be updated about every week, at the same pace that I learn the concepts**
I will not explain the theory. Google is your friend. Features
Theory is already covered by thousands of PDFs from Universities --------
and the Wikipedia. The material assumes that you are comfortable
with low level computing.
This course is a code tutorial, not a real CS lecture. - This course is a code tutorial aimed at people who are comfortable with low level computing.
To make up for the lack of theory, the "lessons" are tiny - There is little theory. Yes, this is a feature. Google is your theory lecturer.
and may take 5-15 minutes to complete. Each new concept - The lessons are tiny and may take 5-15 minutes to complete. This is the only way to learn. Grabbing a whole
is presented on a new lecture. OS, even if small like Minix or TempleOS, is too overwhelming.
- New lessons will be added about every week, at the same pace that I learn the concept
How to use this tutorial How to use this tutorial
------------------------ ------------------------
First, go through every folder in order. They build on previous code, so if 1. Start with the first folder and go down in order. They build on previous code, so if
you jump right to folder 08, you may find a lot of stuff which is not related you jump right to folder 08, you may find a lot of stuff which is not related
to what folder 08 is about. to what folder 08 is about.
To see the increments between "lessons", do a diff between folders. 2. Read each README first. Especially the first line, which details the concepts you should be familiar with
Each lesson README starts with the concepts you should be familiar with
before reading the code. before reading the code.
Second, for each folder, read the README. It is **very concise**. The only theory 3. Read the README. It is **very concise**. The only theory is the required to understand the code and there
is the required to understand the code. are tips on what to look at when you open the code file(s)
Then, look at the code examples. You can try to write them by
yourself on a different folder, modify them slightly and play a bit with the 4. Look at the code examples. Some times you may be able to write them yourself just from the hints on the README.
code, you know, the usual.
5. Experiment with them and try to break things. Try to change pointers and registers and see what happens. You know, the usual.
Finally, the code files provided in each folder are the final result. If
you want to learn quickly (though not as thoroughly), just read the
provided code files.
TL;DR: First read the README on each folder, then decide if you will TL;DR: First read the README on each folder, then decide if you will
implement it yourself or just read the provided code files. implement it yourself or just read the provided code files.