223

I’ve been working on a "Linux Inside Out" series and wrote a post that might interest folks here who like low(ish)-level / OS internals.

The idea is to dissect the components of a Linux OS, layer by layer, and build a mental model of how everything fits together through experiments.

The first part is about the kernel, in the post I:

  • take the same kernel image my distro boots from /boot
  • boot it directly with QEMU (no distro, no init system)
  • watch it panic
  • write a tiny Go program and use it as PID 1
  • build a minimal initramfs around it so the kernel can actually start our process

The goal isn’t to build a real distro, just to give a concrete mental model of:

  • that the Linux kernel is just a compressed file, you can boot it
  • without anything else
  • what the kernel actually does at boot
  • how it hands control to userspace
  • what PID 1 / init is in practice
  • what is kernel space vs user space

Link: https://serversfor.dev/linux-inside-out/the-linux-kernel-is-just-a-program/

I’m the author, would be happy to hear from other devs whether this way of explaining things makes sense, and what you’d add or change for future posts in the series.

Hope you find it useful.

top 15 comments
sorted by: hot top controversial new old
[-] DickFiasco@sh.itjust.works 30 points 2 days ago* (last edited 2 days ago)

Thank you, this is a great explanation. I look forward to the rest of this series.

Edit: I successfully booted a Debian kernel using this tutorial, though I wrote the init program in C++ instead of Go. The process is pretty much the same, but you have to add the -static flag to g++ since the C runtime is not included in the initramfs. This might be obvious to more seasoned programmers but it took me a minute to figure it out.

[-] zknd@lemmy.world 12 points 2 days ago

Thank you for the feedback.

[-] ambitiousslab@lemmy.ml 14 points 2 days ago* (last edited 2 days ago)

It's a very good explanation. I like that it is short and hands on. For me, it is pitched at the right level and the practical style keeps it very grounded.

what you’d add or change for future posts in the series

I wouldn't change anything to do with the content! Speaking personally, I'm a fan of full text RSS feeds, so I'd love one on this blog if that's an option :)

[-] AWizard_ATrueStar@lemmy.world 5 points 2 days ago

I think there is one. All the way at the bottom of the page I see a link for RSS and I was able to add it to my RSS reader. It looks like everything is there unless I am missing something.

[-] ambitiousslab@lemmy.ml 2 points 2 days ago

I'm not sure if your RSS reader is getting the content through some special way. The feed itself only has the first two paragraphs:

<item>
  <title>The Linux kernel is just a program</title>
  <link>https://serversfor.dev/linux-inside-out/the-linux-kernel-is-just-a-program/</link>
  <guid isPermaLink="true">https://serversfor.dev/linux-inside-out/the-linux-kernel-is-just-a-program/</guid>
  <description>Most books and courses introduce Linux through shell commands, leaving the kernel as a mysterious black box doing magic behind the scenes. In this post, we will run some experiments to demystify it: the Linux kernel is just a binary that you can build and run.</description>
  <pubDate>Mon, 01 Dec 2025 00:00:00 GMT</pubDate>
</item>
[-] zknd@lemmy.world 2 points 22 hours ago

Turned out it is not so simple to add the full content of the post to the RSS feed with Astro's RSS plugin, but trying to find some workaround.

[-] ambitiousslab@lemmy.ml 1 points 8 hours ago

Ok, no pressure anyway! Thanks for looking into it :)

[-] zknd@lemmy.world 3 points 2 days ago

Thank you for the feedback.

Sure, I will look into the RSS plugin config. :)

[-] calliope@retrolemmy.com 9 points 2 days ago

This is very cool, thanks for sharing!

I did a similar exercise a decade ago with HTTP and it was fun and eye-opening.

[-] gsx@discuss.tchncs.de 8 points 2 days ago

Nice article. Waiting for the upcoming parts.

Blinry did something similar not to lomg ago, maybe it's interesting for you, too: https://blinry.org/tiny-linux/

[-] lascapi@jlai.lu 4 points 2 days ago

That looks simple when someone (you) say it simply.

Thank you for that. 😌

[-] sfxrlz@lemmy.dbzer0.com 4 points 2 days ago

This looks really interesting. I’ll have a look when I get home.

[-] harsh3466@lemmy.ml 3 points 2 days ago

This sounds awesome. I'm going to read this tomorrow when I can give it my full attention.

[-] LainTrain@lemmy.dbzer0.com 1 points 2 days ago

That's so cool! Thanks for sharing it!

[-] thatradomguy@lemmy.world -2 points 2 days ago

AI is just a program.

this post was submitted on 05 Dec 2025
223 points (98.7% liked)

Programming

23769 readers
149 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



founded 2 years ago
MODERATORS