Concepedia

Publication | Open Access

On implementing MPI-IO portably and with high performance

356

Citations

26

References

1999

Year

Abstract

We discuss the issues involved in implementing MPI-IO portably on multiple machines and file systems and also achieving high performance. One way to implement MPI-IO portably is to implement it on top of the basic Unix I/O functions (open, lseek, read, write, and close), which are themselves portable. We argue that this approach has limitations in both functionality and petformancc. We instead advocatean implementation approach that combines a large portion of portable code and a small portion of code that is optimized separately for different machines and tile systems. We have used such an approach tu develop a high-performance, portable MPI-IO implementation, called ROMIO. In addition to basic I/O functionality, we consider the issues of supporting other MPI-IO features, such us 64-bit file sizes, noncontiguous accesses, collective I/O, asynchronous I/O, consistency and atomichy semantics, user-supplied hints, shared tile pointers, portable data representation, and file preallocatiou. We describe how we implemented each of these features on various machines and file systems. The machines we consider are the HP Exemplar,

References

YearCitations

Page 1