On Tue, 4 Mar 2025 at 15:57, Kacper Michajlow <kaspe...@gmail.com> wrote: > > On Tue, 4 Mar 2025 at 15:50, James Almer <jamr...@gmail.com> wrote: > > > > On 3/4/2025 9:52 AM, Kacper Michajłow wrote: > > > Signed-off-by: Kacper Michajłow <kaspe...@gmail.com> > > > --- > > > compat/w32pthreads.h | 30 ++++++++++++++++++++++++++++++ > > > libavutil/thread.h | 2 ++ > > > 2 files changed, 32 insertions(+) > > > > > > diff --git a/compat/w32pthreads.h b/compat/w32pthreads.h > > > index fd6428e29f..83b4819205 100644 > > > --- a/compat/w32pthreads.h > > > +++ b/compat/w32pthreads.h > > > @@ -44,6 +44,7 @@ > > > #include "libavutil/internal.h" > > > #include "libavutil/mem.h" > > > #include "libavutil/time.h" > > > +#include "libavutil/wchar_filename.h" > > > > > > typedef struct pthread_t { > > > void *handle; > > > @@ -209,4 +210,33 @@ static inline int pthread_setcancelstate(int state, > > > int *oldstate) > > > return 0; > > > } > > > > > > +static inline int win32_thread_setname(const char *name) > > > +{ > > > + typedef HRESULT (WINAPI *SetThreadDescriptionFn)(HANDLE, PCWSTR); > > > + SetThreadDescriptionFn pSetThreadDescription; > > > + HRESULT hr; > > > + wchar_t *wname; > > > + > > > +#if !HAVE_UWP > > > + HMODULE kernel32 = GetModuleHandleW(L"kernel32.dll"); > > > + if (!kernel32) > > > + return ENOSYS; > > > + pSetThreadDescription = (SetThreadDescriptionFn) > > > + GetProcAddress(kernel32, "SetThreadDescription"); > > > + if (!pSetThreadDescription) > > > + return ENOSYS; > > > +#else > > > + WINBASEAPI HRESULT WINAPI > > > + SetThreadDescription(HANDLE hThread, PCWSTR lpThreadDescription); > > > + pSetThreadDescription = &SetThreadDescription; > > > +#endif > > > + > > > + if (utf8towchar(name, &wname) < 0) > > > + return ENOMEM; > > > + > > > + hr = pSetThreadDescription(GetCurrentThread(), wname); > > > + av_free(wname); > > > + return SUCCEEDED(hr) ? 0 : EINVAL; > > > +} > > > + > > > #endif /* COMPAT_W32PTHREADS_H */ > > > diff --git a/libavutil/thread.h b/libavutil/thread.h > > > index 2c00c7cc35..d1a36a6772 100644 > > > --- a/libavutil/thread.h > > > +++ b/libavutil/thread.h > > > @@ -229,6 +229,8 @@ static inline int ff_thread_setname(const char *name) > > > #endif > > > #elif HAVE_PTHREAD_SET_NAME_NP > > > pthread_set_name_np(pthread_self(), name); > > > +#elif HAVE_W32THREADS > > > + ret = AVERROR(win32_thread_setname(name)); > > > > AVERROR(0) is probably not a good idea, so negate the codes in > > win32_thread_setname() directly. > > Hmm, I can, but this is following the current pattern. All > `pthread_setname_np` calls above will return 0 on success and are > wrapped by AVERROR.
I've sent v2 with suggested change. - Kacper _______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org https://ffmpeg.org/mailman/listinfo/ffmpeg-devel To unsubscribe, visit link above, or email ffmpeg-devel-requ...@ffmpeg.org with subject "unsubscribe".