- cross-posted to:
- [email protected]
- [email protected]
- [email protected]
- [email protected]
- cross-posted to:
- [email protected]
- [email protected]
- [email protected]
- [email protected]
Yeah it’s just as simple as the calculator program I copy pasted in highschool computer class.
Well, the kernel is not “just a program” in that it is not like the other programs on your system. If it was, you would “just” run it in your shell. The kernel cannot run this way of course because it is not a user mode program.
That said, if course the kernel is a program in the sense that it is a set of machine instructions that make the hardware do what you want.
And the kernel is designed to talk to hardware and other programs—to be the bridge between the two. It is not something an end-user interacts with directly.
Well, the kernel is not “just a program” in that it is not like the other programs on your system. If it was, you would “just” run it in your shell. The kernel cannot run this way of course because it is not a user mode program.
Point taken but….
UML requires:
1 - extensive support from the host kernel above and beyond what is required to execute for regular programs
2 - the guest kernel to be specially compiled to be a UML guest
In other words, even though UML allows a guest Linux kernel to execute as a process on a host Linux kernel, that Linux kernel is not “just a program” like every other user mode application is.
It’s a program certainly, but “just a program” is a bit misleading because it places it on the same footing as Doom or
cator an Arduino project. Linux is a ring 0 program, which processors give unique treatment.Reminds me of not long after I started using Linux. I thought the kernel was “just a program” like
catand tried to run the kernel from the terminal, only to be disappointed when a new kernel in fact did not start running inside the terminal window.

Zaphod’s just zis guy, you know?
Thanks op this is a great article. Having compiled kernels since 2.4 or thenabouts, it’s a great topic and I never really thought of it as just another program. Neat stuff!
On my arch install, all I have is vmlinuz-linux under /boot. How come there’s no further information appended like in the article?
an arch user doesn’t know that!!
so, that further information is the kernel’s version number. it helps to keep some older versions. but you didn’t set it up to include the version in the filename.
és egyébként bojler eladó. processzorra cserélném.
Different distros vary a bit here, and it will differ if you’re on a system using efi.
Sometimes /boot isn’t mounted by default (it’s not needed unless you’re updating a kernel). You may be seeing a symlink or placeholder there.
If you’re using efi there will probably be /boot/EFI or something where your kernel is stored.
The reason there’s no version in the filename is simply that Arch just doesn’t keep old kernels around.
The
vmlinuz-linuxjust gets replaced whenever you update thelinuxpackage and the old one is deleted immediately.That’s… Insanity. Keeping at least one old kernel is amazingly useful if you run into issues with an update.
I agree that it’s be useful, and I think you can just install e.g. the LTS kernel next to the regular one.
But even without , the arch way isn’t insane either: when something kernel-related breaks, boot with a live system on USB and fix it.
Case in point: I dimensioned the EFI partition too small, so at some point, me using the zen kernel (which comes with a backup kernel image) messed things up and I couldn’t boot a half-written kernel.
then I
- created and booted a live USB stick,
- Mounted my
/and/bootpartitions manually into/mnt/root/and/mnt/root/boot - Bind-mounted the live system’s
/devand/procinto/mnt/root/{dev,proc} - chrooted into
/mnt/root(resulting in an environment using/devand/procfrom the live system and the rest from my system), - Used regular package manager commands to uninstall the zen kernel and install the regular one, and finally
- rebooted into the now working system.
It’s not crazy, it doesn’t take long, you just need to know how the system works. Upside is that nothing ever breaks permanently, everything is fixable (except hardware failure)
Pretty good article, I read both. Well explained without too much tech jargon.
I liked both this and the following article.
Pretty cool seeing everything it takes to have a minimalist Linux to boot, and I finally saw how to get started with strace that I’ve been postponing for like half a year.





