mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-16 09:16:15 +01:00
Stop using ptrctl for thread names
We now prefer pthread_setname_np when available, and don't need the linux specific API anymore. Also change the test for this functionality to use pthread_getname_np.
This commit is contained in:
parent
28f0160031
commit
99bdfd1bcb
@ -709,7 +709,7 @@ AC_CHECK_HEADERS([sys/param.h sys/resource.h mach/mach_time.h])
|
|||||||
AC_CHECK_HEADERS([sys/select.h stdint.h inttypes.h sched.h malloc.h])
|
AC_CHECK_HEADERS([sys/select.h stdint.h inttypes.h sched.h malloc.h])
|
||||||
AC_CHECK_HEADERS([sys/vfs.h sys/vmount.h sys/statfs.h sys/statvfs.h sys/filio.h])
|
AC_CHECK_HEADERS([sys/vfs.h sys/vmount.h sys/statfs.h sys/statvfs.h sys/filio.h])
|
||||||
AC_CHECK_HEADERS([mntent.h sys/mnttab.h sys/vfstab.h sys/mntctl.h fstab.h])
|
AC_CHECK_HEADERS([mntent.h sys/mnttab.h sys/vfstab.h sys/mntctl.h fstab.h])
|
||||||
AC_CHECK_HEADERS([linux/magic.h sys/prctl.h])
|
AC_CHECK_HEADERS([linux/magic.h])
|
||||||
|
|
||||||
# Some versions of MSC lack these
|
# Some versions of MSC lack these
|
||||||
AC_CHECK_HEADERS([dirent.h sys/time.h])
|
AC_CHECK_HEADERS([dirent.h sys/time.h])
|
||||||
|
@ -59,9 +59,6 @@
|
|||||||
#ifdef HAVE_SCHED_H
|
#ifdef HAVE_SCHED_H
|
||||||
#include <sched.h>
|
#include <sched.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_SYS_PRCTL_H
|
|
||||||
#include <sys/prctl.h>
|
|
||||||
#endif
|
|
||||||
#ifdef G_OS_WIN32
|
#ifdef G_OS_WIN32
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#endif
|
#endif
|
||||||
@ -1227,12 +1224,10 @@ g_system_thread_exit (void)
|
|||||||
void
|
void
|
||||||
g_system_thread_set_name (const gchar *name)
|
g_system_thread_set_name (const gchar *name)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_SYS_PRCTL_H) && defined(PR_SET_NAME)
|
#if defined(HAVE_PTHREAD_SETNAME_NP_WITH_TID)
|
||||||
prctl (PR_SET_NAME, name, 0, 0, 0, 0); /* on Linux */
|
pthread_setname_np (pthread_self(), name); /* on Linux and Solaris */
|
||||||
#elif defined(HAVE_PTHREAD_SETNAME_NP_WITHOUT_TID)
|
#elif defined(HAVE_PTHREAD_SETNAME_NP_WITHOUT_TID)
|
||||||
pthread_setname_np (name); /* on OS X and iOS */
|
pthread_setname_np (name); /* on OS X and iOS */
|
||||||
#elif defined(HAVE_PTHREAD_SETNAME_NP_WITH_TID)
|
|
||||||
pthread_setname_np(pthread_self(), name); /* on Solaris */
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -170,14 +170,12 @@ test_thread5 (void)
|
|||||||
static gpointer
|
static gpointer
|
||||||
thread6_func (gpointer data)
|
thread6_func (gpointer data)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_SYS_PRCTL_H
|
#ifdef HAVE_PTHREAD_SETNAME_NP_WITH_TID
|
||||||
#ifdef PR_GET_NAME
|
char name[16];
|
||||||
const gchar name[16];
|
|
||||||
|
|
||||||
prctl (PR_GET_NAME, name, 0, 0, 0, 0);
|
pthread_getname_np (pthread_self(), name, 16);
|
||||||
|
|
||||||
g_assert_cmpstr (name, ==, (gchar*)data);
|
g_assert_cmpstr (name, ==, data);
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user