This is the mail archive of the gdb-cvs@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[binutils-gdb] Fix gdb.threads/watchpoint-fork*.c compilation


https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=1e903e320352db86233e1dd2d10fd140f5d4a887

commit 1e903e320352db86233e1dd2d10fd140f5d4a887
Author: Pedro Alves <palves@redhat.com>
Date:   Tue Mar 1 17:25:56 2016 +0000

    Fix gdb.threads/watchpoint-fork*.c compilation
    
    This testcase currently fails to compile on Fedora 23:
    
     .../src/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c: In function 'start':
     .../src/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c:70:11: warning: implicit declaration of function 'pthread_yield' [-Wimplicit-function-declaration]
    	i = pthread_yield ();
    	    ^
     .../src/gdb/testsuite/gdb.threads/watchpoint-fork-child.c: In function 'forkoff':
     .../src/gdb/testsuite/gdb.threads/watchpoint-fork-child.c:114:8: warning: implicit declaration of function 'pthread_yield' [-Wimplicit-function-declaratio
     n]
         i = pthread_yield ();
    	 ^
     /tmp/ccUkNIsI.o: In function `start':
     .../src/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c:70: undefined reference to `pthread_yield'
     (...)
     collect2: error: ld returned 1 exit status
    
     UNSUPPORTED: gdb.threads/watchpoint-fork.exp: child: multithreaded: Couldn't compile watchpoint-fork-child.c: unrecognized error
     UNTESTED: gdb.threads/watchpoint-fork.exp: child: multithreaded: watchpoint-fork.exp
     testcase .../src/gdb/testsuite/gdb.threads/watchpoint-fork.exp completed i
    
    The glibc manual says, on _GNU_SOURCE:
    
     "You should define these macros by using â??#defineâ?? preprocessor
     directives at the top of your source code files. These directives must
     come before any #include of a system header file."
    
    I instead put it in the header all the .c files of the testcase must
    include anyway.
    
    gdb/testsuite/ChangeLog:
    2016-03-01  Pedro Alves  <palves@redhat.com>
    
    	* gdb.threads/watchpoint-fork-child.c: Include "watchpoint-fork.h"
    	before anything else.
    	* gdb.threads/watchpoint-fork-mt.c: Likewise.  Don't define
    	_GNU_SOURCE here.
    	* gdb.threads/watchpoint-fork-st.c: Include "watchpoint-fork.h"
    	before anything else.
    	* gdb.threads/watchpoint-fork.h: Define _GNU_SOURCE.

Diff:
---
 gdb/testsuite/ChangeLog                           | 10 ++++++++++
 gdb/testsuite/gdb.threads/watchpoint-fork-child.c |  4 ++--
 gdb/testsuite/gdb.threads/watchpoint-fork-mt.c    |  7 ++-----
 gdb/testsuite/gdb.threads/watchpoint-fork-st.c    |  4 ++--
 gdb/testsuite/gdb.threads/watchpoint-fork.h       |  3 +++
 5 files changed, 19 insertions(+), 9 deletions(-)

diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index 49e87bc..c992a59 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,5 +1,15 @@
 2016-03-01  Pedro Alves  <palves@redhat.com>
 
+	* gdb.threads/watchpoint-fork-child.c: Include "watchpoint-fork.h"
+	before anything else.
+	* gdb.threads/watchpoint-fork-mt.c: Likewise.  Don't define
+	_GNU_SOURCE here.
+	* gdb.threads/watchpoint-fork-st.c: Include "watchpoint-fork.h"
+	before anything else.
+	* gdb.threads/watchpoint-fork.h: Define _GNU_SOURCE.
+
+2016-03-01  Pedro Alves  <palves@redhat.com>
+
 	* gdb.base/catch-fork-kill.c: Include <sys/wait.h>.
 
 2016-03-01  Yao Qi  <yao.qi@linaro.org>
diff --git a/gdb/testsuite/gdb.threads/watchpoint-fork-child.c b/gdb/testsuite/gdb.threads/watchpoint-fork-child.c
index 92ca0e5..b84a122 100644
--- a/gdb/testsuite/gdb.threads/watchpoint-fork-child.c
+++ b/gdb/testsuite/gdb.threads/watchpoint-fork-child.c
@@ -17,6 +17,8 @@
    You should have received a copy of the GNU General Public License
    along with this program; if not, see <http://www.gnu.org/licenses/>.  */
 
+#include "watchpoint-fork.h"
+
 #include <string.h>
 #include <errno.h>
 #include <unistd.h>
@@ -24,8 +26,6 @@
 #include <signal.h>
 #include <stdio.h>
 
-#include "watchpoint-fork.h"
-
 /* `pid_t' may not be available.  */
 
 static volatile int usr1_got;
diff --git a/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c b/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c
index f603b6d..bc967ce 100644
--- a/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c
+++ b/gdb/testsuite/gdb.threads/watchpoint-fork-mt.c
@@ -17,22 +17,19 @@
    You should have received a copy of the GNU General Public License
    along with this program; if not, see <http://www.gnu.org/licenses/>.  */
 
+#include "watchpoint-fork.h"
+
 #include <assert.h>
 #include <unistd.h>
 #include <sys/wait.h>
 #include <stdio.h>
 #include <stdlib.h>
-
-/* pthread_yield is a GNU extension.  */
-#define _GNU_SOURCE
 #include <pthread.h>
 
 #include <asm/unistd.h>
 #include <unistd.h>
 #define gettid() syscall (__NR_gettid)
 
-#include "watchpoint-fork.h"
-
 /* Non-atomic `var++' should not hurt as we synchronize the threads by the STEP
    variable.  Hit-comments need to be duplicated there to catch both at-stops
    and behind-stops, depending on the target.  */
diff --git a/gdb/testsuite/gdb.threads/watchpoint-fork-st.c b/gdb/testsuite/gdb.threads/watchpoint-fork-st.c
index 41ddf13..bd3a3f2 100644
--- a/gdb/testsuite/gdb.threads/watchpoint-fork-st.c
+++ b/gdb/testsuite/gdb.threads/watchpoint-fork-st.c
@@ -17,14 +17,14 @@
    You should have received a copy of the GNU General Public License
    along with this program; if not, see <http://www.gnu.org/licenses/>.  */
 
+#include "watchpoint-fork.h"
+
 #include <assert.h>
 #include <unistd.h>
 #include <sys/wait.h>
 #include <stdio.h>
 #include <stdlib.h>
 
-#include "watchpoint-fork.h"
-
 volatile int var;
 
 void
diff --git a/gdb/testsuite/gdb.threads/watchpoint-fork.h b/gdb/testsuite/gdb.threads/watchpoint-fork.h
index 8ea1937..87307ae 100644
--- a/gdb/testsuite/gdb.threads/watchpoint-fork.h
+++ b/gdb/testsuite/gdb.threads/watchpoint-fork.h
@@ -17,6 +17,9 @@
    You should have received a copy of the GNU General Public License
    along with this program; if not, see <http://www.gnu.org/licenses/>.  */
 
+/* pthread_yield is a GNU extension.  */
+#define _GNU_SOURCE
+
 #ifdef THREAD
 #include <pthread.h>


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]