Learn to Code via Tutorials on Repl.it!

← Back to all posts
A beginners guide to OS Dev: Part 1
CSharpIsGud

It will help greatly to go into this guide with some understanding of C and Assembly.

Before you start you will need to install nasm, genisoimage and may want to install qemu or bochs in order to test your OS without rebooting your computer, bochs is preferred as it has more debugging capability than qemu

By the end of this part you should have a very basic OS that can boot.
This part of the guide will not cover anything but making a basic OS that does absolutely nothing due to how long it already is.
If people like this I will make a part 2 going over how to use C with the OS and write text to the screen.

Booting

The first thing to do is create the main assembly file, I will call it Boot.asm

This should boot and do nothing.

But how do we compile it?

First we need a linker script since grub(the bootloader this tutorial will be using) is loaded below 1 MB so we should load above that!

Now I don't expect you to know how to do this, and neither do I, so I will copy this from littleosbook which is another good tutorial on writing an operating system from scratch.

nasm -f elf32 Boot.asm should create a file called Boot.o

Which we can then turn into an elf binary by linking it with ld

ld -T link.ld -melf_i386 Boot.o -o kernel

We then must download grub, which can also be found in littleosbook, http://littleosbook.github.com/files/stage2_eltorito

Now we create the folder structure our os iso will be built from

And our grub configuration to put in /boot/grub/menu.lst

Now to run it!

A bash script to automatically compile/link and run the OS

To use bochs you must make a configuration file named bochsrc

Voters
DaRubyMiner360
temporarilyMe
z80
programmeruser
elipie
Kookiez
FedericaC
ChristopherHosk
EpicGamer007
LoganSpong
Comments
hotnewtop
Highwayman

hum. Time to try to learn asm again ;-;

programmeruser

Question: if you write a VGA driver will it work for something like HDMI?

MocaCDeveloper

I mean there is allot more than just this.

This is the very literal bare bare bones of an OS..there is much more things that need to be implemented before you have an actual functional OS

CSharpIsGud

@MocaCDeveloper it just isn't one that competes with any graphical OS. Or any OS in general.

[deleted]

well im on a mac so this really sucks for me
:(

AmazingMech2418

I'm trying to use QEMU and I got this:

Any idea how to fix it?

CSharpIsGud

@AmazingMech2418

try this

AmazingMech2418

@CSharpIsGud That works! Thank you!

LoganSpong

Should I make a bash repl to do this?

LoganSpong

Is it possible to plugin python in assembly or C for like, running python scripts?

DungeonMaster00

@LoganSpong you probably need a python intepreter first then you could add some python stuff

or you could make a compiler instead of an interpreter and compile python to machine code

LoganSpong

@DungeonMaster00 the 2nd option legit scared me. Compiling Python to machine code? No way man.

CSharpIsGud

@LoganSpong https://repl.it/@CSharpIsGud/CPython2
At first I was writing the parser by hand, then I realized why waste my time doing that when I can just use py's ast module.
I didn't even finish it because what's the point?
There are other more complete ones(Though most of them are abandoned or not meant to be a fully featured compiler) like https://nuitka.net/
Though mine was going to be completely bare and therefor safe for OS dev

AmazingMech2418

On genisoimage, using this exactly as you did it, I get

akkina
<h1> <strong>AWESOME!</strong> </h1>
akkina
<h1> <strong>AWESOME!</strong> </h1>
staticvoidliam7

how do i install nasm and the others with $npm install

CSharpIsGud

@LiamDonohue npm is the package manager for nodejs, this isn't a javascript project

staticvoidliam7
CodeLongAndPros

When is the C coming out?

CSharpIsGud

@CodeLongAndPros in the second part

lynnlo

@CSharpIsGud
What about B#?

CodeLongAndPros
AmazingMech2418

Since you are using an ELF executable, what platform does this work for? ARM? x86? x64? AMD?

CSharpIsGud

@AmazingMech2418 no idea, I only have intel computers

AmazingMech2418

@CSharpIsGud I think x86 then.

AmazingMech2418

@CSharpIsGud Also, I don't see any C in this tutorial. Will that be in the second part?

CSharpIsGud
xxpertHacker

@CSharpIsGud By "C," you're referring to C++, right... right!?

AmazingMech2418
CSharpIsGud

@StudentFires You could probably do it in C++ too but that will only add more ways for things to go wrong, using C++ in os dev is really only useful if you are addicted to classes

xxpertHacker

@CSharpIsGud Isn't Java meant for those who are addicted to classes?

AmazingMech2418

@StudentFires Pretty much, but it still can be useful for some things like Android development (Kotlin is used there too).

CSharpIsGud

@StudentFires or C#, im not addicted to classes but I like having vaguely C like syntax without having to worry about memory

Warhawk947

no idea what this is but it's cool nevertheless

CSharpIsGud

@Warhawk947 Think of "WarhawkOS" but its an OS and not a console program

Warhawk947
sugarfi

You don't need to use GRUB though - it's more fun to write your own bootloader.

CSharpIsGud

@sugarfi It just makes it more painful if you make a mistake

sugarfi

@CSharpIsGud what do you mean?

CSharpIsGud

@sugarfi Do you have any IDEA how long this small mistake took me to fix

imagine not being able to tell if your os is crashing or if the bootloader messed something up

sugarfi

@CSharpIsGud fair. that's the painful part - having to write asm code so that c can call it. if you leave out the pop ebp or something then you will most likely get a segfault

CSharpIsGud

@sugarfi a segfault, I wish. I wish I had segfaults, they would of saved much time (I do have segmentation enabled but I have the segments set to span the entire address space as I have paging working)

sugarfi

@CSharpIsGud you still get them, just not the message. qemu will freeze up and reboot. i think it's actually called a triple fault or something, but i just call it a segfault.

CSharpIsGud

@sugarfi Yeah, you get them if you turn on segmentation and actually use it, you get a triple fault if the interrupt handler for them isn't there or causes another fault. however if you don't use segmentation its not even gauranteed that it was caused by something memory related

CSharpIsGud

@sugarfi also your running out of time to make your os, as soon as I get into user mode im going straight to writing syscalls and vesa drivers

sugarfi

@CSharpIsGud i already got syscalls
i'm working on loading an elf file

CSharpIsGud

@sugarfi im not doing syscalls yet because user mode will add some extra effort to the interrupts which I will deal with once I get there instead of changing it later

sugarfi

@CSharpIsGud fair. do you have an fs yet?

CSharpIsGud

@sugarfi not yet, im saving a file system for when I have disk io

sugarfi

@CSharpIsGud i just read the whole disk in my bootloader, and i'm going to use v86 mode to write it

CSharpIsGud

@sugarfi im going to use the ata apis instead of switching out of protected mode every time

sugarfi

@CSharpIsGud the problem with that is, not all disks support those. and i would only enter v86 mode when the os was shutting down, so it wouldn't matter.

CSharpIsGud

@sugarfi yeah but most should, and if I want to be able to read and write files at will its a necessity

sugarfi

@CSharpIsGud not really. if you load the files into memory, you can just write them there, and not "save" your changes to the disk until the computer powers off.

CSharpIsGud

@sugarfi it wastes memory that could otherwise be used for programs and if the os crashes or someone hard resets the pc all the changes are lost

sugarfi

@CSharpIsGud think about it. this is a small disk; all the files are stored as a tarball. there are 2 - 4gb of memory available, possibly more. and also, who's ever going to use a hobby os?

sugarfi

@CSharpIsGud i mean, i was going to try the ata apis too, but i couldn't find a good tutorial

CSharpIsGud

@sugarfi Why make it low quality when you can make it high quality, also. I bet thats what they said about linux when it was just a hobby kernel

sugarfi

@CSharpIsGud both good points. but like i said, lack of docs is a problem; the osdev wiki can be really bad for things beyond a bare-bones kernel, and most google searches yield at best two stackoverflow pages.

CSharpIsGud

@sugarfi I usally found about 10 but they were never about my specific problem and were usually caused by someone making an obvious mistake I would of caught instantly

sugarfi

@CSharpIsGud i have the same problem.

Warhawk947

@sugarfi big brain moment