From 11cea17496c190969c758153034c94622211dce9 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Tue, 6 Jan 2015 12:04:15 +0100 Subject: [PATCH 1/4] thread/Name: indent preprocessor commands --- src/thread/Name.hxx | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/thread/Name.hxx b/src/thread/Name.hxx index 284d1e147..0edcc0242 100644 --- a/src/thread/Name.hxx +++ b/src/thread/Name.hxx @@ -21,10 +21,10 @@ #define MPD_THREAD_NAME_HXX #ifdef HAVE_PTHREAD_SETNAME_NP -#include -#include +# include +# include #elif defined(HAVE_PRCTL) -#include +# include #endif static inline void From b9ed850b98ff793b43482cc501505f873335bdb1 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Tue, 6 Jan 2015 12:04:02 +0100 Subject: [PATCH 2/4] thread/Name: enable FormatThreadName() with prctl() Add macro HAVE_THREAD_NAME which is set when any method to set the thread name is available. Use that macro in FormatThreadName() instead of just checking for HAVE_PTHREAD_SETNAME_NP. --- src/thread/Name.hxx | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/src/thread/Name.hxx b/src/thread/Name.hxx index 0edcc0242..872702af2 100644 --- a/src/thread/Name.hxx +++ b/src/thread/Name.hxx @@ -21,10 +21,14 @@ #define MPD_THREAD_NAME_HXX #ifdef HAVE_PTHREAD_SETNAME_NP +# define HAVE_THREAD_NAME # include # include #elif defined(HAVE_PRCTL) # include +# ifdef PR_SET_NAME +# define HAVE_THREAD_NAME +# endif #endif static inline void @@ -47,7 +51,7 @@ template static inline void FormatThreadName(const char *fmt, gcc_unused Args&&... args) { -#ifdef HAVE_PTHREAD_SETNAME_NP +#ifdef HAVE_THREAD_NAME char buffer[16]; snprintf(buffer, sizeof(buffer), fmt, args...); SetThreadName(buffer); From 4bd2c75056271e687e26c4d8038bdefaa7c88dc9 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Tue, 6 Jan 2015 12:08:36 +0100 Subject: [PATCH 3/4] thread/Name: disable pthread_setname_np() on NetBSD NetBSD's pthread_setname_np() prototype is incompatible with the rest of the world, and it requires to pass the string argument as a non-const pointer. Instead of working around this misdesign, I hereby disable the feature on NetBSD. --- NEWS | 1 + src/thread/Name.hxx | 8 ++++++-- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/NEWS b/NEWS index 14676a5a7..37b3b4cad 100644 --- a/NEWS +++ b/NEWS @@ -5,6 +5,7 @@ ver 0.19.8 (not yet released) - dsdiff, dsf: allow ID3 tags larger than 4 kB - ffmpeg: support interleaved floating point * fix clang 3.6 warnings +* fix build failure on NetBSD ver 0.19.7 (2014/12/17) * input diff --git a/src/thread/Name.hxx b/src/thread/Name.hxx index 872702af2..0fbad0fd2 100644 --- a/src/thread/Name.hxx +++ b/src/thread/Name.hxx @@ -20,7 +20,7 @@ #ifndef MPD_THREAD_NAME_HXX #define MPD_THREAD_NAME_HXX -#ifdef HAVE_PTHREAD_SETNAME_NP +#if defined(HAVE_PTHREAD_SETNAME_NP) && !defined(__NetBSD__) # define HAVE_THREAD_NAME # include # include @@ -34,7 +34,11 @@ static inline void SetThreadName(const char *name) { -#ifdef HAVE_PTHREAD_SETNAME_NP +#if defined(HAVE_PTHREAD_SETNAME_NP) && !defined(__NetBSD__) + /* not using pthread_setname_np() on NetBSD because it + requires a non-const pointer argument, which we don't have + here */ + #ifdef __APPLE__ pthread_setname_np(name); #else From 37e9010887783c307355f3144786ed72e8a973b0 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Tue, 6 Jan 2015 12:46:28 +0100 Subject: [PATCH 4/4] input/async: reset the "open" flag after seeking successfully Fixes a problem with the "curl" input plugin: IsEOF() always returns true because the "open" flag was cleared by CurlInputStream::RequestDone() when end-of-stream was reached. This flag stays false even when seeking to another position has succeeded. This patch resets the "open" flag to true after seeking successfully. --- NEWS | 1 + src/input/AsyncInputStream.cxx | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/NEWS b/NEWS index 37b3b4cad..5e8d58c22 100644 --- a/NEWS +++ b/NEWS @@ -1,5 +1,6 @@ ver 0.19.8 (not yet released) * input + - curl: fix bug after rewinding from end-of-file - mms: reduce delay at the beginning of playback * decoder - dsdiff, dsf: allow ID3 tags larger than 4 kB diff --git a/src/input/AsyncInputStream.cxx b/src/input/AsyncInputStream.cxx index c8e3fcfd5..5795ecead 100644 --- a/src/input/AsyncInputStream.cxx +++ b/src/input/AsyncInputStream.cxx @@ -160,6 +160,11 @@ AsyncInputStream::SeekDone() assert(io_thread_inside()); assert(IsSeekPending()); + /* we may have reached end-of-file previously, and the + connection may have been closed already; however after + seeking successfully, the connection must be alive again */ + open = true; + seek_state = SeekState::NONE; cond.broadcast(); }