Python和libstdc ++的动态库问题 [英] Dynamic library problems with Python and libstdc++
问题描述
libstdc ++。dylib
版本不同。其结果是从模块崩溃中调用 iostream
。 Backstory
我使用旧计算机上的SWIG创建Python模块(运行10.5.8)。出于各种原因,我使用GCC 4.5(通过MacPorts安装)执行此操作,使用Python 2.7(通过MacPorts安装,使用系统默认的GCC 4.0.1编译)。
为了长话短说:在Python中调用
str(myObject)
会导致C ++代码依次调用 std :: operator<< <的std :: char_traits<炭> >
。这会产生以下错误: Python(487)malloc:***对象0x69548c错误:释放不对齐的指针
***在malloc_error_break中设置一个断点来调试
设置断点并调用<$
#0 0x9734de68在malloc_error_break()中code> backtrace
$ b#1 0x97348ad0 in szone_error()
#2 0x97e6fdfc in std :: string :: _ Rep :: _ M_destroy()
#3 0x97e71388 in std :: basic_string< char,std :: char_traits< char> ;,std :: allocator< char> > ::〜basic_string()
#4 std :: basic_stringbuf中的0x97e6b748< char,std :: char_traits< char> ;, std :: allocator< char> > :: overflow()
#5 0x97e6e7a0 in std :: basic_streambuf< char,std :: char_traits< char> > :: xsputn()
#6 0x00641638 in std :: __ ostream_insert< char,std :: char_traits< char> > ()
#7 0x006418d0在std :: operator<< <的std :: char_traits<炭> > ()
#8 0x01083058 in meshLib :: operator<< < tranSupport :: Dimension<(unsigned short)1> > (self = 0x5a3c50)位于/ Users / sethrj /目录中的/Users/sethrj/_code/pytrt/meshlib/oned/Cell.cpp:21
#9中的0x01008b14处(os = @ 0xbfffc628,c = @ 0x5a3c50)在/ Users / sethrj / _code / _build / pytrt-gcc45DEBUG / meshlib / swig / mesh_onedPYTHON_wrap下的_wrap_Cell_T___str__(args = 0x17eb470)中的_code / _build / pytrt-gcc45DEBUG / meshlib / swig / mesh_onedPYTHON_wrap.cxx:4439
#10 0x0101d150 .cxx:8341
#11 PyEval_EvalFrameEx()中的0x002f2350
#12 PyEval_EvalCodeEx()中的0x002f4bb4
[snip]
怀疑问题
我认为问题在于我的代码与新版本的libstdc ++链接:
/ opt / local / lib / gcc45 / libstdc ++。6.dylib(兼容性版本7.0.0,当前版本7.14.0)
而Python二进制文件对系统 libstdc ++
,它首先加载(在gdb中输出来自 info shared
):
1 dyld - 0x8fe00000 dyld YY / usr / lib / dyld在0x8fe00000(偏移量0x0)前缀为__dyld_
2 Python - 0x1000 exec YY / opt / local / Library / Frameworks / Python.framework / Versions / 2.7 / Resources / Python.app / Contents / MacOS / Python(offset 0x0)
(objfile is)/ opt / local / bin / python
3 Python F 0x219000 dyld YY /opt/local/Library/Frameworks/Python.framework/Versions/2.7/Python at 0x219000(offset 0x219000)
4 libSystem.B.dylib - 0x9723d000 dyld YY / usr / lib / libSystem.B.dylib在0x9723d000(offset -0x68dc3000)
(commpage objfile is)/usr/lib/libSystem.B.dylib[LC_SEGMENT.__DATA.__commpage]
5 CoreFoundation F 0x970b3000 dyld YY / System /Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation at 0x970b3000(offset -0x68f4d000)
6 libgcc_s.1.dylib - 0x923 e6000 dyld YY /usr/lib/libgcc_s.1.dylib at 0x923e6000(offset -0x6dc1a000)
7 libmathCommon.A.dylib - 0x94af5000 dyld YY /usr/lib/system/libmathCommon.A.dylib at 0x94af5000(offset -0x6b50b000)
8 libicucore.A.dylib - 0x97cf4000 dyld YY /usr/lib/libicucore.A.dylib at 0x97cf4000(offset -0x6830c000)
9 libobjc.A.dylib - 0x926f0000 dyld YY / usr /lib/libobjc.A.dylib at 0x926f0000(offset -0x6d910000)
(commpage objfile is)/usr/lib/libobjc.A.dylib[LC_SEGMENT.__DATA.__commpage]
10 libauto.dylib - 0x95eac000 dyld YY /usr/lib/libauto.dylib at 0x95eac000(offset -0x6a154000)
11 libstdc ++。6.0.4.dylib - 0x97e3d000 dyld YY /usr/lib/libstdc++.6.0.4.dylib at 0x97e3d000(offset -0x681c3000)
12 _mesh_oned.so - 0x1000000 dyld YY /Users/sethrj/_code/_build/pytrt-gcc45DEBUG/meshlib/swig/_mesh_oned.so 0x1000000(偏移量0x1000000)
13 libhdf5.7。 dylib - 0x122c000 dyld YY /opt/local/lib/libhdf5.7.dylib在0x122c000(偏移量0x122c000)
14 libz.1.2.5.dylib - 0x133000 dyld YY /opt/local/lib/libz.1.2。 5.dylib at 0x133000(offset 0x133000)
15 libstdc ++。6.dylib - 0x600000 dyld YY /opt/local/lib/gcc45/libstdc++.6.dylib 0x600000(偏移量0x600000)
[snip]
请注意, malloc
错误发生在系统的内存地址 libstdc ++
,不是共享库链接的地址。
尝试的解决方案
我试图强制MacPorts使用GCC 4.5而不是Apple编译器来构建Python,但是安装阶段失败了,因为它需要创建一个Mac框架,而GCC显然不适用'
$ b 即使使用 -static-libstdc ++
编译器标志,__ostream_insert也会调用系统加载的共享库中的std :: basic_streambuf
。
我尝试通过预先加入 / opt / local / lib / gcc45 /
来修改DYLD_LIBRARY_PATH, p>
我可以做些什么来实现这个目标?
更多信息
这个问题似乎是适用于mac os x 。请注意,在所有调试输出中,如何调用 std :: __ ostream_insert
和 std :: basic_streambuf :: xsputn
:它将离开新的GCC 4.5代码并跳入
/ usr / bin
中较旧的共享库代码。现在,找到一个解决方法......解决方案
-flat_namespace
我很高兴。我希望这一个星期没有让我知道。 :)
Executive summary: a Python module is linked against a different version of libstdc++.dylib
than the Python executable. The result is that calls to iostream
from the module crash.
Backstory
I'm creating a Python module using SWIG on an older computer (running 10.5.8). For various reasons, I am using GCC 4.5 (installed via MacPorts) to do this, using Python 2.7 (installed via MacPorts, compiled using the system-default GCC 4.0.1).
Observed Behavior
To make a long story short: calling str( myObject )
in Python causes the C++ code in turn to call std::operator<< <std::char_traits<char> >
. This generates the following error:
Python(487) malloc: *** error for object 0x69548c: Non-aligned pointer being freed
*** set a breakpoint in malloc_error_break to debug
Setting a breakpoint and calling backtrace
when it fails gives:
#0 0x9734de68 in malloc_error_break ()
#1 0x97348ad0 in szone_error ()
#2 0x97e6fdfc in std::string::_Rep::_M_destroy ()
#3 0x97e71388 in std::basic_string<char, std::char_traits<char>, std::allocator<char> >::~basic_string ()
#4 0x97e6b748 in std::basic_stringbuf<char, std::char_traits<char>, std::allocator<char> >::overflow ()
#5 0x97e6e7a0 in std::basic_streambuf<char, std::char_traits<char> >::xsputn ()
#6 0x00641638 in std::__ostream_insert<char, std::char_traits<char> > ()
#7 0x006418d0 in std::operator<< <std::char_traits<char> > ()
#8 0x01083058 in meshLib::operator<< <tranSupport::Dimension<(unsigned short)1> > (os=@0xbfffc628, c=@0x5a3c50) at /Users/sethrj/_code/pytrt/meshlib/oned/Cell.cpp:21
#9 0x01008b14 in meshLib_Cell_Sl_tranSupport_Dimension_Sl_1u_Sg__Sg____str__ (self=0x5a3c50) at /Users/sethrj/_code/_build/pytrt-gcc45DEBUG/meshlib/swig/mesh_onedPYTHON_wrap.cxx:4439
#10 0x0101d150 in _wrap_Cell_T___str__ (args=0x17eb470) at /Users/sethrj/_code/_build/pytrt-gcc45DEBUG/meshlib/swig/mesh_onedPYTHON_wrap.cxx:8341
#11 0x002f2350 in PyEval_EvalFrameEx ()
#12 0x002f4bb4 in PyEval_EvalCodeEx ()
[snip]
Suspected issue
I believe the issue to be that my code links against a new version of libstdc++:
/opt/local/lib/gcc45/libstdc++.6.dylib (compatibility version 7.0.0, current version 7.14.0)
whereas the Python binary has a very indirect dependence on the system libstdc++
, which loads first (output from info shared
in gdb):
1 dyld - 0x8fe00000 dyld Y Y /usr/lib/dyld at 0x8fe00000 (offset 0x0) with prefix "__dyld_"
2 Python - 0x1000 exec Y Y /opt/local/Library/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python (offset 0x0)
(objfile is) /opt/local/bin/python
3 Python F 0x219000 dyld Y Y /opt/local/Library/Frameworks/Python.framework/Versions/2.7/Python at 0x219000 (offset 0x219000)
4 libSystem.B.dylib - 0x9723d000 dyld Y Y /usr/lib/libSystem.B.dylib at 0x9723d000 (offset -0x68dc3000)
(commpage objfile is) /usr/lib/libSystem.B.dylib[LC_SEGMENT.__DATA.__commpage]
5 CoreFoundation F 0x970b3000 dyld Y Y /System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation at 0x970b3000 (offset -0x68f4d000)
6 libgcc_s.1.dylib - 0x923e6000 dyld Y Y /usr/lib/libgcc_s.1.dylib at 0x923e6000 (offset -0x6dc1a000)
7 libmathCommon.A.dylib - 0x94af5000 dyld Y Y /usr/lib/system/libmathCommon.A.dylib at 0x94af5000 (offset -0x6b50b000)
8 libicucore.A.dylib - 0x97cf4000 dyld Y Y /usr/lib/libicucore.A.dylib at 0x97cf4000 (offset -0x6830c000)
9 libobjc.A.dylib - 0x926f0000 dyld Y Y /usr/lib/libobjc.A.dylib at 0x926f0000 (offset -0x6d910000)
(commpage objfile is) /usr/lib/libobjc.A.dylib[LC_SEGMENT.__DATA.__commpage]
10 libauto.dylib - 0x95eac000 dyld Y Y /usr/lib/libauto.dylib at 0x95eac000 (offset -0x6a154000)
11 libstdc++.6.0.4.dylib - 0x97e3d000 dyld Y Y /usr/lib/libstdc++.6.0.4.dylib at 0x97e3d000 (offset -0x681c3000)
12 _mesh_oned.so - 0x1000000 dyld Y Y /Users/sethrj/_code/_build/pytrt-gcc45DEBUG/meshlib/swig/_mesh_oned.so at 0x1000000 (offset 0x1000000)
13 libhdf5.7.dylib - 0x122c000 dyld Y Y /opt/local/lib/libhdf5.7.dylib at 0x122c000 (offset 0x122c000)
14 libz.1.2.5.dylib - 0x133000 dyld Y Y /opt/local/lib/libz.1.2.5.dylib at 0x133000 (offset 0x133000)
15 libstdc++.6.dylib - 0x600000 dyld Y Y /opt/local/lib/gcc45/libstdc++.6.dylib at 0x600000 (offset 0x600000)
[snip]
Note that the malloc
error occurs in the memory address for the system libstdc++
, not the one the shared library is linked against.
Attempted resolutions
I tried to force MacPorts to build Python using GCC 4.5 rather than the Apple compiler, but the install phase fails because it needs to create a Mac "Framework", which vanilla GCC apparently doesn't do.
Even with the -static-libstdc++
compiler flag, __ostream_insert calls the std::basic_streambuf
from the system-loaded shared library.
I tried modifying DYLD_LIBRARY_PATH by prepending /opt/local/lib/gcc45/
but without avail.
What can I do to get this to work? I'm at my wit's end.
More information
This problem seems to be common to mac os x. Notice how in all of the debug outputs show, the address jumps between the calls to std::__ostream_insert
and std::basic_streambuf::xsputn
: it's leaving the new GCC 4.5 code and jumping into the older shared library code in /usr/bin
. Now, to find a workaround...
Solved it. I discovered that this problem is not too uncommon when mixing GCC versions on the mac. After reading this solution for mpich and checking the mpich source code, I found that the solution is to add the following flag to gcc on mac systems:
-flat_namespace
I am so happy. I wish this hadn't taken me a week to figure out. :)
这篇关于Python和libstdc ++的动态库问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!