-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
python>=3.8 dll import fail under windows #33
Comments
Interestingly, the new builds (and tests) using pypy rather than cpython actually succeed for python 3.8 and 3.9 :-), despite the build being identical. Another tool to use : dlltracer results (using with python 3.7 (working): (pyobjcryst37) C:\WINDOWS\system32>ipython
Python 3.7.12 | packaged by conda-forge | (default, Oct 26 2021, 05:35:01) [MSC v.1916 64 bit (AMD64)]
Type 'copyright', 'credits' or 'license' for more information
IPython 7.33.0 -- An enhanced Interactive Python. Type '?' for help.
In [1]: import sys
In [2]: import dlltracer
In [3]: import ctypes
In [4]: with dlltracer.Trace(out=sys.stdout):
...: ctypes.CDLL("C://Users//vince/mambaforge///envs/pyobjcryst37/lib//site-packages//pyobjcryst/_pyobjcryst.cp37-win_amd64.pyd")
...:
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst37\Lib\site-packages\pyobjcryst\_pyobjcryst.cp37-win_amd64.pyd
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst37\vcruntime140_1.dll
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\pkgs\boost-1.78.0-py37h2cdfcc5_0\Library\bin\boost_python37.dll
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst37\msvcp140.dll and with python 3.9: (pyobjcryst) C:\Windows\System32>ipython
Python 3.9.13 | packaged by conda-forge | (main, May 27 2022, 16:51:29) [MSC v.1929 64 bit (AMD64)]
Type 'copyright', 'credits' or 'license' for more information
IPython 8.5.0 -- An enhanced Interactive Python. Type '?' for help.
In [1]: import sys
In [2]: import dlltracer
In [3]: import ctypes
In [4]: with dlltracer.Trace(out=sys.stdout):
...: ctypes.CDLL("C://Users//vince/mambaforge///envs/pyobjcryst/lib/site-packages/pyobjcryst/_pyobjcryst.cp39-win_amd64.pyd")
...:
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\Lib\site-packages\pyobjcryst\_pyobjcryst.cp39-win_amd64.pyd
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\Library\bin\boost_python39.dll
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\vcruntime140_1.dll
LoadLibrary \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\msvcp140.dll
Failed \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\Library\bin\boost_python39.dll
Failed \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\msvcp140.dll
Failed \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\vcruntime140_1.dll
Failed \Device\HarddiskVolume8\Users\vince\mambaforge\envs\pyobjcryst\Lib\site-packages\pyobjcryst\_pyobjcryst.cp39-win_amd64.pyd
---------------------------------------------------------------------------
OSError Traceback (most recent call last)
Cell In [4], line 2
1 with dlltracer.Trace(out=sys.stdout):
----> 2 ctypes.CDLL("C://Users//vince/mambaforge///envs/pyobjcryst/lib/site-packages/pyobjcryst/_pyobjcryst.cp39-win_amd64.pyd")
File ~\mambaforge\envs\pyobjcryst\lib\ctypes\__init__.py:374, in CDLL.__init__(self, name, mode, handle, use_errno, use_last_error, winmode)
371 self._FuncPtr = _FuncPtr
373 if handle is None:
--> 374 self._handle = _dlopen(self._name, mode)
375 else:
376 self._handle = handle
OSError: [WinError 1114] Une routine d’initialisation d’une bibliothèque de liens dynamiques (DLL) a échoué So it seems thatthe issue is not with the ability to find the required libraries (the paths are found), but rather something goes wrong when actually loading them. Also note that the path for |
What has been tried so far (just the headlines, many tests have been done...):
In the end, all fail. What seems clear is that the issue is NOT actually with finding the path to the libraries to load. When done manually with the proper What is interesting is that using
but using So this would indicate that there is an issue with the built pyobjcryst extension - incorrectly exposed symbols ? The actual error may correspond to the exact step as tested before (using py39):
The |
Creating a new minimal project with just
...this requires commenting other lines using ...keeping the
into the |
pyobjcryst now installs correctly under windows using
pip install .
(using the windows branch), but only works using python 3.7, and gets a "DLL load failed while importing _pyobcryst" on python>=3.8This seems to be due to a change in python 3.8, see https://docs.python.org/3.8/whatsnew/3.8.html#bpo-36085-whatsnew
A workaround should be to insert the adequate paths in the DLL load path using
os.add_dll_directory
(https://docs.python.org/3.8/library/os.html#os.add_dll_directory), but it is not clear which paths are missing since the error message does not indicate which DLL dependency failed to import (that would be waaay too simple).A relevant note for conda:
https://conda.io/projects/conda/en/latest/user-guide/troubleshooting.html#numpy-mkl-library-load-failed
.. but it seems using the
CONDA_DLL_SEARCH_MODIFICATION_ENABLE
does not make any differenceThe following link may contain useful info:
https://stackoverflow.com/questions/65334494/python-c-extension-packaging-dll-along-with-pyd
is a
package_data
missing in thesetup_args
?Yet another possibility:
https://stackoverflow.com/questions/59330863/cant-import-dll-module-in-python/64472088#64472088
Another discussion:
Toblerity/Fiona#851
Toblerity/Fiona#1081
Yet another Relevant Link (Maybe):
https://stackoverflow.com/questions/56797584/why-does-static-version-of-the-boost-python-library-has-a-dependency-to-python-i
Another approach:
https://github.com/PixarAnimationStudios/USD/pull/1511/files
The text was updated successfully, but these errors were encountered: