Carnegie Mellon University Technical Report CMU-CS-96-193, October, 1996. Also appears as Technical Report CACR-130, Scalable I/O Initiative, Caltech Center for Advanced Computing Research, Pasadena, CA, November 1996.
Peter Corbett1, Jean-Pierre Prost1, Chris Demetriou, Garth A. Gibson, Erik Riedel, Jim Zelenka, Yuqun Chen2, Ed Felten2, Kai Li2, John Hartman3, Larry Peterson3, Brian Bershad4, Alec Wolman4, Ruth Aydt5
School of Computer Science {1}IBM T. J. Watson Research Center
{2}Department of Computer Science, Princeton University
{3}Department of Computer Science, The University of Arizona
{4}Computer Science & Engineering, University of Washington
{5}Department of Computer Science, University of Illinois at Urbana-Champaign
This document proposes an interface to parallel file systems intended for use with a variety of parallel computers. This proposal is based on the separation of programmer convenience functions from high-performance enabling functions. We propose that the former be supported above this interface, possibly in client libraries. The latter, functions that enable high performance, are defined by this proposed API under the assumption that these functions are more likely to need system and vendor-specific support.
Specifically, this proposal includes functions which support reading and writing with scatter-gather addressing for memory and file ranges, and asynchronous operations. It also includes mechanisms that permit client control over client caching, and file access and layout hints. Finally, it includes a mechanism by which this API can be extended and extensions for fast file copy and batching collective I/O operations.
FULL PAPER: pdf / postscript