This is the mail archive of the
gdb@sourceware.org
mailing list for the GDB project.
Re: How to configure gdb to support '--arch=i386' on Mac OS X
On Wed, Oct 07, 2009 at 02:00:38PM -0700, Michael Snyder wrote:
> n179911 wrote:
>> Thank you. You are right.
>>
>> The gdb comes with apple has '-arch' option, but gdb 7.0 does not.
>>
Actually if you look at what Apple does, the gdb in /usr/bin (for
Leopard anyway) is just an executable shell script...
#! /bin/sh
host_architecture=""
requested_architecture="UNSET"
architecture_to_use=""
# classic-inferior-support
translate_mode=0
translate_binary=""
PATH=$PATH:/sbin:/bin:/usr/sbin:/usr/bin
# gdb is setgid procmod and dyld will truncate any DYLD_FRAMEWORK_PATH etc
# settings on exec. The user is really trying to set these things
# in their process, not gdb. So we smuggle it over the setgid border in
# GDB_DYLD_* where it'll be laundered inside gdb before invoking the inferior.
unset GDB_DYLD_FRAMEWORK_PATH
unset GDB_DYLD_FALLBACK_FRAMEWORK_PATH
unset GDB_DYLD_LIBRARY_PATH
unset GDB_DYLD_FALLBACK_LIBRARY_PATH
unset GDB_DYLD_ROOT_PATH
unset GDB_DYLD_PATHS_ROOT
unset GDB_DYLD_IMAGE_SUFFIX
unset GDB_DYLD_INSERT_LIBRARIES
[ -n "$DYLD_FRAMEWORK_PATH" ] && GDB_DYLD_FRAMEWORK_PATH="$DYLD_FRAMEWORK_PATH"
[ -n "$DYLD_FALLBACK_FRAMEWORK_PATH" ] && GDB_DYLD_FALLBACK_FRAMEWORK_PATH="$DYLD_FALLBACK_FRAMEWORK_PATH"
[ -n "$DYLD_LIBRARY_PATH" ] && GDB_DYLD_LIBRARY_PATH="$DYLD_LIBRARY_PATH"
[ -n "$DYLD_FALLBACK_LIBRARY_PATH" ] && GDB_DYLD_FALLBACK_LIBRARY_PATH="$DYLD_FALLBACK_LIBRARY_PATH"
[ -n "$DYLD_ROOT_PATH" ] && GDB_DYLD_ROOT_PATH="$DYLD_ROOT_PATH"
[ -n "$DYLD_PATHS_ROOT" ] && GDB_DYLD_PATHS_ROOT="$DYLD_PATHS_ROOT"
[ -n "$DYLD_IMAGE_SUFFIX" ] && GDB_DYLD_IMAGE_SUFFIX="$DYLD_IMAGE_SUFFIX"
[ -n "$DYLD_INSERT_LIBRARIES" ] && GDB_DYLD_INSERT_LIBRARIES="$DYLD_INSERT_LIBRARIES"
export GDB_DYLD_FRAMEWORK_PATH
export GDB_DYLD_FALLBACK_FRAMEWORK_PATH
export GDB_DYLD_LIBRARY_PATH
export GDB_DYLD_FALLBACK_LIBRARY_PATH
export GDB_DYLD_ROOT_PATH
export GDB_DYLD_PATHS_ROOT
export GDB_DYLD_IMAGE_SUFFIX
export GDB_DYLD_INSERT_LIBRARIES
# dyld will warn if any of these are set and the user invokes a setgid program
# like gdb.
unset DYLD_FRAMEWORK_PATH
unset DYLD_FALLBACK_FRAMEWORK_PATH
unset DYLD_LIBRARY_PATH
unset DYLD_FALLBACK_LIBRARY_PATH
unset DYLD_ROOT_PATH
unset DYLD_PATHS_ROOT
unset DYLD_IMAGE_SUFFIX
unset DYLD_INSERT_LIBRARIES
host_architecture=`/usr/bin/arch 2>/dev/null` || host_architecture=""
if [ -z "$host_architecture" ]; then
echo "There was an error executing 'arch(1)'; assuming 'i386'.";
host_architecture="i386";
fi
case "$1" in
--help)
echo " --translate Debug applications running under translation." >&2
echo " -arch i386|armv6|x86_64|ppc Specify a gdb targetting a specific architecture" >&2
;;
-arch=* | -a=* | --arch=*)
requested_architecture=`echo "$1" | sed 's,^[^=]*=,,'`
shift;;
-arch | -a | --arch)
shift
requested_architecture="$1"
shift;;
-translate | --translate | -oah* | --oah*)
translate_mode=1
shift;;
esac
if [ -z "$requested_architecture" ]
then
echo ERROR: No architecture specified with -arch argument. >&2
exit 1
fi
[ "$requested_architecture" = "UNSET" ] && requested_architecture=""
if [ $translate_mode -eq 1 ]
then
if [ "$host_architecture" = i386 -a -x /usr/libexec/oah/translate ]
then
requested_architecture="ppc"
translate_binary="/usr/libexec/oah/translate -execOAH"
else
echo ERROR: translate not available. Running in normal debugger mode. >&2
fi
fi
if [ -n "$requested_architecture" ]
then
case $requested_architecture in
ppc* | i386 | x86_64 | arm*)
;;
*)
echo Unrecognized architecture \'$requested_architecture\', using host arch. >&2
requested_architecture=""
;;
esac
fi
if [ -n "$requested_architecture" ]
then
architecture_to_use="$requested_architecture"
else
# No architecture was specified. We will try to find the executable
# or a core file in the list of arguments, and launch the correct
# gdb for the job. If there are multiple architectures in the executable,
# we will search for the architecture that matches the host architecture.
# If all this searching doesn't produce a match, we will use a gdb that
# matches the host architecture by default.
best_arch=
exec_file=
core_file=
for arg in "$@"
do
case "$arg" in
-*)
# Skip all option arguments
;;
*)
# Call file to determine the file type of the argument
file_result=`file "$arg"`;
case "$file_result" in
*Mach-O*core*)
core_file=$arg
;;
*Mach-O*)
exec_file=$arg
;;
*)
if [ -x "$arg" ]; then
exec_file="$arg"
fi
;;
esac
;;
esac
done
# Get a list of possible architectures in FILE_ARCHS.
# If we have a core file, we must use it to determine the architecture,
# else we use the architectures in the executable file.
file_archs=
if [ -n "$core_file" ]; then
file_archs=`file "$core_file" | awk '{ print $NF }'`
else
if [ -n "$exec_file" ]; then
file_archs=`file "$exec_file" | grep -v universal | awk '{ print $NF }'`
fi
fi
# Iterate through the architectures and try and find the best match.
for file_arch in $file_archs
do
# If we don't have any best architecture set yet, use this in case
# none of them match the host architecture.
if [ -z "$best_arch" ]; then
best_arch="$file_arch"
fi
# See if the file architecture matches the host, and if so set the
# best architecture to that.
if [ "$file_arch" = "$host_architecture" ]; then
best_arch="$file_arch"
fi
done
case "$best_arch" in
ppc* | i386 | x86_64 | arm*)
# We found a plausible architecture and we will use it
architecture_to_use="$best_arch"
;;
*)
# We did not find a plausible architecture, use the host architecture
architecture_to_use="$host_architecture"
;;
esac
fi
# If GDB_ROOT is not set, then figure it out
# from $0. We need this for gdb's that are
# not installed in /usr/bin.
GDB_ROOT_SET=${GDB_ROOT:+set}
if [ "$GDB_ROOT_SET" != "set" ]
then
gdb_bin="$0"
if [ -L "$gdb_bin" ]
then
gdb_bin=`readlink "$gdb_bin"`
fi
gdb_bin_dirname=`dirname "$gdb_bin"`
GDB_ROOT=`cd "$gdb_bin_dirname"/../.. ; pwd`
if [ "$GDB_ROOT" = "/" ]
then
GDB_ROOT=
fi
fi
case "$architecture_to_use" in
ppc*)
# Make sure we specify the architecture to gdb when launching if the
# gdb can handle both 32 and 64 bit variants.
if [ -z "$requested_architecture" ]; then
requested_architecture=$architecture_to_use;
fi
gdb="${GDB_ROOT}/usr/libexec/gdb/gdb-powerpc-apple-darwin"
;;
i386 | x86_64)
# Make sure we specify the architecture to gdb when launching if the
# gdb can handle both 32 and 64 bit variants.
if [ -z "$requested_architecture" ]; then
requested_architecture=$architecture_to_use;
fi
gdb="${GDB_ROOT}/usr/libexec/gdb/gdb-i386-apple-darwin"
;;
arm*)
gdb="${GDB_ROOT}/usr/libexec/gdb/gdb-arm-apple-darwin"
case "$architecture_to_use" in
armv6)
osabiopts="--osabi DarwinV6"
;;
*)
# Make the REQUESTED_ARCHITECTURE the empty string so
# we can let gdb auto-detect the cpu type and subtype
requested_architecture=""
;;
esac
;;
*)
echo "Unknown architecture '$architecture_to_use'; using 'ppc' instead.";
gdb="${GDB_ROOT}/usr/libexec/gdb/gdb-powerpc-apple-darwin"
;;
esac
if [ ! -x "$gdb" ]; then
echo "Unable to start GDB: cannot find binary in '$gdb'"
exit 1
fi
if [ -n "$requested_architecture" -a $translate_mode -eq 0 ]
then
exec $translate_binary "$gdb" --arch "$requested_architecture" "$@"
else
exec $translate_binary "$gdb" $osabiopts "$@"
fi
So he could simply make a copy of that for /usr/local/bin and adjust it
to run the FSF gdb. Actually it might not be a bad idea since one
could script calling the gdb binary with sudo (as 10.5.8 or later
requires gdb to be run as root for now).
Jack
ps I wonder if there are any clues in this script that might help us
run FSF gdb as non-root?