[PATCH] debug/cross-gdb: check host dependencies
Benoît THÉBAUDEAU
benoit.thebaudeau@advansee.com
Mon Jun 6 14:50:00 GMT 2011
# HG changeset patch
# User "Benoît THÉBAUDEAU" <benoit.thebaudeau@advansee.com>
# Date 1307370928 -7200
# Node ID ca6222a138d007bcc7403276c924db0259a0f178
# Parent 2ab553e37517082017b10e992f5b0f5390fc053c
debug/cross-gdb: check host dependencies
Cross-gdb depends on expat and python. If either is missing, cross-gdb will
build successfully, but lacking some features.
Especially, if expat is missing, cross-gdb will be unable to parse the target
description, which may lead to runtime malfunctions and the following GDB
warning:
"Can not parse XML target description; XML support was disabled at compile time"
Hence, expat should be considered mandatory.
On the other hand, the features missing without python are not critical, so
python should not be considered mandatory.
This patch does the following:
- At configure time, warn the user if either expat or python is missing.
- In menuconfig, disable the static build options regarding cross-gdb if no
static version of expat is available, and disable cross-gdb if expat is
missing.
Signed-off-by: "Benoît THÉBAUDEAU" <benoit.thebaudeau@advansee.com>
diff --git a/config/debug/gdb.in.cross b/config/debug/gdb.in.cross
--- a/config/debug/gdb.in.cross
+++ b/config/debug/gdb.in.cross
@@ -3,10 +3,14 @@
config STATIC_TOOLCHAIN
select GDB_CROSS_STATIC if GDB_CROSS
+comment "Cross-gdb - disabled (requires expat; re-run ./configure to enable)"
+ depends on !CONFIGURE_has_expat_header || !CONFIGURE_has_expat_library
+
config GDB_CROSS
bool
prompt "Cross-gdb"
default y
+ depends on CONFIGURE_has_expat_header && CONFIGURE_has_expat_library
select GDB_GDBSERVER if ! BARE_METAL
help
Build and install a cross-gdb for the target, to run on host.
@@ -16,6 +20,7 @@
config GDB_CROSS_STATIC
bool
prompt "Build a static cross gdb"
+ depends on CONFIGURE_has_static_expat
help
A static cross gdb can be usefull if you debug on a machine that is
not the one that is used to compile the toolchain.
diff --git a/config/toolchain.in b/config/toolchain.in
--- a/config/toolchain.in
+++ b/config/toolchain.in
@@ -52,6 +52,7 @@
bool
default y
depends on CONFIGURE_has_static_libstdcxx
+ depends on !GDB_CROSS || CONFIGURE_has_static_expat
# Add new deps here! :-)
config STATIC_TOOLCHAIN
diff --git a/configure b/configure
--- a/configure
+++ b/configure
@@ -444,6 +444,42 @@
err="static 'libstdc++' is needed to statically link the toolchain's executables" \
kconfig=has_static_libstdcxx
+has_or_warn inc="expat.h" \
+ err="The 'expat' header file is needed to build cross-gdb" \
+ kconfig=has_expat_header
+
+expat_libs="$( for x in so dylib a; do \
+ printf "libexpat.$x "; \
+ done \
+ )"
+has_or_warn lib="${expat_libs}" \
+ err="The 'expat' library is needed to link cross-gdb's executables" \
+ kconfig=has_expat_library
+
+# Yes, we may be checking twice for libexpat.a
+# The first is because we need one instance of libexpat (shared or static)
+# because it is needed for cross-gdb; the second is because the static version
+# is required for static-linking, and if missing, the option is removed.
+has_or_warn lib="libexpat.a" \
+ err="static 'expat' is needed to statically link cross-gdb's executables" \
+ kconfig=has_static_expat
+
+python_incs="$( for v in 7 6 5 4; do \
+ printf "python2.$v/Python.h "; \
+ done \
+ )"
+has_or_warn inc="${python_incs}" \
+ err="The 'python' header file is needed for some features of cross-gdb"
+
+python_libs="$( for v in 7 6 5 4; do \
+ for x in so dylib a; do \
+ printf "libpython2.$v.$x "; \
+ done; \
+ done \
+ )"
+has_or_warn lib="${python_libs}" \
+ err="The 'python' library is needed for some features of cross-gdb"
+
#---------------------------------------------------------------------
# Compute the version string
diff --git a/scripts/build/debug/300-gdb.sh b/scripts/build/debug/300-gdb.sh
--- a/scripts/build/debug/300-gdb.sh
+++ b/scripts/build/debug/300-gdb.sh
@@ -139,6 +139,7 @@
--prefix="${CT_PREFIX_DIR}" \
--with-build-sysroot="${CT_SYSROOT_DIR}" \
--with-sysroot="${CT_SYSROOT_DIR}" \
+ --with-expat=yes \
--disable-werror \
"${cross_extra_config[@]}"
More information about the crossgcc
mailing list