173
submitted 5 days ago by Ladislawgrowlo@lemy.lol to c/linux@lemmy.ml
top 23 comments
sorted by: hot top controversial new old
[-] davel@lemmy.ml 67 points 5 days ago

It’s a program certainly, but “just a program” is a bit misleading because it places it on the same footing as Doom or cat or an Arduino project. Linux is a ring 0 program, which processors give unique treatment.

[-] arthropod_shift@programming.dev 6 points 3 days ago

Reminds me of not long after I started using Linux. I thought the kernel was "just a program" like cat and 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.

[-] db2@lemmy.world 32 points 5 days ago
[-] LeFantome@programming.dev 12 points 4 days ago* (last edited 4 days ago)

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.

[-] GlowHuddy@lemmy.world 4 points 4 days ago

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.

Actually...

[-] LeFantome@programming.dev 3 points 3 days ago* (last edited 3 days ago)

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.

[-] data1701d@startrek.website 26 points 5 days ago

Zaphod’s just zis guy, you know?

[-] AnnaFrankfurter@lemmy.ml 3 points 3 days ago

Yeah it's just as simple as the calculator program I copy pasted in highschool computer class.

[-] lemmyseizethemeans@lemmygrad.ml 7 points 5 days ago

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!

[-] dubyakay@lemmy.ca 5 points 5 days ago

On my arch install, all I have is vmlinuz-linux under /boot. How come there's no further information appended like in the article?

[-] ReversalHatchery@beehaw.org 2 points 3 days ago* (last edited 3 days ago)

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.

[-] dubyakay@lemmy.ca 1 points 3 days ago

I've used Arch-Installer on my desktop after two failed manual attempts on a laptop. And then dove in head first for the rest.

Én memóriára cseréltem!

[-] atzanteol@sh.itjust.works 9 points 5 days ago

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.

[-] flying_sheep@lemmy.ml 3 points 3 days ago* (last edited 3 days ago)

The reason there’s no version in the filename is simply that Arch just doesn't keep old kernels around.

The vmlinuz-linux just gets replaced whenever you update the linux package and the old one is deleted immediately.

[-] atzanteol@sh.itjust.works 1 points 3 days ago

That's... Insanity. Keeping at least one old kernel is amazingly useful if you run into issues with an update.

[-] flying_sheep@lemmy.ml 1 points 3 days ago* (last edited 3 days ago)

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

  1. created and booted a live USB stick,
  2. Mounted my / and /boot partitions manually into /mnt/root/ and /mnt/root/boot
  3. Bind-mounted the live system's /dev and /proc into /mnt/root/{dev,proc}
  4. chrooted into /mnt/root (resulting in an environment using /dev and /proc from the live system and the rest from my system),
  5. Used regular package manager commands to uninstall the zen kernel and install the regular one, and finally
  6. 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)

[-] atzanteol@sh.itjust.works 1 points 3 days ago* (last edited 3 days ago)

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.

That is not a replacement for "arrow-key down during boot to select an older kernel".

I have a server with a RAID card and the kernel at some point introduced a bug with the driver that prevented that server from booting. So I select the older kernel at boot, get the system up and running, mark that kernel as the default until the bug is fixed.

It’s not crazy, it doesn’t take long, you just need to know how the system works.

I know how the system works very well thankyouverymuch. But that's an insane option when having multiple older kernels is so easy to do and common.

[-] flying_sheep@lemmy.ml 1 points 2 days ago

As said: installing the LTS kernel also works, I think.

And you wouldn't use Arch for servers, you want something stable (as in “rarely changing”) there.

[-] atzanteol@sh.itjust.works 1 points 2 days ago

I wouldn't use arch for anything.

[-] flying_sheep@lemmy.ml 1 points 2 days ago

I really like rolling release. So much better to deal with updates one-by-one than in a giant batch every half year or so.

[-] CodenameDarlen@lemmy.world 3 points 5 days ago

Pretty good article, I read both. Well explained without too much tech jargon.

[-] trolololol@lemmy.world 1 points 4 days ago

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.

this post was submitted on 26 Dec 2025
173 points (97.8% liked)

Linux

57274 readers
200 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 6 years ago
MODERATORS