this post was submitted on 30 Mar 2024
17 points (100.0% liked)

Linux

47237 readers
3343 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 5 years ago
MODERATORS
 

Curious to know the coolest things you achieved by configuring your kernel. I know kernel config can be boring, but I'm hoping someone will have an impressive answer.

For me I have a very lightweight kernel that runs wayland on nvidia without any issues to date.

top 45 comments
sorted by: hot top controversial new old
[–] [email protected] 18 points 5 months ago (2 children)

As a Linux user of almost 30 years, compiling hundreds of kernels over the years has given me a great appreciation of pre-build kernels, and a profound gratitude for those who package them up into convenient distros that work out of the box and let me get on with the rest of my life.

[–] [email protected] 5 points 5 months ago (1 children)

i think the learning experience is valid

[–] [email protected] 5 points 5 months ago

Absolutely! If you're doing it to learn something, by all means compile your own kernel. Every Linux user should do that at least once in my opinion. But once the learning is done, the novelty wears off fast and it just becomes tedious.

[–] [email protected] 2 points 5 months ago

Well said. I originally compiled my own kernels because I thought it was something you just did to use Linux. I also compiled hundreds of them, probably. Now it's stock kernel all the way. Not worth the effort and time and headache.

[–] [email protected] 12 points 5 months ago

Better lzma performance with xz. 🤪

[–] [email protected] 8 points 5 months ago

Bragging rights.

[–] [email protected] 7 points 5 months ago

A wee bit of knowledge and the wisdom to stop doing it.

[–] [email protected] 5 points 5 months ago

Not for myself but a client who was running a game server. He wanted to tweak the number of ticks/second that the kernel interacted with CPU. Didn't even know that this was a parameter and after a few attempts, according to him, never went on that server myself, made a huge difference and he claimed having grabbed a good part of the market because of that.

After that familiarized myself more with the stuff in there. But that was a good while ago, before most of you guys were born.

[–] [email protected] 5 points 5 months ago (1 children)

Years ago (2006-ish), I ran Gentoo on a 300mhz ultra low power system I used for an irc & web server. I gained LOTS of speed and lowered power draw even further while also enabling the hardware acceleration the board had for ssl encryption and video encoding. The whole thing would pull <5 watts and be super stable. It was well worth it.

But now days a Pi zero would trounce it in both low power draw and speed with stock kernels and I don’t really care enough to try to squeeze more out.

[–] [email protected] 1 points 5 months ago

Customising the kernel just means something works properly in rare hardware configurations like you described. It's something which he who uses the general hardware (like an X86 desktop) can't easily see or understand because the 'stock' kernel is already working properly.

[–] [email protected] 4 points 5 months ago

Just download the devel kernel from your distro and go into make menuconfig. I am on an Intel Laptop with recent hardware. No reason to use amd, nvidia etc drivers. And there is a shitload of likely unmaintained drivers for ancient hardware.

[–] [email protected] 4 points 5 months ago (1 children)

Back when I was still using Gentoo, configuring your own kernel was a rite of passage. It was kind of fun to try and configure it as minimalist as possible to cut down on the kernel compile time. Also, understanding all the different options and possibilities. And thanks to use flags, you had access to all these different patch sets for the kernel, which took a lot of the pain out of trying things like experimental schedulers or filesystems.

[–] [email protected] 1 points 5 months ago (1 children)

Everybody gangsta until they set their block and filesystem drivers to module.

[–] [email protected] 2 points 5 months ago

"Oh, did I need to rebuild the initrd too? Shhheeeeit, can I do that in a chroot from a livedisk or something?"

[–] [email protected] 3 points 5 months ago* (last edited 5 months ago)

I do it because I can... I read release notes on every update and once you've configured a kernel for a particular machine you really don't need to touch the config, barring major changes like when PATA and SATA merged. Or of course if I'm adding a new piece of hardware.

I remove everything I don't need and compiling the kernel only takes a couple minutes. I use Gentoo and approach everything on my system the same way - remove the things I don't need to make it as minimal as possible.

Compiling your own kernel also makes it easier when you need to do a git bisect to determine when a bug was introduced to report it or try to fix it. I've also included kernel patches in my build years ago, but haven't needed to do that in a long time.

I used to compile a custom kernel for my phone to enable modules/drivers that weren't included by default by the maintainer.

It's not about performance for me, it's about control.

[–] [email protected] 2 points 5 months ago
[–] [email protected] 1 points 5 months ago* (last edited 5 months ago) (2 children)

I run linux-xanmod-anbox for root support in Waydroid (Android on Linux).

And I configured my kernel to support VFIO (Virtual Function Input Output).
So I can fully pass through one of my GPUs to my Ameliorated Windows KVM,
which I use for both work and gaming.

[–] [email protected] 0 points 5 months ago (1 children)
[–] [email protected] 2 points 5 months ago (1 children)

Amazing, basically native speeds,
currently playing Horizon Forbidden West with maxed out graphics and DRS disabled at a steady 60-80 FPS.

Previously I also played Horizon Zero Dawn in it, also maxed out graphics, steady locked 100 FPS,
below is a benchmark comparison of HZD in the Linux host OS and the Windows KVM guest OS:
workstation-gaming-linux-vs-windows

[–] [email protected] 1 points 5 months ago

Has this gotten any easier to do? I set it up a few years ago, it was painful to do and maintain so I let it slide. You were writing all sorts of scripts to specify the passthrough devices and then they'd stop working so you had to track down what was failing and update. Then there was iommu so you had to be careful which groups you added devices to.

[–] [email protected] -1 points 5 months ago (1 children)

Root Waydroid lol, thats basically hell.

Waydroid without SELinux already removes all the Android sandboxing. Now its rooted!

[–] [email protected] 1 points 5 months ago (1 children)

Root on Android is a necessity for me.
I've been rooting all droids I use for the past 10 years or so.

Imagine using Linux as a power user,
without being able to use sudo/su.

Also, Magisk does not just allow any application to access root, you have to manually allow apps to make use of it.

Just like administrator rights on any other OS,
things only go wrong if you don't know what you're doing, and then grant rights to something malicious.

[–] [email protected] 2 points 5 months ago

Yes but Waydroid is not an Android phone. Have a look at this

https://github.com/waydroid/waydroid/issues/1136#issuecomment-2016948867

[–] [email protected] 1 points 5 months ago* (last edited 5 months ago)

The secureblue image I use disables numerous kernel modules, and enables many kernel mitigation argument.

The performance impact is minimal, hopefully that means a more secure system? I honestly don't know, nor do I change the default recommended by the developer.

[–] [email protected] 1 points 5 months ago (1 children)

I don't know if this is considered as custom kernel, but I run Guix using non-libre Linux, with Intel Wi-Fi firmware blob. Since it does not have other firmware, it is pretty light, and I'm saving around 200-300MB.

[–] [email protected] 0 points 5 months ago (1 children)

Does that have any appreciable difference in day to day computing?

[–] [email protected] 0 points 5 months ago* (last edited 5 months ago) (1 children)

Compiling kernels makes no sense anymore.

Back in the days - Linux versions 2 and below - the kernel was much less modular, and resources wasn't as plentiful. So it often made sense to build kernels with the stuff you needed statically compiled for speed, and the rest left out fo save memory and shorten boot time. Not to mention, Lilo (the thing we used before Grub) had limitations with respect to kernel size.

Nowadays, Grub can load a kernel of any size from anywhere on the disk. There's plenty enough memory and CPU to leave the kernel core slightly bloated with stuff almost nobody needs with zero practical impact on boot time and memory usage, and most everything else is compiled as modules and loaded as needed - again with next to no boot time or running speed impact.

If you custom-build a kernel today, you'll boot a tiny bit faster and it'll run a tiny bit faster, and you'll have a tiny bit more free memory - all of which you will never notice. What you will notice however is that kernel updates are a PITA on a regular basis.

[–] [email protected] 1 points 5 months ago

Kernel updates are extremely easy when custom compiling, not sure what you are doing to make them a pain. Custom compiling is a great way to sort of passively absorb knowledge about kernel changes and new features or features you didn't know about as they change and make oldconfig brings up questions about them.

[–] [email protected] 1 points 5 months ago (1 children)

I'm running a custom kernel on my Arch laptop. It's a little faster, a little smaller and a little quite more secure. I'm also running custom kernel which enables adiantum encryption on old phone with postmarketOS.

[–] [email protected] 0 points 5 months ago (1 children)

How did you conduct this speed test? Where are the results? 😂

Sorry, I think this any time someone says their computer is faster or mod X on Android is "snappier"

[–] [email protected] 1 points 5 months ago

I used geekbench 5. My CPU is AMD Ryzen 5 5500U. I tested a few prebuild kernels and custom compiled the fastest one.

prebuild linux kernel:

  • singlethread: 1170
  • multithread score: 4604

prebuild linux-zen kernel:

  • singlethread: 1156
  • multithread score: 4593

prebuild linux-xanmod kernel:

  • singlethread: 1164
  • multithread score: 4594

prebuild linux-hardened kernel:

  • singlethread: 1156
  • multithread score: 4841

custom linux-hardened kernel:

  • singlethread: 1160
  • multithread score: 4977
[–] [email protected] 1 points 5 months ago

Well, I can still boot my system without an initram (although that isn't just due to the kernel config)—does that count?

Other than that, custom kernels free up a small amount of disk space that would otherwise be taken up by modules for driving things like CANbus, and taught me a whole lot about the existence of hardware and protocols that I will never use.

[–] [email protected] 1 points 5 months ago

I have configured custom Android kernel builds to enable more USB drivers, enable module support, and tweak various other things. For one tangible example of the result: I could plug in a USB Wi-Fi adapter and use it to simultaneously connect to another Wi-Fi network with the internal NIC while also sharing my own AP over USB. On an Android device of all things. I have also adjusted kernel builds for SBCs (like Pi clones) to get things working at all.

I have never seen any reason to configure a custom kernel for my own desktop/laptop systems. Default builds for the distros I've used have been fine for me; if I'm ever dissatisfied with anything it's the version number rather than the defconfig. The RHEL/Rocky kernel omits a few features I want (like btrfs) but I'd rather stick to other distros on personal systems than tweak a distro that isn't even meant for tweaking.

[–] [email protected] 1 points 5 months ago

Better access to tools like ebpf and xdp.

[–] [email protected] 1 points 5 months ago (1 children)

A kernel that fits my hardware and supports things the original kernel doesn't. Then again, i use gentoo.

[–] [email protected] 1 points 5 months ago (1 children)

What did the original kernel not support?

[–] [email protected] 1 points 5 months ago

Having / on ZFS, but that went into an initrd i think... don't remember, but not hardware related.

[–] [email protected] 1 points 5 months ago

A gentoo install once upon a time... and learning how to configure a kernel. Also a slightly better understanding of kernel module configuration for custom or odd ball hardware and a vague idea of what to look for in hardware support if I want to dig deeper.

[–] [email protected] 1 points 5 months ago

I'm playing around with coreboot and that gives me ability to embed Linux kernel. The problem is we're limited by the amount of ROM chip which is between 4MiB to 16MiB depending on the specific device. The one I'm working on got 12MiB, about 3 is taken in order to boot normally, leaving me with 9 to play around.

Enter buildroot, (arguably) a Linux distro that allows you to have kernel, busybox, minimum libc, along with whatever software you'd choose.

While it's easy to include only what's needed to have a working system (busybox provides working shell as well as the coreutils), you'd need to get rid of stuff you don't need, such as drivers for hardware you wouldn't have.

Aside from that, you'd end up with better running kernel in general if you know what you're doing. I run Gentoo and have kept a working config that I tweak from time to time (especially on version upgrade).

[–] [email protected] 1 points 5 months ago

The first time I configured the kernel was in Gentoo. The gain from the configuration it self may not have been much, but making my own initramfs image to bundle and load with the kernel taught me a bunch of how linux works in early boot.

[–] [email protected] 1 points 5 months ago

Mostly just understanding what was there, what was necessary for my machine at the time and what was optional.

[–] [email protected] 0 points 5 months ago (1 children)

Knowledge and time forced to not be on the computer

[–] [email protected] 0 points 5 months ago (1 children)

Wow, I never thought of that as a good thing until now. I bet Gentoo users are more well-rounded than Arch users

[–] [email protected] 2 points 5 months ago (1 children)

Well, lots of time to practice sword fighting in office chairs

[–] [email protected] 1 points 5 months ago

Or to scroll through XKCD, apparently :P