Automatic Communication Performance Debugging in PGAS Languages

  • Jimmy Su
  • Katherine Yelick
Conference paper

DOI: 10.1007/978-3-540-85261-2_16

Volume 5234 of the book series Lecture Notes in Computer Science (LNCS)
Cite this paper as:
Su J., Yelick K. (2008) Automatic Communication Performance Debugging in PGAS Languages. In: Adve V., Garzarán M.J., Petersen P. (eds) Languages and Compilers for Parallel Computing. LCPC 2007. Lecture Notes in Computer Science, vol 5234. Springer, Berlin, Heidelberg

Abstract

Recent studies have shown that programming in a Partition Global Address Space (PGAS) language can be more productive than programming in a message passing model. One reason for this is the ability to access remote memory implicitly through shared memory reads and writes. But this benefit does not come without a cost. It is very difficult to spot communication by looking at the program text, since remote reads and writes look exactly the same as local reads and writes. This makes manual communication performance debugging an arduous task. In this paper, we describe a tool called ti-trend-prof that can do automatic performance debugging using only program traces from small processor configurations and small input sizes in Titanium [13], a PGAS language. ti-trend-prof presents trends to the programmer to help spot possible communication performance bugs even for processor configurations and input sizes that have not been run. We used ti-trend-prof on two of the largest Titanium applications and found bugs that would have taken days in under an hour.

Keywords

PGAS languages automatic performance debugging 

Preview

Unable to display preview. Download preview PDF.

Unable to display preview. Download preview PDF.

Copyright information

© Springer-Verlag Berlin Heidelberg 2008

Authors and Affiliations

  • Jimmy Su
    • 1
  • Katherine Yelick
    • 1
    • 2
  1. 1.Computer Science DivisionUniversity of California at Berkeley 
  2. 2.Lawrence Berkeley National Laboratory