Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

''::hypot' has not been declared' and 'undefined reference to `__imp_Py_InitModule4'' errors for mingw-w64 builds on Windows #140

Closed
sav-ix opened this issue Jul 17, 2017 · 15 comments
Labels

Comments

@sav-ix
Copy link

sav-ix commented Jul 17, 2017

Hello everyone,

For Boost.Python builds using mingw-w64 on Windows got error:

.\b2 --build-type=complete --with-python toolset=gcc-6.3.0 variant=release link=shared threading=multi runtime-link=shared address-model=64 -j1 -d2 -q

<snip>

gcc.compile.c++ bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\numeric.o

    "g++"  -ftemplate-depth-128 -O3 -finline-functions -Wno-inline -Wall -mthreads -m64  -DBOOST_ALL_NO_LIB=1 -DBOOST_PYTHON_SOURCE -DNDEBUG  -I"." -I"C:\ProgramData\Python64\Include" -c -o "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\numeric.o" "libs\python\src\numeric.cpp"

In file included from C:/ProgramData/Mingw64/lib/gcc/x86_64-w64-mingw32/6.3.0/include/c++/math.h:36:0,
                 from C:\ProgramData\Python64\Include/pyport.h:325,
                 from C:\ProgramData\Python64\Include/Python.h:58,
                 from ./boost/python/detail/wrap_python.hpp:151,
                 from ./boost/python/detail/prefix.hpp:13,
                 from ./boost/python/numeric.hpp:8,
                 from libs\python\src\numeric.cpp:6:
C:/ProgramData/Mingw64/lib/gcc/x86_64-w64-mingw32/6.3.0/include/c++/cmath:1157:11: error: '::hypot' has not been declared
   using ::hypot;
           ^~~~~

<snip>

...failed gcc.compile.c++ bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\numeric.o...
...failed updating 1 target...
...updated 8 targets...

Reproduced for builds using mingw-w64 with <Debug|Release> <Shared|Static> configurations. Not reproduced for builds using ICC or MSVC.

Could be fixed by adding cxxflags="-D_hypot=hypot" key to Boost build commands (see appropriate topic).

If blocker above is fixed, next error appear:

.\b2 cxxflags="-D_hypot=hypot" --build-type=complete --with-python toolset=gcc-6.3.0 variant=release link=shared threading=multi runtime-link=shared address-model=64 -j1 -d2 -q

<snip>

gcc.link.dll bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\libboost_python-mgw63-mt-1_64.dll.a

    "g++" -L"C:\ProgramData\Python64\libs" -Wl,-R -Wl,"C:\ProgramData\Python64" -Wl,-R -Wl,"C:\ProgramData\Python64\libs" "-Wl,--out-implib,bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\libboost_python-mgw63-mt-1_64.dll.a" -o "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\libboost_python-mgw63-mt-1_64.dll"  -shared -Wl,--start-group "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\numeric.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\list.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\long.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\dict.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\tuple.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\str.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\slice.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\converter\from_python.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\converter\registry.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\converter\type_id.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\enum.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\class.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\function.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\inheritance.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\life_support.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\pickle_support.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\errors.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\module.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\converter\builtin_converters.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\converter\arg_to_python_base.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\iterator.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\stl_iterator.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object_protocol.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object_operators.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\wrapper.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\import.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\exec.o" "bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\object\function_doc_signature.o"  -Wl,-Bstatic  -Wl,-Bdynamic -lpython27 -Wl,--end-group -mthreads -m64 

bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\module.o:module.cpp:(.text+0xf1): undefined reference to `__imp_Py_InitModule4'
collect2.exe: error: ld returned 1 exit status
...failed gcc.link.dll bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\libboost_python-mgw63-mt-1_64.dll.a bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\libboost_python-mgw63-mt-1_64.dll...
...removing bin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi\libboost_python-mgw63-mt-1_64.dll.a
...skipped <pstage\lib>libboost_python-mgw63-mt-1_64.dll.a for lack of <pbin.v2\libs\python\build\gcc-mingw-6.3.0\release\threading-multi>libboost_python-mgw63-mt-1_64.dll.a...
...failed updating 1 target...
...skipped 1 target...
...updated 30 targets...

Reproduced for builds using mingw-w64 with <Debug|Release> Shared configurations. Not reproduced for builds using ICC or MSVC.

Could be fixed by adding cxxflags="-DMS_WIN64" key to Boost build commands (see appropriate topic).

Both errors above relate to the Python implementation because of definitions:

#define hypot _hypot

and

#if defined(MS_WIN64) ... #endif

in file <Python dir>/include/pyconfig.h

Is it possible to fix this issue? E.g. add mentioned preprocessor definitions to Boost.Python build system as a separate rule for mingw-w64 builds on Windows, or something.

Environment:

  • Windows 10 x64,
  • mingw-w64 6.3.0 x86_64,
  • Python 2.7.13,
  • Boost-1.64.0.

Alexander

@stefanseefeld
Copy link
Member

I'm inclined to remove the numeric module entirely, as we now have Boost.NumPy. Are you a user of the numeric module, or only reporting the build failure ?

@sav-ix
Copy link
Author

sav-ix commented Jul 20, 2017

Just reporting build failure, since it broke whole Boost.Python module build.

@stefanseefeld
Copy link
Member

OK, I have removed the numeric module from the develop branch (and will merge this soon to master, too. Does this fix your build ?

@sav-ix
Copy link
Author

sav-ix commented Jul 20, 2017

Downloaded fresh Boost.Python dev branch, made sure it contain PR 2d1f66f, made builds using mingw-w64 with Release+<Shared|Static> configurations. Both cases finished with error '::hypot' has not been declared.

@stefanseefeld
Copy link
Member

Have you considered reporting this issue upstream, to Python itself ? Is Python never built with mingw-w64 ?

@sav-ix
Copy link
Author

sav-ix commented Jul 20, 2017

Nope, didn't consider. But since #define hypot _hypot definition is a feature of Python (pyconfig.h) implementation, it's hard to expect positive result.
I assumed, that solution is to add required build keys to Boost.Python toolchains, similar to other OSS libraries do. E.g. MESA added 0x0601 key into mingw-w64 toolchain in order to "unlock" required mingw-w64 functionality, not available by default, etc.
I don't claim to offer the best solution. But at least it allows to build Boots.Python using mingw-w64 without errors.

@stefanseefeld
Copy link
Member

Here is an existing issue: https://bugs.python.org/issue11566, just for the record.

@stefanseefeld
Copy link
Member

...plus a PR: python/cpython#880. It looks like this is a bit more involved as CPython and NumPy have different ideas as to how hypot() should behave...

@sav-ix
Copy link
Author

sav-ix commented Jul 20, 2017

Created on 2011-03-15. A long play issue.
Since it was taken as Python bug and some PR already introduced, it make sense to pause this issue for some time. In case that PR would pass review and would be used in future Python releases.
But even then, how would be fixed undefined reference to __imp_Py_InitModule4 error?

@stefanseefeld
Copy link
Member

I think that issue is indeed solved by adding -DMS_WIN64 to the command line. It seems that ought to be done by Boost.Build for all instances of mingw64, not in Boost.Python. I hope @raffienficiaud or @grafikrobot can help.

@sav-ix
Copy link
Author

sav-ix commented Jul 20, 2017

MS_WIN64 definition is a Python-related only. Mean Python introduced it for its own purposes, and compilers know nothing about it. E.g. no sense to add it anywhere except Boost.Python builds.

@stefanseefeld
Copy link
Member

Then perhaps it should be defined in boost/python/detail/config.hpp ?

@eldiener
Copy link
Contributor

I also see this issue trying to build Boost.Python with mingw-644/gcc-8.1 on Windows. Adding a _DMS_WIN64 to the command line does not solve anything. I will assume that building Boost.Python with mingw-64/gcc is just broke.

@eldiener
Copy link
Contributor

I should add in my report that I am using Python 2.7.13.

@nihir27
Copy link

nihir27 commented Oct 19, 2018

I'm experiencing the same with Python 3.6.5

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants