GPUfs: Integrating a file system with GPUs

  • Authors:
  • Mark Silberstein;Bryan Ford;Idit Keidar;Emmett Witchel

  • Affiliations:
  • University of Texas at Austin;Yale University;Technion;University of Texas at Austin

  • Venue:
  • ACM Transactions on Computer Systems (TOCS)
  • Year:
  • 2014

Quantified Score

Hi-index 0.00

Visualization

Abstract

As GPU hardware becomes increasingly general-purpose, it is quickly outgrowing the traditional, constrained GPU-as-coprocessor programming model. This article advocates for extending standard operating system services and abstractions to GPUs in order to facilitate program development and enable harmonious integration of GPUs in computing systems. As an example, we describe the design and implementation of GPUFs, a software layer which provides operating system support for accessing host files directly from GPU programs. GPUFs provides a POSIX-like API, exploits GPU parallelism for efficiency, and optimizes GPU file access by extending the host CPU's buffer cache into GPU memory. Our experiments, based on a set of real benchmarks adapted to use our file system, demonstrate the feasibility and benefits of the GPUFs approach. For example, a self-contained GPU program that searches for a set of strings throughout the Linux kernel source tree runs over seven times faster than on an eight-core CPU.