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 Benchmarking Platform
Phoromatic Test Orchestration

Volatile Ranges Still Being Tried For The Linux Kernel

Linux Kernel

Published on 02 January 2014 07:41 AM EST
Written by Michael Larabel in Linux Kernel
1 Comment

The Volatile Ranges feature for the Linux kernel is now in its third year of being developed and a new set of sixteen patches were published today but there's still no sign that the code is ready for merging in the near-term.

Volatile Ranges is another option for Linux application developers to notify the kernel that a range of pages can be discarded from the system's RAM rather than being swapped out to the disk. When the system is suffering from memory pressure, the kernel can first attempt to evict these "volatile ranges" rather than swapping it to the disk. When the application needs the data later, if it was flushed away, the application will be responsible for recreating the lost data. If there was no memory pressure, everything continues to be smooth sailing.

One of the major use-cases for this work is web browsers where volatile ranges can be easily marked and the data regenerated if needed. Volatile Ranges can also be of benefit to memory-constrained mobile devices, but there's also other similar approaches already on Linux for flagging memory that should first be discarded in situations of low memory.

The patches published this morning by Minchan Kim are up to the tenth revision of the most recent Volatile Ranges design. This latest version will work on the Linux 3.12 kernel and has numerous other changes.

Those interested in the new Linux Volatile Ranges patches can find them on the Linux kernel mailing list. There's still greater code review needed and items left on the feature's TODO list, so don't expect the feature to be merged for the Linux 3.14 kernel.

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 News
  1. At Least Two Ubuntu Phone Announcements Expected In June
  2. Russia's Baikal Chips End Up Going For A MIPS CPU
  3. Mesa Git OpenGL Tests With Intel Ivy Bridge Graphics
  4. Blender 2.75 Allows For AMD OpenCL Support
  5. GNOME's Mutter 3.17.2 Adds X11/Wayland Clipboard Interoperation
  6. Wayland 1.8 RC2 Arrives Along With New Weston Compositor Release
  7. LLVM 3.7 Is Planned For A Late August Release
  8. The OpenGL ES 3.1 Foundation Is Being Laid In Mesa
  9. There Are 140k Benchmark Results So Far On LinuxBenchmarking.com
  10. LLVM 3.6.1 Brings R600 & MIPS Fixes
Latest Articles & Reviews
  1. Opening The Gates To Our Daily Open-Source Linux Benchmark Results
  2. The Latest Features For Linux Performance Management + Benchmark Monitoring
  3. Noctua NH-U12DX i4 + NF-F12
  4. Btrfs RAID 0/1 Benchmarks On The Linux 4.1 Kernel
Most Viewed News This Week
  1. The Linux 4.0 EXT4 RAID Corruption Bug Has Been Uncovered
  2. NVIDIA's Proprietary Driver Is Moving Closer With Kernel Mode-Setting
  3. Systemd 220 Has Finally Been Released
  4. Microsoft Open-Sources The Windows Communication Foundation
  5. Zapcc Claims To Be A "Much Faster C++ Compiler"
  6. LibreOffice 5.0 Beta 1 Released
  7. Another HTTPS Vulnerability Rattles The Internet
  8. LibreOffice 5.0 Open-Source Office Suite Has Been Branched