diff mbox series

thread-posix: add support for setting threads name on OpenBSD

Message ID Y57NrCmPTVSXLWC4@humpty.home.comstyle.com (mailing list archive)
State New, archived
Headers show
Series thread-posix: add support for setting threads name on OpenBSD | expand

Commit Message

Brad Smith Dec. 18, 2022, 8:22 a.m. UTC
Make use of pthread_set_name_np() to be able to set the threads name
on OpenBSD.

Signed-off-by: Brad Smith <brad@comstyle.com>
---
 meson.build              | 12 ++++++++++++
 util/qemu-thread-posix.c |  9 ++++++++-
 2 files changed, 20 insertions(+), 1 deletion(-)

Comments

Richard Henderson Dec. 18, 2022, 5:07 p.m. UTC | #1
On 12/18/22 00:22, Brad Smith wrote:
> Make use of pthread_set_name_np() to be able to set the threads name
> on OpenBSD.
> 
> Signed-off-by: Brad Smith<brad@comstyle.com>
> ---
>   meson.build              | 12 ++++++++++++
>   util/qemu-thread-posix.c |  9 ++++++++-
>   2 files changed, 20 insertions(+), 1 deletion(-)

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>

r~
Philippe Mathieu-Daudé Dec. 19, 2022, 8:59 p.m. UTC | #2
On 18/12/22 09:22, Brad Smith wrote:
> Make use of pthread_set_name_np() to be able to set the threads name
> on OpenBSD.
> 
> Signed-off-by: Brad Smith <brad@comstyle.com>
> ---
>   meson.build              | 12 ++++++++++++
>   util/qemu-thread-posix.c |  9 ++++++++-
>   2 files changed, 20 insertions(+), 1 deletion(-)

Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Brad Smith Feb. 17, 2023, 2:48 a.m. UTC | #3
ping.

On 2022-12-18 3:22 a.m., Brad Smith wrote:
> Make use of pthread_set_name_np() to be able to set the threads name
> on OpenBSD.
>
> Signed-off-by: Brad Smith <brad@comstyle.com>
> ---
>   meson.build              | 12 ++++++++++++
>   util/qemu-thread-posix.c |  9 ++++++++-
>   2 files changed, 20 insertions(+), 1 deletion(-)
>
> diff --git a/meson.build b/meson.build
> index 5c6b5a1c75..68adcb6291 100644
> --- a/meson.build
> +++ b/meson.build
> @@ -2123,6 +2123,18 @@ config_host_data.set('CONFIG_PTHREAD_SETNAME_NP_WO_TID', cc.links(gnu_source_pre
>       pthread_create(&thread, 0, f, 0);
>       return 0;
>     }''', dependencies: threads))
> +config_host_data.set('CONFIG_PTHREAD_SET_NAME_NP', cc.links(gnu_source_prefix + '''
> +  #include <pthread.h>
> +  #include <pthread_np.h>
> +
> +  static void *f(void *p) { return NULL; }
> +  int main(void)
> +  {
> +    pthread_t thread;
> +    pthread_create(&thread, 0, f, 0);
> +    pthread_set_name_np(thread, "QEMU");
> +    return 0;
> +  }''', dependencies: threads))
>   config_host_data.set('CONFIG_PTHREAD_CONDATTR_SETCLOCK', cc.links(gnu_source_prefix + '''
>     #include <pthread.h>
>     #include <time.h>
> diff --git a/util/qemu-thread-posix.c b/util/qemu-thread-posix.c
> index bae938c670..412caa45ef 100644
> --- a/util/qemu-thread-posix.c
> +++ b/util/qemu-thread-posix.c
> @@ -18,6 +18,10 @@
>   #include "qemu/tsan.h"
>   #include "qemu/bitmap.h"
>   
> +#ifdef CONFIG_PTHREAD_SET_NAME_NP
> +#include <pthread_np.h>
> +#endif
> +
>   static bool name_threads;
>   
>   void qemu_thread_naming(bool enable)
> @@ -25,7 +29,8 @@ void qemu_thread_naming(bool enable)
>       name_threads = enable;
>   
>   #if !defined CONFIG_PTHREAD_SETNAME_NP_W_TID && \
> -    !defined CONFIG_PTHREAD_SETNAME_NP_WO_TID
> +    !defined CONFIG_PTHREAD_SETNAME_NP_WO_TID && \
> +    !defined CONFIG_PTHREAD_SET_NAME_NP
>       /* This is a debugging option, not fatal */
>       if (enable) {
>           fprintf(stderr, "qemu: thread naming not supported on this host\n");
> @@ -480,6 +485,8 @@ static void *qemu_thread_start(void *args)
>           pthread_setname_np(pthread_self(), qemu_thread_args->name);
>   # elif defined(CONFIG_PTHREAD_SETNAME_NP_WO_TID)
>           pthread_setname_np(qemu_thread_args->name);
> +# elif defined(CONFIG_PTHREAD_SET_NAME_NP)
> +        pthread_set_name_np(pthread_self(), qemu_thread_args->name);
>   # endif
>       }
>       QEMU_TSAN_ANNOTATE_THREAD_NAME(qemu_thread_args->name);
Paolo Bonzini Feb. 17, 2023, 8:56 a.m. UTC | #4
Queued, thanks.

Paolo
diff mbox series

Patch

diff --git a/meson.build b/meson.build
index 5c6b5a1c75..68adcb6291 100644
--- a/meson.build
+++ b/meson.build
@@ -2123,6 +2123,18 @@  config_host_data.set('CONFIG_PTHREAD_SETNAME_NP_WO_TID', cc.links(gnu_source_pre
     pthread_create(&thread, 0, f, 0);
     return 0;
   }''', dependencies: threads))
+config_host_data.set('CONFIG_PTHREAD_SET_NAME_NP', cc.links(gnu_source_prefix + '''
+  #include <pthread.h>
+  #include <pthread_np.h>
+
+  static void *f(void *p) { return NULL; }
+  int main(void)
+  {
+    pthread_t thread;
+    pthread_create(&thread, 0, f, 0);
+    pthread_set_name_np(thread, "QEMU");
+    return 0;
+  }''', dependencies: threads))
 config_host_data.set('CONFIG_PTHREAD_CONDATTR_SETCLOCK', cc.links(gnu_source_prefix + '''
   #include <pthread.h>
   #include <time.h>
diff --git a/util/qemu-thread-posix.c b/util/qemu-thread-posix.c
index bae938c670..412caa45ef 100644
--- a/util/qemu-thread-posix.c
+++ b/util/qemu-thread-posix.c
@@ -18,6 +18,10 @@ 
 #include "qemu/tsan.h"
 #include "qemu/bitmap.h"
 
+#ifdef CONFIG_PTHREAD_SET_NAME_NP
+#include <pthread_np.h>
+#endif
+
 static bool name_threads;
 
 void qemu_thread_naming(bool enable)
@@ -25,7 +29,8 @@  void qemu_thread_naming(bool enable)
     name_threads = enable;
 
 #if !defined CONFIG_PTHREAD_SETNAME_NP_W_TID && \
-    !defined CONFIG_PTHREAD_SETNAME_NP_WO_TID
+    !defined CONFIG_PTHREAD_SETNAME_NP_WO_TID && \
+    !defined CONFIG_PTHREAD_SET_NAME_NP
     /* This is a debugging option, not fatal */
     if (enable) {
         fprintf(stderr, "qemu: thread naming not supported on this host\n");
@@ -480,6 +485,8 @@  static void *qemu_thread_start(void *args)
         pthread_setname_np(pthread_self(), qemu_thread_args->name);
 # elif defined(CONFIG_PTHREAD_SETNAME_NP_WO_TID)
         pthread_setname_np(qemu_thread_args->name);
+# elif defined(CONFIG_PTHREAD_SET_NAME_NP)
+        pthread_set_name_np(pthread_self(), qemu_thread_args->name);
 # endif
     }
     QEMU_TSAN_ANNOTATE_THREAD_NAME(qemu_thread_args->name);