Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
* [RFA/commit] pre-initialize python-value.c:values_in_python (bug in MacOS linker)
@ 2008-12-05 18:42 Joel Brobecker
  2008-12-05 19:08 ` Tom Tromey
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Joel Brobecker @ 2008-12-05 18:42 UTC (permalink / raw)
  To: gdb-patches

[-- Attachment #1: Type: text/plain, Size: 1207 bytes --]

Hello,

We noticed that GDB does not build on x86-macos and x86_64-macos when
configured --without-python (we found this out because one of our
machine no longer has python installed on it). The problem is that
the linker complains that it cannot file values_in_python, referenced
from value.c. This is a bug, since we verified that the symbol was
defined inside python-value.o which was also part of the archive.
We think that this might be related to the fact that the symbol is
defined as "C" (common). We changed the code to add an initial value
of NULL (which in C is strictly equivalent to the current code),
which changed our variable to the Data section and, ta da, allowed
GDB to link.

2008-12-05  Joel Brobecker  <brobecker@adacore.com>

        * python/python-value.c (values_in_python): Add specific initialization
        to NULL to work-around a MacOS linker bug.

Tested on x86-linux, both using --with-python and --without-python.
No regression.

I think this is pretty safe and safe contained, and doesn't reduce
the quality of the code, so I'm planning on committing this on Monday
when back from weekend holiday (I'm in Europe). Any objection? Should
I add a comment?

Thanks,
-- 
Joel

[-- Attachment #2: python-value.diff --]
[-- Type: text/plain, Size: 429 bytes --]

diff --git a/gdb/python/python-value.c b/gdb/python/python-value.c
index 8bf4ec8..c17fb3b 100644
--- a/gdb/python/python-value.c
+++ b/gdb/python/python-value.c
@@ -30,7 +30,7 @@
    can copy the values' types if needed.  This is declared
    unconditionally to reduce the number of uses of HAVE_PYTHON in the
    generic code.  */
-struct value *values_in_python;
+struct value *values_in_python = NULL;
 
 #ifdef HAVE_PYTHON
 

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2008-12-08 17:14 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-12-05 18:42 [RFA/commit] pre-initialize python-value.c:values_in_python (bug in MacOS linker) Joel Brobecker
2008-12-05 19:08 ` Tom Tromey
2008-12-06 15:31 ` Mark Kettenis
2008-12-08 15:18   ` Joel Brobecker
2008-12-08 17:14 ` Joel Brobecker

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox