@inproceedings{a98d01f8a58047d69bcf2df4b0f58e42,
title = "User level DB: A debugging API for user-level thread libraries",
abstract = "With the advent of the multicore era, parallel programming is becoming ubiquitous. Multithreading is a common approach to benefit from these architectures. Hybrid M:N libraries like MultiProcessor Communication (MPC) or MARCEL reach high performance expressing fine-grain parallelism by mapping M user-level threads onto N kernellevel threads. However, such implementations skew the debuggers' ability to distinguish one thread from another, because only kernel threads can be handled. SUN MICROSYSTEMS' THREAD DB API is an interface between the debugger and the thread library allowing the debugger to inquire for thread semantics details. In this paper we introduce the USER LEVEL DB (ULDB) library, an implementation of the THREAD DB interface abstracting the common features of user-level thread libraries. ULDB gathers the generic algorithms required to debug threads and provide the thread library with a small and focused interface. We describe the usage of our library with widely-used debuggers (GDB, DBX) and the integration into a user-level thread library (GNUPTH) and two high-performance hybrid libraries (MPC, MARCEL).",
keywords = "Debugging, GDB, MPC, Multithreading",
author = "Kevin Pouget and Marc P{\'e}rachey and Patrick Carribault and Herv{\'e} Jourdren",
year = "2010",
month = jul,
day = "2",
doi = "10.1109/IPDPSW.2010.5470815",
language = "English",
isbn = "9781424465347",
series = "Proceedings of the 2010 IEEE International Symposium on Parallel and Distributed Processing, Workshops and Phd Forum, IPDPSW 2010",
booktitle = "Proceedings of the 2010 IEEE International Symposium on Parallel and Distributed Processing, Workshops and Phd Forum, IPDPSW 2010",
note = "2010 IEEE International Symposium on Parallel and Distributed Processing, Workshops and Phd Forum, IPDPSW 2010 ; Conference date: 19-04-2010 Through 23-04-2010",
}