1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

KernelASan: Bringing Address Sanitizer To The Linux Kernel

Linux Kernel

Published on 18 July 2014 09:23 AM EDT
Written by Michael Larabel in Linux Kernel
7 Comments

Work being done by Samsung and other Linux stakeholders is bringing the Address Sanitizer capabilities found in GCC as being useful for detecting potential memory issues within the Linux kernel.

Address Sanitizer is the feature within GCC (and now LLVM/Clang too) for detecting memory corruption bugs like buffer overflows, use-after-free, and other memory errors. Address Sanitizer is successfully used in the real world for finding bugs within Firefox, Chromium, FFmpeg, and many other projects for using this easy memory detection instrumentation within the compiler.

Earlier this month a set of patches were published for supporting the Address Sanitizer for the Linux kernel and introducing new CONFIG_KASAN=y and CONFIG_KASAN_SANITIZE_ALL=y kernel config options. The patches for the kernel currently support finding use-after-free bugs and out-of-bounds read/writes in kmalloc. Not yet wired in but possible to implement for the kernel memory checking code are global buffer overflows, stack buffer overflows, and use after returns.

While these patches aren't yet feature complete, there's already been a number of bugs fixed by Address Sanitizer for the kernel ranging from IPv4/IPv6 code to the EXT4 file-system and AIO. The current kernel patches can be found on the LKML and hopefully they'll get queued up for the Linux 3.17 kernel merge window.

Published today is a small GCC patch for supporting the Kernel Address Sanitizer.

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Linux Hardware Reviews
  1. MSI X99S SLI PLUS On Linux
  2. NVIDIA GeForce GTX 970 Offers Great Linux Performance
  3. CompuLab Intense-PC2: An Excellent, Fanless, Mini PC Powered By Intel's i7 Haswell
  4. From The Atom 330 To Haswell ULT: Intel Linux Performance Benchmarks
Latest Linux Articles
  1. RunAbove: A POWER8 Compute Cloud With Offerings Up To 176 Threads
  2. 6-Way Ubuntu 14.10 Linux Desktop Benchmarks
  3. Ubuntu 14.10 XMir System Compositor Benchmarks
  4. Btrfs RAID HDD Testing On Ubuntu Linux 14.10
Latest Linux News
  1. openSUSE Factory & Tumbleweed Are Merging
  2. More Fedora Delays: Fedora 21 Beta Slips
  3. Mono Brings C# To The Unreal Engine 4
  4. Coreboot Now Has Support For Intel Broadwell Hardware
  5. Enlightenment's EFL 1.12 Alpha Has Evas GL-DRM Engine, OpenGL ES 1.1 Support
  6. GTK+ Lands Experimental Backend For Mir Display Server
  7. Ubuntu 14.10 Officially Released
  8. Mesa 10.4 Might Re-Enable HyperZ For R600g/RadeonSI
  9. Intel GVT-g GPU Virtualization Moves Closer
  10. GTK+ 3.16 To Bring Several New Features
Latest Forum Discussions
  1. Ubuntu 16.04 Might Be The Distribution's Last 32-Bit Release
  2. Updated and Optimized Ubuntu Free Graphics Drivers
  3. Linux hacker compares Solaris kernel code:
  4. HOPE: The Ease Of Python With The Speed Of C++
  5. Advertisements On Phoronix
  6. Users/Developers Threatening Fork Of Debian GNU/Linux
  7. AMD Releases UVD Video Decode Support For R600 GPUs
  8. Proof that strlcpy is un-needed

Close Advertisement

Close Advertisement