Initial commit
This commit is contained in:
		
							
								
								
									
										87
									
								
								package/devel/gdb/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								package/devel/gdb/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| # | ||||
| # Copyright (C) 2006-2016 OpenWrt.org | ||||
| # | ||||
| # This is free software, licensed under the GNU General Public License v2. | ||||
| # See /LICENSE for more information. | ||||
| # | ||||
|  | ||||
| include $(TOPDIR)/rules.mk | ||||
|  | ||||
| PKG_NAME:=gdb | ||||
| PKG_VERSION:=8.0.1 | ||||
| PKG_RELEASE:=1 | ||||
|  | ||||
| PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz | ||||
| PKG_SOURCE_URL:=@GNU/gdb | ||||
| PKG_HASH:=3dbd5f93e36ba2815ad0efab030dcd0c7b211d7b353a40a53f4c02d7d56295e3 | ||||
|  | ||||
| PKG_BUILD_PARALLEL:=1 | ||||
| PKG_INSTALL:=1 | ||||
| PKG_LICENSE:=GPL-3.0+ | ||||
| PKG_CPE_ID:=cpe:/a:gnu:gdb | ||||
|  | ||||
| include $(INCLUDE_DIR)/package.mk | ||||
|  | ||||
| define Package/gdb/Default | ||||
|   SECTION:=devel | ||||
|   CATEGORY:=Development | ||||
|   DEPENDS:=+!USE_MUSL:libthread-db +PACKAGE_zlib:zlib @!arc | ||||
|   URL:=http://www.gnu.org/software/gdb/ | ||||
| endef | ||||
|  | ||||
| define Package/gdb | ||||
| $(call Package/gdb/Default) | ||||
|   TITLE:=GNU Debugger | ||||
|   DEPENDS+=+libreadline +libncurses +zlib | ||||
| endef | ||||
|  | ||||
| define Package/gdb/description | ||||
| GDB, the GNU Project debugger, allows you to see what is going on `inside' | ||||
| another program while it executes -- or what another program was doing at the | ||||
| moment it crashed. | ||||
| endef | ||||
|  | ||||
| define Package/gdbserver | ||||
| $(call Package/gdb/Default) | ||||
|   TITLE:=Remote server for GNU Debugger | ||||
| endef | ||||
|  | ||||
| define Package/gdbserver/description | ||||
| GDBSERVER is a program that allows you to run GDB on a different machine than the | ||||
| one which is running the program being debugged. | ||||
| endef | ||||
|  | ||||
| # XXX: add --disable-werror to prevent build failure with arm | ||||
| CONFIGURE_ARGS+= \ | ||||
| 	--with-system-readline \ | ||||
| 	--without-expat \ | ||||
| 	--without-lzma \ | ||||
| 	--disable-sim \ | ||||
| 	--disable-werror | ||||
|  | ||||
| CONFIGURE_VARS+= \ | ||||
| 	ac_cv_search_tgetent="$(TARGET_LDFLAGS) -lncurses -lreadline" | ||||
|  | ||||
| TARGET_LDFLAGS+= \ | ||||
| 	-static-libstdc++ \ | ||||
| 	-Wl,--gc-sections | ||||
|  | ||||
| define Build/Install | ||||
| 	$(MAKE) -C $(PKG_BUILD_DIR) \ | ||||
| 		DESTDIR="$(PKG_INSTALL_DIR)" \ | ||||
| 		CPPFLAGS="$(TARGET_CPPFLAGS)" \ | ||||
| 		install-gdb | ||||
| endef | ||||
|  | ||||
| define Package/gdb/install | ||||
| 	$(INSTALL_DIR) $(1)/usr/bin | ||||
| 	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/gdb $(1)/usr/bin/ | ||||
| endef | ||||
|  | ||||
| define Package/gdbserver/install | ||||
| 	$(INSTALL_DIR) $(1)/usr/bin | ||||
| 	$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/gdbserver $(1)/usr/bin/ | ||||
| endef | ||||
|  | ||||
| $(eval $(call BuildPackage,gdb)) | ||||
| $(eval $(call BuildPackage,gdbserver)) | ||||
| @@ -0,0 +1,16 @@ | ||||
| See http://sourceware.org/bugzilla/show_bug.cgi?id=14523 | ||||
| --- | ||||
| --- a/gdb/common/signals.c | ||||
| +++ b/gdb/common/signals.c | ||||
| @@ -348,6 +348,11 @@ gdb_signal_from_host (int hostsig) | ||||
|        else if (64 <= hostsig && hostsig <= 127) | ||||
|  	return (enum gdb_signal) | ||||
|  	  (hostsig - 64 + (int) GDB_SIGNAL_REALTIME_64); | ||||
| +      else if (hostsig == 128) | ||||
| +	/* Some platforms, such as Linux MIPS, have NSIG == 128, in which case | ||||
| +	   signal 128 is the highest realtime signal. There is no constant for | ||||
| +	   that though. */ | ||||
| +	return GDB_SIGNAL_UNKNOWN; | ||||
|        else | ||||
|  	error (_("GDB bug: target.c (gdb_signal_from_host): " | ||||
|  	       "unrecognized real-time signal")); | ||||
							
								
								
									
										53
									
								
								package/devel/gdb/patches/100-musl_fix.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								package/devel/gdb/patches/100-musl_fix.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | ||||
| --- a/gdb/linux-nat.c | ||||
| +++ b/gdb/linux-nat.c | ||||
| @@ -17,6 +17,7 @@ | ||||
|     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 "stopcode.h" | ||||
|  #include "defs.h" | ||||
|  #include "inferior.h" | ||||
|  #include "infrun.h" | ||||
| @@ -71,6 +72,10 @@ | ||||
|  #define SPUFS_MAGIC 0x23c9b64e | ||||
|  #endif | ||||
|   | ||||
| +#ifndef __SIGRTMIN | ||||
| +#define __SIGRTMIN SIGRTMIN | ||||
| +#endif | ||||
| + | ||||
|  /* This comment documents high-level logic of this file. | ||||
|   | ||||
|  Waiting for events in sync mode | ||||
| --- /dev/null | ||||
| +++ b/gdb/stopcode.h | ||||
| @@ -0,0 +1,4 @@ | ||||
| +#ifndef W_STOPCODE | ||||
| +#define W_STOPCODE(sig) ((sig) << 8 | 0x7f) | ||||
| +#endif | ||||
| + | ||||
| --- a/gdb/nat/ppc-linux.h | ||||
| +++ b/gdb/nat/ppc-linux.h | ||||
| @@ -18,7 +18,10 @@ | ||||
|  #ifndef PPC_LINUX_H | ||||
|  #define PPC_LINUX_H 1 | ||||
|   | ||||
| +#define pt_regs __pt_regs | ||||
|  #include <asm/ptrace.h> | ||||
| +#undef pt_regs | ||||
| + | ||||
|  #include <asm/cputable.h> | ||||
|   | ||||
|  /* This sometimes isn't defined.  */ | ||||
| --- a/gdb/gdbserver/linux-ppc-low.c | ||||
| +++ b/gdb/gdbserver/linux-ppc-low.c | ||||
| @@ -21,7 +21,9 @@ | ||||
|  #include "linux-low.h" | ||||
|   | ||||
|  #include <elf.h> | ||||
| +#define pt_regs __pt_regs | ||||
|  #include <asm/ptrace.h> | ||||
| +#undef pt_regs | ||||
|   | ||||
|  #include "nat/ppc-linux.h" | ||||
|  #include "linux-ppc-tdesc.h" | ||||
							
								
								
									
										76
									
								
								package/devel/gdb/patches/110-shared_libgcc.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								package/devel/gdb/patches/110-shared_libgcc.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | ||||
| --- a/configure.ac | ||||
| +++ b/configure.ac | ||||
| @@ -1300,13 +1300,13 @@ if test -z "$LD"; then | ||||
|    fi | ||||
|  fi | ||||
|   | ||||
| -# Check whether -static-libstdc++ -static-libgcc is supported. | ||||
| +# Check whether -static-libstdc++ is supported. | ||||
|  have_static_libs=no | ||||
|  if test "$GCC" = yes; then | ||||
|    saved_LDFLAGS="$LDFLAGS" | ||||
|   | ||||
| -  LDFLAGS="$LDFLAGS -static-libstdc++ -static-libgcc" | ||||
| -  AC_MSG_CHECKING([whether g++ accepts -static-libstdc++ -static-libgcc]) | ||||
| +  LDFLAGS="$LDFLAGS -static-libstdc++" | ||||
| +  AC_MSG_CHECKING([whether g++ accepts -static-libstdc++]) | ||||
|    AC_LANG_PUSH(C++) | ||||
|    AC_LINK_IFELSE([ | ||||
|  #if (__GNUC__ < 4) || (__GNUC__ == 4 && __GNUC_MINOR__ < 5) | ||||
| @@ -1632,7 +1632,7 @@ AC_ARG_WITH(stage1-ldflags, | ||||
|   # if supported.  But if the user explicitly specified the libraries to use, | ||||
|   # trust that they are doing what they want. | ||||
|   if test "$stage1_libs" = "" -a "$have_static_libs" = yes; then | ||||
| -   stage1_ldflags="-static-libstdc++ -static-libgcc" | ||||
| +   stage1_ldflags="-static-libstdc++" | ||||
|   fi]) | ||||
|  AC_SUBST(stage1_ldflags) | ||||
|   | ||||
| @@ -1661,7 +1661,7 @@ AC_ARG_WITH(boot-ldflags, | ||||
|   # statically.  But if the user explicitly specified the libraries to | ||||
|   # use, trust that they are doing what they want. | ||||
|   if test "$poststage1_libs" = ""; then | ||||
| -   poststage1_ldflags="-static-libstdc++ -static-libgcc" | ||||
| +   poststage1_ldflags="-static-libstdc++" | ||||
|   fi]) | ||||
|  AC_SUBST(poststage1_ldflags) | ||||
|   | ||||
| --- a/configure | ||||
| +++ b/configure | ||||
| @@ -5005,14 +5005,14 @@ if test -z "$LD"; then | ||||
|    fi | ||||
|  fi | ||||
|   | ||||
| -# Check whether -static-libstdc++ -static-libgcc is supported. | ||||
| +# Check whether -static-libstdc++ is supported. | ||||
|  have_static_libs=no | ||||
|  if test "$GCC" = yes; then | ||||
|    saved_LDFLAGS="$LDFLAGS" | ||||
|   | ||||
| -  LDFLAGS="$LDFLAGS -static-libstdc++ -static-libgcc" | ||||
| -  { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether g++ accepts -static-libstdc++ -static-libgcc" >&5 | ||||
| -$as_echo_n "checking whether g++ accepts -static-libstdc++ -static-libgcc... " >&6; } | ||||
| +  LDFLAGS="$LDFLAGS -static-libstdc++" | ||||
| +  { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether g++ accepts -static-libstdc++" >&5 | ||||
| +$as_echo_n "checking whether g++ accepts -static-libstdc++... " >&6; } | ||||
|    ac_ext=cpp | ||||
|  ac_cpp='$CXXCPP $CPPFLAGS' | ||||
|  ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' | ||||
| @@ -5795,7 +5795,7 @@ else | ||||
|   # if supported.  But if the user explicitly specified the libraries to use, | ||||
|   # trust that they are doing what they want. | ||||
|   if test "$stage1_libs" = "" -a "$have_static_libs" = yes; then | ||||
| -   stage1_ldflags="-static-libstdc++ -static-libgcc" | ||||
| +   stage1_ldflags="-static-libstdc++" | ||||
|   fi | ||||
|  fi | ||||
|   | ||||
| @@ -5831,7 +5831,7 @@ else | ||||
|   # statically.  But if the user explicitly specified the libraries to | ||||
|   # use, trust that they are doing what they want. | ||||
|   if test "$poststage1_libs" = ""; then | ||||
| -   poststage1_ldflags="-static-libstdc++ -static-libgcc" | ||||
| +   poststage1_ldflags="-static-libstdc++" | ||||
|   fi | ||||
|  fi | ||||
|   | ||||
							
								
								
									
										38
									
								
								package/devel/gdb/patches/120-sigprocmask-invalid-call.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								package/devel/gdb/patches/120-sigprocmask-invalid-call.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,38 @@ | ||||
| From 56893a61aa4f0270fa8d1197b9848247f90fce0d Mon Sep 17 00:00:00 2001 | ||||
| From: Yousong Zhou <yszhou4tech@gmail.com> | ||||
| Date: Fri, 24 Mar 2017 10:36:03 +0800 | ||||
| Subject: [PATCH] Fix invalid sigprocmask call | ||||
|  | ||||
| The POSIX document says | ||||
|  | ||||
|     The pthread_sigmask() and sigprocmask() functions shall fail if: | ||||
|  | ||||
|     [EINVAL] | ||||
|     The value of the how argument is not equal to one of the defined values. | ||||
|  | ||||
| and this is how musl-libc is currently doing.  Fix the call to be safe | ||||
| and correct | ||||
|  | ||||
|  [1] http://pubs.opengroup.org/onlinepubs/9699919799/functions/pthread_sigmask.html | ||||
|  | ||||
| gdb/ChangeLog: | ||||
| 2017-03-24  Yousong Zhou  <yszhou4tech@gmail.com> | ||||
|  | ||||
|     * common/signals-state-save-restore.c (save_original_signals_state): | ||||
|     Fix invalid sigprocmask call. | ||||
| --- | ||||
|  gdb/ChangeLog                           | 5 +++++ | ||||
|  gdb/common/signals-state-save-restore.c | 2 +- | ||||
|  2 files changed, 6 insertions(+), 1 deletion(-) | ||||
|  | ||||
| --- a/gdb/common/signals-state-save-restore.c | ||||
| +++ b/gdb/common/signals-state-save-restore.c | ||||
| @@ -41,7 +41,7 @@ save_original_signals_state (void) | ||||
|    int i; | ||||
|    int res; | ||||
|   | ||||
| -  res = sigprocmask (0,  NULL, &original_signal_mask); | ||||
| +  res = sigprocmask (SIG_BLOCK,  NULL, &original_signal_mask); | ||||
|    if (res == -1) | ||||
|      perror_with_name (("sigprocmask")); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico