mirror of
https://gitlab.freedesktop.org/dbus/dbus.git
synced 2026-02-04 04:50:40 +01:00
Display thread id in _dbus_verbose to be able to see threading issues.
Bug: https://bugs.freedesktop.org/show_bug.cgi?id=95191 Reviewed-by: Simon McVittie <simon.mcvittie@collabora.co.uk>
This commit is contained in:
parent
9ab7fe33f8
commit
dc71d04010
5 changed files with 31 additions and 12 deletions
|
|
@ -281,12 +281,6 @@ _dbus_warn_check_failed(const char *format,
|
|||
static dbus_bool_t verbose_initted = FALSE;
|
||||
static dbus_bool_t verbose = TRUE;
|
||||
|
||||
/** Whether to show the current thread in verbose messages */
|
||||
#define PTHREAD_IN_VERBOSE 0
|
||||
#if PTHREAD_IN_VERBOSE
|
||||
#include <pthread.h>
|
||||
#endif
|
||||
|
||||
#ifdef DBUS_USE_OUTPUT_DEBUG_STRING
|
||||
static char module_name[1024];
|
||||
#endif
|
||||
|
|
@ -406,11 +400,7 @@ _dbus_verbose_real (
|
|||
/* Print out pid before the line */
|
||||
if (need_pid)
|
||||
{
|
||||
#if PTHREAD_IN_VERBOSE
|
||||
fprintf (stderr, "%lu: 0x%lx: ", _dbus_pid_for_log (), pthread_self ());
|
||||
#else
|
||||
fprintf (stderr, "%lu: ", _dbus_pid_for_log ());
|
||||
#endif
|
||||
_dbus_print_thread ();
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
|
|||
|
|
@ -28,6 +28,7 @@
|
|||
|
||||
#include <sys/time.h>
|
||||
#include <pthread.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
#ifdef HAVE_ERRNO_H
|
||||
|
|
@ -300,3 +301,20 @@ _dbus_threads_unlock_platform_specific (void)
|
|||
{
|
||||
pthread_mutex_unlock (&init_mutex);
|
||||
}
|
||||
|
||||
#ifdef DBUS_ENABLE_VERBOSE_MODE
|
||||
/*
|
||||
* If we can identify the current process and/or thread, print them to stderr followed by a colon.
|
||||
*/
|
||||
void
|
||||
_dbus_print_thread (void)
|
||||
{
|
||||
#ifdef __linux__
|
||||
/* we know a pthread_t is numeric on Linux */
|
||||
fprintf (stderr, "%lu: 0x%lx: ", _dbus_pid_for_log (), (unsigned long) pthread_self ());
|
||||
#else
|
||||
/* in principle pthread_t isn't required to be printable */
|
||||
fprintf (stderr, "%lu: ", _dbus_pid_for_log ());
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -300,3 +300,11 @@ _dbus_threads_unlock_platform_specific (void)
|
|||
_dbus_assert (global_init_done);
|
||||
LeaveCriticalSection (&init_lock);
|
||||
}
|
||||
|
||||
#ifdef DBUS_ENABLE_VERBOSE_MODE
|
||||
void
|
||||
_dbus_print_thread (void)
|
||||
{
|
||||
fprintf (stderr, "%lu: 0x%04lx: ", _dbus_pid_for_log (), GetCurrentThreadId ());
|
||||
}
|
||||
#endif
|
||||
|
|
|
|||
|
|
@ -3636,4 +3636,3 @@ _dbus_restore_socket_errno (int saved_errno)
|
|||
|
||||
/** @} end of sysdeps-win */
|
||||
/* tests in dbus-sysdeps-util.c */
|
||||
|
||||
|
|
|
|||
|
|
@ -492,6 +492,10 @@ DBUS_PRIVATE_EXPORT
|
|||
int _dbus_printf_string_upper_bound (const char *format,
|
||||
va_list args);
|
||||
|
||||
#ifdef DBUS_ENABLE_VERBOSE_MODE
|
||||
DBUS_PRIVATE_EXPORT
|
||||
void _dbus_print_thread (void);
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Portable struct with stat() results
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue