mirror of
https://github.com/crosstool-ng/crosstool-ng.git
synced 2025-01-09 06:22:42 +00:00
Move GDB build into a common backend function
... needed to create a common runtime test for an incompatible change in glibc API. Signed-off-by: Alexey Neyman <stilor@att.net>
This commit is contained in:
parent
32af07341d
commit
1e25ebc7e0
@ -4,7 +4,6 @@
|
|||||||
|
|
||||||
source "config/debug/gdb.in.cross"
|
source "config/debug/gdb.in.cross"
|
||||||
source "config/debug/gdb.in.native"
|
source "config/debug/gdb.in.native"
|
||||||
source "config/debug/gdb.in.gdbserver"
|
|
||||||
|
|
||||||
config GDB_HAS_PKGVERSION_BUGURL
|
config GDB_HAS_PKGVERSION_BUGURL
|
||||||
bool
|
bool
|
||||||
@ -32,3 +31,9 @@ config GDB_DEP_CXX11
|
|||||||
def_bool y
|
def_bool y
|
||||||
depends on !CONFIGURE_has_cxx11
|
depends on !CONFIGURE_has_cxx11
|
||||||
select GDB_REQUIRE_older_than_8_0
|
select GDB_REQUIRE_older_than_8_0
|
||||||
|
|
||||||
|
config GDB_HAS_IPA_LIB
|
||||||
|
bool
|
||||||
|
depends on GDB_7_2_or_later
|
||||||
|
default y
|
||||||
|
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
# Menu for the native gdbserver
|
|
||||||
|
|
||||||
config GDB_GDBSERVER
|
|
||||||
bool
|
|
||||||
prompt "gdbserver"
|
|
||||||
default y
|
|
||||||
depends on ! BARE_METAL
|
|
||||||
select LIBC_UCLIBC_WCHAR if LIBC_UCLIBC && GDB_8_0_or_later
|
|
||||||
help
|
|
||||||
Build and install a gdbserver for the target, to run on the target.
|
|
||||||
|
|
||||||
if GDB_GDBSERVER
|
|
||||||
|
|
||||||
config GDB_GDBSERVER_HAS_IPA_LIB
|
|
||||||
bool
|
|
||||||
depends on GDB_7_2_or_later
|
|
||||||
default y
|
|
||||||
|
|
||||||
config GDB_GDBSERVER_STATIC
|
|
||||||
bool
|
|
||||||
prompt "Build a static gdbserver"
|
|
||||||
depends on EXPERIMENTAL
|
|
||||||
help
|
|
||||||
In case you have trouble with dynamic loading of shared libraries,
|
|
||||||
you will find that a static gdbserver comes in handy.
|
|
||||||
|
|
||||||
However, it has been noticed at least on x86 that enabling this
|
|
||||||
option produces an invalid gdbserver binary. It is linked with
|
|
||||||
"-static -Wl,--dynamic-list=..." which
|
|
||||||
# (a) requests invalid program interpreter
|
|
||||||
# (b) crashes glibc/uClibc-ng and does not work with musl
|
|
||||||
# See https://sourceware.org/ml/libc-alpha/2017-03/msg00267.html
|
|
||||||
|
|
||||||
It is possible it would work with other architectures, hence it is
|
|
||||||
not completely removed. Use with care and report to the mailing list
|
|
||||||
if the resulting gdbserver works.
|
|
||||||
|
|
||||||
For further details, see:
|
|
||||||
https://sourceware.org/bugzilla/show_bug.cgi?id=19617
|
|
||||||
https://sourceware.org/bugzilla/show_bug.cgi?id=21086
|
|
||||||
|
|
||||||
config GDB_GDBSERVER_STATIC_LIBSTDCXX
|
|
||||||
bool
|
|
||||||
prompt "Link against static libstdc+++"
|
|
||||||
depends on !GDB_GDBSERVER_STATIC
|
|
||||||
default n
|
|
||||||
help
|
|
||||||
Say 'y' if you do not want gdbserver to require libstdc++.so on the
|
|
||||||
target.
|
|
||||||
|
|
||||||
config GDB_GDBSERVER_BUILD_IPA_LIB
|
|
||||||
bool
|
|
||||||
prompt "Build the IPA library"
|
|
||||||
depends on GDB_GDBSERVER_HAS_IPA_LIB && !GDB_GDBSERVER_STATIC
|
|
||||||
help
|
|
||||||
gdbserver >= 7.2 comes with an optional library to use tracepoints,
|
|
||||||
the In Process Agent (IPA) library, libinproctrace.so.
|
|
||||||
|
|
||||||
Say 'y' if you indend to use tracepoints when debugging your
|
|
||||||
programs with gdbserver.
|
|
||||||
|
|
||||||
Note: Currently, building this library is not possible when the
|
|
||||||
gdbserver is built statically. This is a limitation in
|
|
||||||
crosstool-NG, so do not bug upstream about it...
|
|
||||||
|
|
||||||
endif # GDB_GDBSERVER
|
|
||||||
|
|
||||||
if BARE_METAL
|
|
||||||
comment "In bare-metal, you'll need to "
|
|
||||||
comment "provide your own gdbserver stub."
|
|
||||||
endif # BARE_METAL
|
|
@ -1,4 +1,4 @@
|
|||||||
# Menu for the native GDB
|
# Menu for the native GDB binaries (GDB itself and gdbserver)
|
||||||
|
|
||||||
config GDB_NATIVE
|
config GDB_NATIVE
|
||||||
bool
|
bool
|
||||||
@ -12,11 +12,35 @@ config GDB_NATIVE
|
|||||||
help
|
help
|
||||||
Build and install a native gdb for the target, to run on the target.
|
Build and install a native gdb for the target, to run on the target.
|
||||||
|
|
||||||
if GDB_NATIVE
|
config GDB_GDBSERVER
|
||||||
|
bool
|
||||||
|
prompt "gdbserver"
|
||||||
|
default y
|
||||||
|
depends on ! BARE_METAL
|
||||||
|
select LIBC_UCLIBC_WCHAR if LIBC_UCLIBC && GDB_8_0_or_later
|
||||||
|
help
|
||||||
|
Build and install a gdbserver for the target, to run on the target.
|
||||||
|
|
||||||
|
if GDB_NATIVE || GDB_GDBSERVER
|
||||||
|
|
||||||
|
config GDB_NATIVE_BUILD_IPA_LIB
|
||||||
|
bool
|
||||||
|
prompt "Build the IPA library"
|
||||||
|
depends on GDB_HAS_IPA_LIB && !GDB_NATIVE_STATIC
|
||||||
|
help
|
||||||
|
gdbserver >= 7.2 comes with an optional library to use tracepoints,
|
||||||
|
the In Process Agent (IPA) library, libinproctrace.so.
|
||||||
|
|
||||||
|
Say 'y' if you intend to use tracepoints when debugging your
|
||||||
|
programs with gdbserver.
|
||||||
|
|
||||||
|
Note: Currently, building this library is not possible when the
|
||||||
|
gdbserver is built statically. This is a limitation in
|
||||||
|
crosstool-NG, so do not bug upstream about it...
|
||||||
|
|
||||||
config GDB_NATIVE_STATIC
|
config GDB_NATIVE_STATIC
|
||||||
bool
|
bool
|
||||||
prompt "Build a static native gdb"
|
prompt "Build a static gdb binaries"
|
||||||
depends on EXPERIMENTAL
|
depends on EXPERIMENTAL
|
||||||
help
|
help
|
||||||
In case you have trouble with dynamic loading of shared libraries,
|
In case you have trouble with dynamic loading of shared libraries,
|
||||||
@ -31,10 +55,24 @@ config GDB_NATIVE_STATIC
|
|||||||
|
|
||||||
It is possible it would work with other architectures, hence it is
|
It is possible it would work with other architectures, hence it is
|
||||||
not completely removed. Use with care and report to the mailing list
|
not completely removed. Use with care and report to the mailing list
|
||||||
if the resulting gdbserver works.
|
if the resulting binaries work.
|
||||||
|
|
||||||
For further details, see:
|
For further details, see:
|
||||||
https://sourceware.org/bugzilla/show_bug.cgi?id=19617
|
https://sourceware.org/bugzilla/show_bug.cgi?id=19617
|
||||||
https://sourceware.org/bugzilla/show_bug.cgi?id=21086
|
https://sourceware.org/bugzilla/show_bug.cgi?id=21086
|
||||||
|
|
||||||
|
config GDB_NATIVE_STATIC_LIBSTDCXX
|
||||||
|
bool
|
||||||
|
prompt "Link against static libstdc+++"
|
||||||
|
depends on !GDB_NATIVE_STATIC
|
||||||
|
default n
|
||||||
|
help
|
||||||
|
Say 'y' if you do not want gdbserver to require libstdc++.so on the
|
||||||
|
target.
|
||||||
|
|
||||||
endif # GDB_NATIVE
|
endif # GDB_NATIVE
|
||||||
|
|
||||||
|
if BARE_METAL
|
||||||
|
comment "In bare-metal, you'll need to "
|
||||||
|
comment "provide your own gdbserver stub."
|
||||||
|
endif # BARE_METAL
|
||||||
|
2
ct-ng.in
2
ct-ng.in
@ -41,7 +41,7 @@ export CT_VCHECK=
|
|||||||
# need to pass it to the upgrade script - which may receive an input that
|
# need to pass it to the upgrade script - which may receive an input that
|
||||||
# was not preprocessed by kconfig, and hence have no string for "up-to-date"
|
# was not preprocessed by kconfig, and hence have no string for "up-to-date"
|
||||||
# version.
|
# version.
|
||||||
export CT_CONFIG_VERSION_CURRENT=2
|
export CT_CONFIG_VERSION_CURRENT=3
|
||||||
|
|
||||||
# Download agents used by scripts.mk
|
# Download agents used by scripts.mk
|
||||||
CT_WGET := @wget@
|
CT_WGET := @wget@
|
||||||
|
43
packages/gdb/7.11.1/0004-include-order.patch
vendored
Normal file
43
packages/gdb/7.11.1/0004-include-order.patch
vendored
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
commit 5a6c3296a7a90694ad4042f6256f3da6d4fa4ee8
|
||||||
|
Author: James Clarke <jrtc27@jrtc27.com>
|
||||||
|
Date: Fri Jan 19 17:22:49 2018 +0000
|
||||||
|
|
||||||
|
gdb: Fix ia64 defining TRAP_HWBKPT before including gdb_wait.h
|
||||||
|
|
||||||
|
On ia64, gdb_wait.h eventually includes siginfo-consts-arch.h, which
|
||||||
|
contains an enum with TRAP_HWBKPT, along with a #define. Thus we cannot
|
||||||
|
define TRAP_HWBKPT to 4 beforehand, and so gdb_wait.h must be included
|
||||||
|
earlier; include it from linux-ptrace.h so it can never come afterwards.
|
||||||
|
|
||||||
|
gdb/ChangeLog:
|
||||||
|
|
||||||
|
* nat/linux-ptrace.c: Remove unnecessary reinclusion of
|
||||||
|
gdb_ptrace.h, and move including gdb_wait.h ...
|
||||||
|
* nat/linux-ptrace.h: ... to here.
|
||||||
|
|
||||||
|
---
|
||||||
|
gdb/nat/linux-ptrace.c | 2 --
|
||||||
|
gdb/nat/linux-ptrace.h | 1 +
|
||||||
|
2 files changed, 1 insertion(+), 2 deletions(-)
|
||||||
|
|
||||||
|
--- a/gdb/nat/linux-ptrace.c
|
||||||
|
+++ b/gdb/nat/linux-ptrace.c
|
||||||
|
@@ -21,8 +21,6 @@
|
||||||
|
#include "linux-procfs.h"
|
||||||
|
#include "linux-waitpid.h"
|
||||||
|
#include "buffer.h"
|
||||||
|
-#include "gdb_wait.h"
|
||||||
|
-#include "gdb_ptrace.h"
|
||||||
|
|
||||||
|
/* Stores the ptrace options supported by the running kernel.
|
||||||
|
A value of -1 means we did not check for features yet. A value
|
||||||
|
--- a/gdb/nat/linux-ptrace.h
|
||||||
|
+++ b/gdb/nat/linux-ptrace.h
|
||||||
|
@@ -21,6 +21,7 @@
|
||||||
|
struct buffer;
|
||||||
|
|
||||||
|
#include "nat/gdb_ptrace.h"
|
||||||
|
+#include "gdb_wait.h"
|
||||||
|
|
||||||
|
#ifdef __UCLIBC__
|
||||||
|
#if !(defined(__UCLIBC_HAS_MMU__) || defined(__ARCH_HAS_MMU__))
|
@ -125,7 +125,7 @@ do_ncurses_backend() {
|
|||||||
for arg in "$@"; do
|
for arg in "$@"; do
|
||||||
case "$arg" in
|
case "$arg" in
|
||||||
--*)
|
--*)
|
||||||
ncurses_opts+=("$arg")
|
ncurses_opts+=("${arg}")
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
eval "${arg// /\\ }"
|
eval "${arg// /\\ }"
|
||||||
|
@ -1,67 +1,33 @@
|
|||||||
# Build script for the gdb debug facility
|
# Build script for the gdb debug facility
|
||||||
|
|
||||||
do_debug_gdb_get() {
|
do_debug_gdb_get()
|
||||||
|
{
|
||||||
CT_Fetch GDB
|
CT_Fetch GDB
|
||||||
}
|
}
|
||||||
|
|
||||||
do_debug_gdb_extract() {
|
do_debug_gdb_extract()
|
||||||
|
{
|
||||||
CT_ExtractPatch GDB
|
CT_ExtractPatch GDB
|
||||||
|
|
||||||
|
# Workaround for bad versions, where the configure
|
||||||
|
# script for gdbserver is not executable...
|
||||||
|
# Bah, GNU folks strike again... :-(
|
||||||
|
chmod a+x "${CT_SRC_DIR}/gdb/gdb/gdbserver/configure"
|
||||||
}
|
}
|
||||||
|
|
||||||
do_debug_gdb_build() {
|
do_debug_gdb_build()
|
||||||
local -a extra_config
|
{
|
||||||
|
|
||||||
# These variables should be global and shared between all packages.
|
|
||||||
local CT_TARGET_CPP="${CT_TARGET}-cpp"
|
|
||||||
local CT_TARGET_CC="${CT_TARGET}-gcc"
|
|
||||||
local CT_TARGET_CXX="${CT_TARGET}-g++"
|
|
||||||
local CT_TARGET_LD="${CT_TARGET}-ld"
|
|
||||||
local CT_HOST_CPP="${CT_HOST}-cpp"
|
|
||||||
local CT_HOST_CC="${CT_HOST}-gcc"
|
|
||||||
local CT_HOST_CXX="${CT_HOST}-g++"
|
|
||||||
local CT_HOST_LD="${CT_HOST}-ld"
|
|
||||||
|
|
||||||
gdb_src_dir="${CT_SRC_DIR}/gdb"
|
|
||||||
|
|
||||||
if [ "${CT_GDB_HAS_PKGVERSION_BUGURL}" = "y" ]; then
|
|
||||||
[ -n "${CT_PKGVERSION}" ] && extra_config+=("--with-pkgversion=${CT_PKGVERSION}")
|
|
||||||
[ -n "${CT_TOOLCHAIN_BUGURL}" ] && extra_config+=("--with-bugurl=${CT_TOOLCHAIN_BUGURL}")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "${CT_GDB_CROSS}" = "y" ]; then
|
if [ "${CT_GDB_CROSS}" = "y" ]; then
|
||||||
local -a cross_extra_config
|
|
||||||
local gcc_version p _p
|
local gcc_version p _p
|
||||||
local cross_CFLAGS cross_LDFLAGS
|
local -a cross_extra_config
|
||||||
|
|
||||||
CT_DoStep INFO "Installing cross-gdb"
|
CT_DoStep INFO "Installing cross-gdb"
|
||||||
CT_DoLog EXTRA "Configuring cross-gdb"
|
|
||||||
|
cross_extra_config=( "${CT_GDB_CROSS_EXTRA_CONFIG_ARRAY[@]}" )
|
||||||
|
|
||||||
mkdir -p "${CT_BUILD_DIR}/build-gdb-cross"
|
mkdir -p "${CT_BUILD_DIR}/build-gdb-cross"
|
||||||
cd "${CT_BUILD_DIR}/build-gdb-cross"
|
cd "${CT_BUILD_DIR}/build-gdb-cross"
|
||||||
|
|
||||||
cross_extra_config=("${extra_config[@]}")
|
|
||||||
|
|
||||||
if [ "${CT_GDB_HAS_DISABLE_CXX_BUILD}" = "y" ]; then
|
|
||||||
cross_extra_config+=("--disable-build-with-cxx")
|
|
||||||
fi
|
|
||||||
|
|
||||||
# For gdb-cross this combination of flags forces
|
|
||||||
# gdb configure to fall back to default '-lexpat' flag
|
|
||||||
# which is acceptable.
|
|
||||||
#
|
|
||||||
# NOTE: DO NOT USE --with-libexpat-prefix (until GDB configure is smarter)!!!
|
|
||||||
# It conflicts with a static build: GDB's configure script will find the shared
|
|
||||||
# version of expat and will attempt to link that, despite the -static flag.
|
|
||||||
# The link will fail, and configure will abort with "expat missing or unusable"
|
|
||||||
# message.
|
|
||||||
cross_extra_config+=("--with-expat")
|
|
||||||
cross_extra_config+=("--without-libexpat-prefix")
|
|
||||||
|
|
||||||
case "${CT_THREADS}" in
|
|
||||||
none) cross_extra_config+=("--disable-threads");;
|
|
||||||
*) cross_extra_config+=("--enable-threads");;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ "${CT_GDB_CROSS_PYTHON}" = "y" ]; then
|
if [ "${CT_GDB_CROSS_PYTHON}" = "y" ]; then
|
||||||
if [ -z "${CT_GDB_CROSS_PYTHON_BINARY}" ]; then
|
if [ -z "${CT_GDB_CROSS_PYTHON_BINARY}" ]; then
|
||||||
if [ "${CT_CANADIAN}" = "y" -o "${CT_CROSS_NATIVE}" = "y" ]; then
|
if [ "${CT_CANADIAN}" = "y" -o "${CT_CROSS_NATIVE}" = "y" ]; then
|
||||||
@ -84,18 +50,6 @@ do_debug_gdb_build() {
|
|||||||
cross_extra_config+=("--disable-sim")
|
cross_extra_config+=("--disable-sim")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${CT_TOOLCHAIN_ENABLE_NLS}" != "y" ]; then
|
|
||||||
cross_extra_config+=("--disable-nls")
|
|
||||||
fi
|
|
||||||
|
|
||||||
cross_CFLAGS="${CT_CFLAGS_FOR_HOST}"
|
|
||||||
cross_LDFLAGS="${CT_LDFLAGS_FOR_HOST}"
|
|
||||||
|
|
||||||
if [ "${CT_GDB_CROSS_STATIC}" = "y" ]; then
|
|
||||||
cross_CFLAGS+=" -static"
|
|
||||||
cross_LDFLAGS+=" -static"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ${CT_HOST}-gcc --version 2>&1 | grep clang; then
|
if ${CT_HOST}-gcc --version 2>&1 | grep clang; then
|
||||||
# clang detects the line from gettext's _ macro as format string
|
# clang detects the line from gettext's _ macro as format string
|
||||||
# not being a string literal and produces a lot of warnings - which
|
# not being a string literal and produces a lot of warnings - which
|
||||||
@ -104,45 +58,15 @@ do_debug_gdb_build() {
|
|||||||
cross_extra_config+=("--enable-build-warnings=,-Wno-format-nonliteral,-Wno-format-security")
|
cross_extra_config+=("--enable-build-warnings=,-Wno-format-nonliteral,-Wno-format-security")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Fix up whitespace. Some older GDB releases (e.g. 6.8a) get confused if there
|
do_gdb_backend \
|
||||||
# are multiple consecutive spaces: sub-configure scripts replace them with a
|
buildtype=cross \
|
||||||
# single space and then complain that $CC value changed from that in
|
host="${CT_HOST}" \
|
||||||
# the master directory.
|
cflags="${CT_CFLAGS_FOR_HOST}" \
|
||||||
cross_CFLAGS=`echo ${cross_CFLAGS}`
|
ldflags="${CT_LDFLAGS_FOR_HOST}" \
|
||||||
cross_LDFLAGS=`echo ${cross_LDFLAGS}`
|
prefix="${CT_PREFIX_DIR}" \
|
||||||
|
static="${CT_GDB_CROSS_STATIC}" \
|
||||||
# Disable binutils options when building from the binutils-gdb repo.
|
|
||||||
cross_extra_config+=("--disable-binutils")
|
|
||||||
cross_extra_config+=("--disable-ld")
|
|
||||||
cross_extra_config+=("--disable-gas")
|
|
||||||
|
|
||||||
CT_DoLog DEBUG "Extra config passed: '${cross_extra_config[*]}'"
|
|
||||||
|
|
||||||
CT_DoExecLog CFG \
|
|
||||||
CPP="${CT_HOST_CPP}" \
|
|
||||||
CC="${CT_HOST_CC}" \
|
|
||||||
CXX="${CT_HOST_CXX}" \
|
|
||||||
LD="${CT_HOST_LD}" \
|
|
||||||
CFLAGS="${cross_CFLAGS}" \
|
|
||||||
CXXFLAGS="${cross_CFLAGS}" \
|
|
||||||
LDFLAGS="${cross_LDFLAGS}" \
|
|
||||||
${CONFIG_SHELL} \
|
|
||||||
"${gdb_src_dir}/configure" \
|
|
||||||
--build=${CT_BUILD} \
|
|
||||||
--host=${CT_HOST} \
|
|
||||||
--target=${CT_TARGET} \
|
|
||||||
--prefix="${CT_PREFIX_DIR}" \
|
|
||||||
--with-build-sysroot="${CT_SYSROOT_DIR}" \
|
|
||||||
--with-sysroot="${CT_SYSROOT_DIR}" \
|
--with-sysroot="${CT_SYSROOT_DIR}" \
|
||||||
--disable-werror \
|
"${cross_extra_config[@]}"
|
||||||
"${cross_extra_config[@]}" \
|
|
||||||
"${CT_GDB_CROSS_EXTRA_CONFIG_ARRAY[@]}"
|
|
||||||
|
|
||||||
CT_DoLog EXTRA "Building cross-gdb"
|
|
||||||
CT_DoExecLog ALL make ${JOBSFLAGS}
|
|
||||||
|
|
||||||
CT_DoLog EXTRA "Installing cross-gdb"
|
|
||||||
CT_DoExecLog ALL make install
|
|
||||||
|
|
||||||
if [ "${CT_BUILD_MANUALS}" = "y" ]; then
|
if [ "${CT_BUILD_MANUALS}" = "y" ]; then
|
||||||
CT_DoLog EXTRA "Building and installing the cross-GDB manuals"
|
CT_DoLog EXTRA "Building and installing the cross-GDB manuals"
|
||||||
@ -171,32 +95,108 @@ do_debug_gdb_build() {
|
|||||||
CT_EndStep
|
CT_EndStep
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# TBD combine GDB native and gdbserver backends, build either or both in a single pass.
|
if [ "${CT_GDB_NATIVE}" = "y" -o "${CT_GDB_GDBSERVER}" = "y" ]; then
|
||||||
if [ "${CT_GDB_NATIVE}" = "y" ]; then
|
|
||||||
local -a native_extra_config
|
local -a native_extra_config
|
||||||
local native_CFLAGS native_LDFLAGS
|
local subdir
|
||||||
|
|
||||||
CT_DoStep INFO "Installing native gdb"
|
CT_DoStep INFO "Installing native gdb"
|
||||||
CT_DoLog EXTRA "Configuring native gdb"
|
|
||||||
|
|
||||||
mkdir -p "${CT_BUILD_DIR}/build-gdb-native"
|
mkdir -p "${CT_BUILD_DIR}/build-gdb-native"
|
||||||
cd "${CT_BUILD_DIR}/build-gdb-native"
|
cd "${CT_BUILD_DIR}/build-gdb-native"
|
||||||
|
|
||||||
native_extra_config=("${extra_config[@]}")
|
|
||||||
|
|
||||||
# We may not have C++ language configured for target
|
|
||||||
if [ "${CT_GDB_HAS_DISABLE_CXX_BUILD}" = "y" ]; then
|
|
||||||
native_extra_config+=("--disable-build-with-cxx")
|
|
||||||
fi
|
|
||||||
|
|
||||||
# GDB on Mingw depends on PDcurses, not ncurses
|
# GDB on Mingw depends on PDcurses, not ncurses
|
||||||
if [ "${CT_MINGW32}" != "y" ]; then
|
if [ "${CT_MINGW32}" != "y" ]; then
|
||||||
native_extra_config+=("--with-curses")
|
native_extra_config+=("--with-curses")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Build a native gdbserver later if required.
|
# Build a native gdbserver if needed. If building only
|
||||||
|
# gdbserver, configure in the subdirectory.
|
||||||
# Newer versions enable it automatically for a native target by default.
|
# Newer versions enable it automatically for a native target by default.
|
||||||
native_extra_config+=("--enable-gdbserver=no")
|
if [ "${CT_GDB_GDBSERVER}" != "y" ]; then
|
||||||
|
native_extra_config+=("--disable-gdbserver")
|
||||||
|
else
|
||||||
|
native_extra_config+=("--enable-gdbserver")
|
||||||
|
if [ "${CT_GDB_NATIVE_BUILD_IPA_LIB}" = "y" ]; then
|
||||||
|
gdbserver_extra_config+=("--enable-inprocess-agent")
|
||||||
|
else
|
||||||
|
gdbserver_extra_config+=("--disable-inprocess-agent")
|
||||||
|
fi
|
||||||
|
if [ "${CT_GDB_NATIVE}" != "y" ]; then
|
||||||
|
subdir=gdbserver/
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
export ac_cv_func_strncmp_works=yes
|
||||||
|
|
||||||
|
# TBD do we need all these? Eg why do we disable TUI if we build curses for target?
|
||||||
|
native_extra_config+=(
|
||||||
|
--without-uiout
|
||||||
|
--disable-tui
|
||||||
|
--disable-gdbtk
|
||||||
|
--without-x
|
||||||
|
--disable-sim
|
||||||
|
--without-included-gettext
|
||||||
|
--without-develop
|
||||||
|
--sysconfdir=/etc
|
||||||
|
--localstatedir=/var
|
||||||
|
)
|
||||||
|
|
||||||
|
do_gdb_backend \
|
||||||
|
buildtype=native \
|
||||||
|
subdir=${subdir} \
|
||||||
|
host="${CT_TARGET}" \
|
||||||
|
cflags="${CT_ALL_TARGET_CFLAGS}" \
|
||||||
|
ldflags="${CT_ALL_TARGET_LDFLAGS}" \
|
||||||
|
static="${CT_GDB_NATIVE_STATIC}" \
|
||||||
|
static_libstdc="${CT_GDB_NATIVE_STATIC_LIBSTDC}" \
|
||||||
|
prefix=/usr \
|
||||||
|
destdir="${CT_DEBUGROOT_DIR}" \
|
||||||
|
"${native_extra_config[@]}"
|
||||||
|
|
||||||
|
unset ac_cv_func_strncmp_works
|
||||||
|
|
||||||
|
CT_EndStep # native gdb build
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
do_gdb_backend()
|
||||||
|
{
|
||||||
|
local host prefix destdir cflags ldflags static buildtype subdir
|
||||||
|
local -a extra_config
|
||||||
|
|
||||||
|
for arg in "$@"; do
|
||||||
|
case "$arg" in
|
||||||
|
--*)
|
||||||
|
extra_config+=("${arg}")
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
eval "${arg// /\\ }"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ "${CT_GDB_HAS_PKGVERSION_BUGURL}" = "y" ]; then
|
||||||
|
[ -n "${CT_PKGVERSION}" ] && extra_config+=("--with-pkgversion=${CT_PKGVERSION}")
|
||||||
|
[ -n "${CT_TOOLCHAIN_BUGURL}" ] && extra_config+=("--with-bugurl=${CT_TOOLCHAIN_BUGURL}")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Disable binutils options when building from the binutils-gdb repo.
|
||||||
|
extra_config+=("--disable-binutils")
|
||||||
|
extra_config+=("--disable-ld")
|
||||||
|
extra_config+=("--disable-gas")
|
||||||
|
|
||||||
|
if [ "${CT_GDB_HAS_DISABLE_CXX_BUILD}" = "y" ]; then
|
||||||
|
extra_config+=("--disable-build-with-cxx")
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "${CT_THREADS}" in
|
||||||
|
none) extra_config+=("--disable-threads");;
|
||||||
|
*) extra_config+=("--enable-threads");;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ "${CT_TOOLCHAIN_ENABLE_NLS}" != "y" ]; then
|
||||||
|
extra_config+=("--disable-nls")
|
||||||
|
fi
|
||||||
|
|
||||||
# Target libexpat resides in sysroot and does not have
|
# Target libexpat resides in sysroot and does not have
|
||||||
# any dependencies, so just passing '-lexpat' to gcc is enough.
|
# any dependencies, so just passing '-lexpat' to gcc is enough.
|
||||||
@ -214,163 +214,51 @@ do_debug_gdb_build() {
|
|||||||
# version of expat and will attempt to link that, despite the -static flag.
|
# version of expat and will attempt to link that, despite the -static flag.
|
||||||
# The link will fail, and configure will abort with "expat missing or unusable"
|
# The link will fail, and configure will abort with "expat missing or unusable"
|
||||||
# message.
|
# message.
|
||||||
native_extra_config+=("--with-expat")
|
extra_config+=("--with-expat")
|
||||||
native_extra_config+=("--without-libexpat-prefix")
|
extra_config+=("--without-libexpat-prefix")
|
||||||
|
|
||||||
case "${CT_THREADS}" in
|
if [ "${static}" = "y" ]; then
|
||||||
none) native_extra_config+=("--disable-threads");;
|
cflags+=" -static"
|
||||||
*) native_extra_config+=("--enable-threads");;
|
ldflags+=" -static"
|
||||||
esac
|
fi
|
||||||
|
if [ "${static_libstdc}" = "y" ]; then
|
||||||
if [ "${CT_TOOLCHAIN_ENABLE_NLS}" != "y" ]; then
|
ldflags+=" -static-libstdc++"
|
||||||
native_extra_config+=("--disable-nls")
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
native_CFLAGS="${CT_ALL_TARGET_CFLAGS}"
|
|
||||||
native_LDFLAGS="${CT_ALL_TARGET_LDFLAGS}"
|
|
||||||
|
|
||||||
if [ "${CT_GDB_NATIVE_STATIC}" = "y" ]; then
|
# Fix up whitespace. Some older GDB releases (e.g. 6.8a) get confused if there
|
||||||
native_CFLAGS+=" -static"
|
# are multiple consecutive spaces: sub-configure scripts replace them with a
|
||||||
native_LDFLAGS+=" -static"
|
# single space and then complain that $CC value changed from that in
|
||||||
fi
|
# the master directory.
|
||||||
|
cflags=`echo ${cflags}`
|
||||||
|
ldflags=`echo ${ldflags}`
|
||||||
|
|
||||||
export ac_cv_func_strncmp_works=yes
|
CT_DoLog EXTRA "Configuring ${buildtype} gdb"
|
||||||
|
CT_DoLog DEBUG "Extra config passed: '${extra_config[*]}'"
|
||||||
# Disable binutils options when building from the binutils-gdb repo.
|
|
||||||
native_extra_config+=("--disable-binutils")
|
|
||||||
native_extra_config+=("--disable-ld")
|
|
||||||
native_extra_config+=("--disable-gas")
|
|
||||||
|
|
||||||
native_CFLAGS=`echo ${native_CFLAGS}`
|
|
||||||
native_LDFLAGS=`echo ${native_LDFLAGS}`
|
|
||||||
|
|
||||||
CT_DoLog DEBUG "Extra config passed: '${native_extra_config[*]}'"
|
|
||||||
|
|
||||||
|
# TBD: is passing CPP/CC/CXX/LD needed? GCC should be determining this automatically from the triplets
|
||||||
CT_DoExecLog CFG \
|
CT_DoExecLog CFG \
|
||||||
CPP="${CT_TARGET_CPP}" \
|
CPP="${host}-cpp" \
|
||||||
CC="${CT_TARGET_CC}" \
|
CC="${host}-gcc" \
|
||||||
CXX="${CT_TARGET_CXX}" \
|
CXX="${host}-g++" \
|
||||||
LD="${CT_TARGET_LD}" \
|
LD="${host}-ld" \
|
||||||
CFLAGS="${native_CFLAGS}" \
|
CFLAGS="${cflags}" \
|
||||||
CXXFLAGS="${native_CFLAGS}" \
|
CXXFLAGS="${cflags}" \
|
||||||
LDFLAGS="${native_LDFLAGS}" \
|
LDFLAGS="${ldflags}" \
|
||||||
${CONFIG_SHELL} \
|
${CONFIG_SHELL} \
|
||||||
"${gdb_src_dir}/configure" \
|
"${CT_SRC_DIR}/gdb/${subdir}configure" \
|
||||||
--build=${CT_BUILD} \
|
--build=${CT_BUILD} \
|
||||||
--host=${CT_TARGET} \
|
--host=${host} \
|
||||||
--target=${CT_TARGET} \
|
--target=${CT_TARGET} \
|
||||||
--prefix=/usr \
|
--prefix="${prefix}" \
|
||||||
--with-build-sysroot="${CT_SYSROOT_DIR}" \
|
--with-build-sysroot="${CT_SYSROOT_DIR}" \
|
||||||
--without-uiout \
|
--includedir="${CT_HEADERS_DIR}" \
|
||||||
--disable-tui \
|
|
||||||
--disable-gdbtk \
|
|
||||||
--without-x \
|
|
||||||
--disable-sim \
|
|
||||||
--disable-werror \
|
--disable-werror \
|
||||||
--without-included-gettext \
|
"${extra_config[@]}" \
|
||||||
--without-develop \
|
|
||||||
"${native_extra_config[@]}"
|
|
||||||
|
|
||||||
CT_DoLog EXTRA "Building native gdb"
|
CT_DoLog EXTRA "Building ${buildtype} gdb"
|
||||||
CT_DoExecLog ALL make ${JOBSFLAGS}
|
CT_DoExecLog ALL make ${JOBSFLAGS}
|
||||||
|
|
||||||
CT_DoLog EXTRA "Installing native gdb"
|
CT_DoLog EXTRA "Installing ${buildtype} gdb"
|
||||||
CT_DoExecLog ALL make DESTDIR="${CT_DEBUGROOT_DIR}" install
|
CT_DoExecLog ALL make install ${destdir:+DESTDIR="${destdir}"}
|
||||||
|
|
||||||
# Building a native gdb also builds a gdbserver
|
|
||||||
find "${CT_DEBUGROOT_DIR}" -type f -name gdbserver -exec rm -fv {} \; 2>&1 |CT_DoLog ALL
|
|
||||||
|
|
||||||
unset ac_cv_func_strncmp_works
|
|
||||||
|
|
||||||
CT_EndStep # native gdb build
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "${CT_GDB_GDBSERVER}" = "y" ]; then
|
|
||||||
local -a gdbserver_extra_config
|
|
||||||
local gdbserver_CFLAGS gdbserver_LDFLAGS
|
|
||||||
|
|
||||||
CT_DoStep INFO "Installing gdbserver"
|
|
||||||
CT_DoLog EXTRA "Configuring gdbserver"
|
|
||||||
|
|
||||||
mkdir -p "${CT_BUILD_DIR}/build-gdb-gdbserver"
|
|
||||||
cd "${CT_BUILD_DIR}/build-gdb-gdbserver"
|
|
||||||
|
|
||||||
# Workaround for bad versions, where the configure
|
|
||||||
# script for gdbserver is not executable...
|
|
||||||
# Bah, GNU folks strike again... :-(
|
|
||||||
chmod a+x "${gdb_src_dir}/gdb/gdbserver/configure"
|
|
||||||
|
|
||||||
gdbserver_extra_config=("${extra_config[@]}")
|
|
||||||
|
|
||||||
# We may not have C++ language configured for target
|
|
||||||
if [ "${CT_GDB_HAS_DISABLE_CXX_BUILD}" = "y" ]; then
|
|
||||||
gdbserver_extra_config+=("--disable-build-with-cxx")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "${CT_GDB_GDBSERVER_HAS_IPA_LIB}" = "y" ]; then
|
|
||||||
if [ "${CT_GDB_GDBSERVER_BUILD_IPA_LIB}" = "y" ]; then
|
|
||||||
gdbserver_extra_config+=("--enable-inprocess-agent")
|
|
||||||
else
|
|
||||||
gdbserver_extra_config+=("--disable-inprocess-agent")
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Disable binutils options when building from the binutils-gdb repo.
|
|
||||||
gdbserver_extra_config+=("--disable-binutils")
|
|
||||||
gdbserver_extra_config+=("--disable-ld")
|
|
||||||
gdbserver_extra_config+=("--disable-gas")
|
|
||||||
|
|
||||||
gdbserver_CFLAGS="${CT_ALL_TARGET_CFLAGS}"
|
|
||||||
gdbserver_LDFLAGS="${CT_ALL_TARGET_LDFLAGS}"
|
|
||||||
|
|
||||||
if [ "${CT_GDB_GDBSERVER_STATIC}" = "y" ]; then
|
|
||||||
gdbserver_CFLAGS+=" -static"
|
|
||||||
gdbserver_LDFLAGS+=" -static"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "${CT_GDB_GDBSERVER_STATIC_LIBSTDCXX}" = "y" ]; then
|
|
||||||
gdbserver_LDFLAGS+=" -static-libstdc++"
|
|
||||||
fi
|
|
||||||
|
|
||||||
gdbserver_CFLAGS=`echo ${gdbserver_CFLAGS}`
|
|
||||||
gdbserver_LDFLAGS=`echo ${gdbserver_LDFLAGS}`
|
|
||||||
|
|
||||||
CT_DoLog DEBUG "Extra config passed: '${gdbserver_extra_config[*]}'"
|
|
||||||
|
|
||||||
CT_DoExecLog CFG \
|
|
||||||
CPP="${CT_TARGET_CPP}" \
|
|
||||||
CC="${CT_TARGET_CC}" \
|
|
||||||
CXX="${CT_TARGET_CXX}" \
|
|
||||||
LD="${CT_TARGET_LD}" \
|
|
||||||
CFLAGS="${gdbserver_CFLAGS}" \
|
|
||||||
CXXFLAGS="${gdbserver_CFLAGS}" \
|
|
||||||
LDFLAGS="${gdbserver_LDFLAGS}" \
|
|
||||||
${CONFIG_SHELL} \
|
|
||||||
"${gdb_src_dir}/gdb/gdbserver/configure" \
|
|
||||||
--build=${CT_BUILD} \
|
|
||||||
--host=${CT_TARGET} \
|
|
||||||
--target=${CT_TARGET} \
|
|
||||||
--prefix=/usr \
|
|
||||||
--sysconfdir=/etc \
|
|
||||||
--localstatedir=/var \
|
|
||||||
--includedir="${CT_HEADERS_DIR}" \
|
|
||||||
--with-build-sysroot="${CT_SYSROOT_DIR}" \
|
|
||||||
--program-prefix= \
|
|
||||||
--without-uiout \
|
|
||||||
--disable-tui \
|
|
||||||
--disable-gdbtk \
|
|
||||||
--without-x \
|
|
||||||
--without-included-gettext \
|
|
||||||
--without-develop \
|
|
||||||
--disable-werror \
|
|
||||||
"${gdbserver_extra_config[@]}"
|
|
||||||
|
|
||||||
CT_DoLog EXTRA "Building gdbserver"
|
|
||||||
CT_DoExecLog ALL make ${JOBSFLAGS} CC=${CT_TARGET}-${CT_CC}
|
|
||||||
|
|
||||||
CT_DoLog EXTRA "Installing gdbserver"
|
|
||||||
CT_DoExecLog ALL make DESTDIR="${CT_DEBUGROOT_DIR}" install
|
|
||||||
|
|
||||||
CT_EndStep
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
25
scripts/upgrade/v2
Normal file
25
scripts/upgrade/v2
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
# vim: set filetype=sh :
|
||||||
|
|
||||||
|
# Upgrade v2 -> v3: unified build of native gdb and gdbserver,
|
||||||
|
# combining their options
|
||||||
|
upgrade()
|
||||||
|
{
|
||||||
|
case "${opt}" in
|
||||||
|
CT_GDB_GDBSERVER_BUILD_IPA_LIB)
|
||||||
|
replace CT_GDB_NATIVE_BUILD_IPA_LIB
|
||||||
|
;;
|
||||||
|
CT_GDB_GDBSERVER_STATIC)
|
||||||
|
if [ "${CT_GDB_GDBSERVER_STATIC}" != "${CT_GDB_GDBSERVER_STATIC}" ]; then
|
||||||
|
warning "Both native gdb and gdbserver must now be built in the same way"
|
||||||
|
fi
|
||||||
|
unset opt
|
||||||
|
;;
|
||||||
|
CT_GDB_GDBSERVER_STATIC_LIBSTDCXX)
|
||||||
|
replace GDB_NATIVE_STATIC_LIBSTDCXX
|
||||||
|
;;
|
||||||
|
CT_GDB_GDBSERVER_HAS_IPA_LIB)
|
||||||
|
# not user-selectable
|
||||||
|
unset opt
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
2562
testing/upgrade/kconfig-list/3
Normal file
2562
testing/upgrade/kconfig-list/3
Normal file
File diff suppressed because it is too large
Load Diff
@ -117,20 +117,29 @@ curver=`sed -n 's,export CT_CONFIG_VERSION_CURRENT=,,p' ${CTNG}`
|
|||||||
if [ -z "${curver}" ]; then
|
if [ -z "${curver}" ]; then
|
||||||
echo "Cannot determine config version" >&${LOG}
|
echo "Cannot determine config version" >&${LOG}
|
||||||
fail
|
fail
|
||||||
elif [ ! -r "kconfig-list/${curver}" ]; then
|
|
||||||
echo "No saved kconfig data for version ${curver}" >&${LOG}
|
|
||||||
fail
|
|
||||||
else
|
else
|
||||||
grep -hr '^\(menu\)\?config ' "${dirs[@]}" ../../config | \
|
grep -hr '^\(menu\)\?config ' "${dirs[@]}" ../../config | \
|
||||||
grep -v '^Binary ' | \
|
grep -v '^Binary ' | \
|
||||||
sed 's,^.* ,CT_,' | LANG=C sort | uniq > logs/current-kconfig-list
|
sed 's,^.* ,CT_,' | LANG=C sort | uniq > logs/current-kconfig-list
|
||||||
|
if [ ! -r "kconfig-list/${curver}" ]; then
|
||||||
|
echo "No saved kconfig data for version ${curver}" >&${LOG}
|
||||||
|
if [ -r "kconfig-list/$[ curver - 1 ]" ]; then
|
||||||
|
echo "Comparing with previous version $[ curver - 1 ]"
|
||||||
|
echo "Verify that the following options are handled:"
|
||||||
|
diff -U 10000 "kconfig-list/$[ curver - 1 ]" logs/current-kconfig-list | \
|
||||||
|
grep '^-CT_' || true
|
||||||
|
echo "Then rename logs/current-kconfig-list to kconfig-list/${curver}"
|
||||||
|
fi >&${LOG}
|
||||||
|
fail
|
||||||
|
else
|
||||||
diff -U 10000 "kconfig-list/${curver}" logs/current-kconfig-list | \
|
diff -U 10000 "kconfig-list/${curver}" logs/current-kconfig-list | \
|
||||||
grep '^-CT_' > logs/current-kconfig-retired || true
|
grep '^-CT_' > logs/current-kconfig-retired || true
|
||||||
nretired=`wc -l logs/current-kconfig-retired | sed 's/ .*//'`
|
nretired=`wc -l logs/current-kconfig-retired | sed 's/ .*//'`
|
||||||
echo "${nretired} kconfig options have been removed without bumping the config version" >&${LOG}
|
|
||||||
if [ "${nretired}" != "0" ]; then
|
if [ "${nretired}" != "0" ]; then
|
||||||
|
echo "${nretired} kconfig options have been removed without bumping the config version" >&${LOG}
|
||||||
fail
|
fail
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
finish
|
finish
|
||||||
exec {LOG}>&-
|
exec {LOG}>&-
|
||||||
|
Loading…
Reference in New Issue
Block a user