Zack's Kernel News
Zack's Kernel News

Chronicler Zack Brown reports on the latest news, views, dilemmas, and developments within the Linux kernel community.
Protecting Future Feet
When compiling software of a certain size, you typically compile a bunch of smaller files and then link the results together into the final executable file. This is a simple and easy process that definitely contains no psychotic nightmare lunacy whatsoever – except for most of it.
One aspect of linking involves assigning memory addresses to all the functions and variables and whatnot that are perhaps defined in one file but need to be referenced by code in another file. It gets even more fun when you want to do this while simultaneously hiding these addresses from potentially hostile code that might be running on the same system, looking for security holes. But that's another story.
A while back, Linus Torvalds stubbed his toe on the linker when he was struggling to identify the start and end of particular sections of code to be linked so that he could store certain data in some sections and other data in other sections. After Linus kicked that brick wall for a while, Rasmus Villemoes explained to him that there was a simple and automatic way to do what he wanted: "If an output section's name is the same as the input section's name and is representable as a C identifier, then the linker will automatically [provide] two symbols: __start_SECNAME and __stop_SECNAME, where SECNAME is the name of the section. These indicate the start address and end address of the output section respectively. Note: most section names are not representable as C identifiers because they contain a '.' character." Linus had a big laugh at himself over that one, because all his struggles could be solved with a single character. But that's yet another story.
[...]
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.

News
-
TuxCare Announces Support for AlmaLinux 9.2
Thanks to TuxCare, AlmaLinux 9.2 (and soon version 9.6) now enjoys years of ongoing patching and compliance.
-
Go-Based Botnet Attacking IoT Devices
Using an SSH credential brute-force attack, the Go-based PumaBot is exploiting IoT devices everywhere.
-
Plasma 6.5 Promises Better Memory Optimization
With the stable Plasma 6.4 on the horizon, KDE has a few new tricks up its sleeve for Plasma 6.5.
-
KaOS 2025.05 Officially Qt5 Free
If you're a fan of independent Linux distributions, the team behind KaOS is proud to announce the latest iteration that includes kernel 6.14 and KDE's Plasma 6.3.5.
-
Linux Kernel 6.15 Now Available
The latest Linux kernel is now available with several new features/improvements and the usual bug fixes.
-
Microsoft Makes Surprising WSL Announcement
In a move that might surprise some users, Microsoft has made Windows Subsystem for Linux open source.
-
Red Hat Releases RHEL 10 Early
Red Hat quietly rolled out the official release of RHEL 10.0 a bit early.
-
openSUSE Joins End of 10
openSUSE has decided to not only join the End of 10 movement but it also will no longer support the Deepin Desktop Environment.
-
New Version of Flatpak Released
Flatpak 1.16.1 is now available as the latest, stable version with various improvements.
-
IBM Announces Powerhouse Linux Server
IBM has unleashed a seriously powerful Linux server with the LinuxONE Emperor 5.