Mixing compiled matlab shared libraries with mex code.

13 ビュー (過去 30 日間)
Chris Volpe
Chris Volpe 2015 年 7 月 10 日
コメント済み: Adam Callens 2017 年 4 月 5 日
I have some matlab code that invokes mex code (compiled with VS2013). I have both Debug and Release builds of the mex code, and can adjust my system (windows) PATH prior to starting up Matlab so that when I invoke that mex function from Matlab, it invokes the desired build configuration.
Now, I want to bundle up the matlab code into a DLL with the matlab compiler. If I don't add the mex DLLs as additional files required in the .PRJ GUI, the compiled matlab code can't find it at runtime. But if I do add the mex code, the resulting compiled matlab library is "build configuration dependent" -- i.e. if I added the debug build of the mex code, the library won't work from a release build of an executable program client of the compiled matlab library, and vice versa. So, what I want to do is to get a compiled matlab library that doesn't know about the mex code, but which can find it at runtime using the normal PATH-related load procedure, since the desired mex DLL will be in the same folder (Debug or Release) as the executable program client of the compiled matlab library. But I don't seem to be able to find a way to accomplish this goal. Any thoughts?

回答 (2 件)

Dasharath Gulvady
Dasharath Gulvady 2015 年 7 月 21 日
The best way to do this is to place the MEX file in a relative path to "ctfroot":
Normally, in Windows, "ctfroot" is %temp%\username\mcrCachexx.
  4 件のコメント
Chris Volpe
Chris Volpe 2015 年 9 月 17 日
編集済み: Chris Volpe 2015 年 9 月 18 日
Rather than copy the mex file to the ctfroot, I have tried a different approach in which I pass, to the compiled matlab code, the path where the mex code normally gets built (which is a subfolder of where the main C++ client application gets built). In the compiled matlab code, I add this location to the matlab path with the addpath() function. Now, when I try to invoke the mex code, it finds the mex file in the correct location, but it cannot execute it. When I try, it complains: "Cannot find authentication file 'D:\Path\to\mymexfile.mexw64.auth'. I suspect it knows that I'm trying to "inject" code into the behavior of the compiled matlab DLL at runtime, and perhaps it's intentionally blocking that for security reasons.
I suspect that the underlying issue is that my mex file, call it "A.mexw64' is dependent on another library, "B.dll". But "B.dll" is also a dependency of the main executable, so when I build a particular configuration (debug or release) of A.mexw64 into the compiled matlab DLL, and the client application invokes it, the loader sees that in order to load A.mexw64, it needs B.dll, but B.dll is already loaded as part of the main client application, and the configuration of B.dll that is loaded depends on the configuration of the client executable, which may or may not be the same as that of A.mexw64. This is my dilemma. I don't think bundling the corresponding configuration of B.dll into the matlab compiler project alongside A.mexw64 will solve the problem, because Windows will probably ignore that DLL, knowing that it already as a "B.dll" loaded. I wonder if I'm just stuck building config-specific versions of the compiled matlab project.
Adam Callens
Adam Callens 2017 年 4 月 5 日
What about the A.mexw64.auth file that is not generated if you don't include the mex file in the mcc build. How do you get around that?

サインインしてコメントする。


Chris Volpe
Chris Volpe 2015 年 9 月 18 日
I solved my issue with a three-step process. First, I changed my VS2013 project settings for Project B such that it creates B_debug.dll and B_release.dll. Second, I added B_release.dll to the additional required files for the matlab compiler. Third, I changed my VS2013 project settings for A.mexw64 such that the target file gets built into the same folder as B.dll. I had previously set all my mex code to be built into a "MEX" subfolder so that I could add this subfolder to my Matlab path and non bog down Matlab with searching through a binaries folder that contained all sorts of 3rd-party DLLs. Putting them in the same folder ensures that when I add them both in the deploytool GUI, they'll end up in the same relative path off the expanded ctfroot temp folder at runtime, ensuring that B_release.dll can be found at runtime.

カテゴリ

Help Center および File ExchangeMATLAB Compiler についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by