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

Speeding Up The Linux Kernel With Your GPU

Linux Kernel

Published on 07 May 2011 02:28 PM EDT
Written by Michael Larabel in Linux Kernel
41 Comments

Sponsored in part by NVIDIA, at the University of Utah they are exploring speeding up the Linux kernel by using GPU acceleration. Rather than just allowing user-space applications to utilize the immense power offered by modern graphics processors, they are looking to speed up parts of the Linux kernel by running it directly on the GPU.

From the project page: "The idea behind KGPU is to treat the GPU as a computing co-processor for the operating system, enabling data-parallel computation inside the Linux kernel. This allows us to use SIMD (or SIMT in CUDA) style code to accelerate Linux kernel functionality, and to bring new functionality formerly considered too compute intensive into the kernel. Simply put, KGPU enables vector computing for the kernel."

Additionally, "it makes the Linux kernel really parallelized: it is not only processing multiple requests concurrently, but can also partition a single large requested computation into tiles and spread them across the large number of cores on a GPU."

While it sounds like a novel concept, this is more of a research project at this point and there are a few factors that basically rule out this "KGPU" project from making much mainstream adoption for the foreseeable future. The big problem is that none of the open-source graphics drivers living within the Linux kernel DRM (Direct Rendering Manager) sub-system are yet capable of GPGPU support. There is support planned for an OpenCL Gallium3D state tracker with Clover, but that's far from being ready.

The other problem is that this current work just targets the Linux kernel on calling the GPU using CUDA. This work is sponsored by NVIDIA so the university went with using the Compute Unified Device Architecture, which is only supported on NVIDIA hardware, and when using their latest proprietary driver. A better choice would have been OpenCL, which can run on both AMD and NVIDIA GPUs and is an open industry standard.

At this point in the development of KGPU, they have a GPU-accelerated AES cipher for use by the eCryptfs encrypted file-system, which is showing off promising results considering how well modern GPUs can deal with cryptography.

Those interested in learning more about KGPU to augment the Linux kernel with the GPU, visit the Google Code page. Code is also available on GitHub. It would be interesting to see the Linux kernel begin to take advantage of the processing capabilities offered by modern GPUs, but first the open-source kernel drivers must be improved and be able to handle OpenCL and/or other GPGPU interfaces.

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. Intel Xeon E5-1680 v3 & E5-2687W v3 Compared To The Core i7 5960X On Linux
  2. Intel 120GB 530 Series SSD Linux Performance
  3. Btrfs/EXT4/XFS/F2FS RAID 0/1/5/6/10 Linux Benchmarks On Four SSDs
  4. AMD's Windows Catalyst Driver Remains Largely Faster Than Linux Drivers
Latest Linux Articles
  1. NVIDIA vs. Nouveau Drivers With Linux 3.18 + Mesa 10.4-devel
  2. Is The Open-Source NVIDIA Driver Fast Enough For Steam On Linux Gaming?
  3. Linux 3.18 File-System Performance Minimally Changed But Possible Regressions
  4. AMD Radeon Gallium3D Is Catching Up & Sometimes Beating Catalyst On Linux
Latest Linux News
  1. VirtualBox 4.3.20 Arrives, Still No Sign Of VirtualBox 4.4
  2. Scientific Linux 6.6 vs. Scientific Linux 7.0 Benchmarks
  3. Qualcomm Looks To Get Into The ARM Server Business
  4. HHVM 3.4 Adds New Features, Support
  5. More Radeon Driver Changes Queued For Linux 3.19
  6. Unigine 2.0 Alpha 2 Adds C# Support
  7. FFmpeg Is Returning To Ubuntu With 15.04 Release
  8. Linux Version Of Civilization: Beyond Earth Still Coming Along
  9. Yahoo To Become Default Search Provider For Firefox
  10. Better Fan Control Support Coming To The Open-Source Radeon Driver
Latest Forum Discussions
  1. Updated and Optimized Ubuntu Free Graphics Drivers
  2. Debian Init System Coupling Vote Results
  3. Debian Developer Resigns From The Systemd Maintainership Team
  4. Ubuntu Developers Still Thinking What To Do About Adobe Flash Support
  5. How to get rid of Linux
  6. how to configure module phoromatic ?
  7. Major Performance Breakthrough Discovered For Intel's Mesa Driver
  8. Script for Fan Speed Control