This is the mail archive of the cygwin mailing list for the Cygwin project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Linking to multi-threaded MinGW DLL from Cygwin


I have a third-party, multi-threaded DLL (with .h file and .def file) that has 
been compiled using minGW. The DLL uses the Windows threadpool API.

I want to use this DLL from Cygwin. What I'm actually doing is linking to this 
DLL from Perl XS code, and functionally speaking, this now works fine. (I had 
to make sure to use __stdcall from the Cygwin side.) I use gcc/g++ v4.8.2.

Now that it works, I'm getting greedy and I want to take advantage of the 
multi-threading on the DLL side, since there is a great deal of parallelism in 
the function that the DLL performs.

I shouldn't have to do anything on the Cygwin side to achieve this. And yet 
the DLL is behaving in a single-threaded way and not showing the speed-up that 
it should.

I'm wondering if two threading models are colliding here, but then the DLL 
doesn't fail completely.  When compiling the XS code, there is a flag that I 
don't understand called 

"-I/usr/lib/perl5/5.14/686-cygwin-threads-64int/CORE"

which sounds a bit ominous.  I've tried -mno-cygwin since I read about that, 
but that doesn't seem to work anymore.  Any help for a newbie is appreciated.


--
Problem reports:       http://cygwin.com/problems.html
FAQ:                   http://cygwin.com/faq/
Documentation:         http://cygwin.com/docs.html
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]