How can I remove the dependencies for mingwm10.dll and ligcc_s_dw2-1.dll?Should I do static linking?Is it possible to do static linking with Qt Creator?
How can I do static linking?(step by step please)
How can I remove the dependencies for mingwm10.dll and ligcc_s_dw2-1.dll?Should I do static linking?Is it possible to do static linking with Qt Creator?
How can I do static linking?(step by step please)
Try adding the -static-libgcc linker option.
How can I do this?I compile with Qt Creator and don't know how I can compile,link without using Qt Creator.
You can still use Qt Creator, just put the option in your .pro file like so:
Qt Code:
win32 { QMAKE_LFLAGS += -static-libgcc }To copy to clipboard, switch view to plain text mode
Thank you very much![]()
Can we do that with the LGPL license?
Lawand (3rd December 2010)
That would depend on the licenses of MinGW and libGCC, as they are not Qt related.
I couldn't make it work.
My project's .pro file is:
qmake Code:
QT -= core gui TARGET = struct1 Win32 { QMAKE_LFLAGS_RELEASE += -static-libgcc } CONFIG += console CONFIG -= app_bundle TEMPLATE = app SOURCES += main.cppTo copy to clipboard, switch view to plain text mode
but it still requires mingwm10.dll.
Last edited by wysota; 13th April 2010 at 13:21. Reason: reformatted to look better
You need mingwm10.dll because of the thread module.
I didn't find how to remove the thread module from the pro file but if you manually remove every occurrence of "-mthreads" in makefiles, it won't complain anymore about mingwm10.dll .
The problem is that you can not use QThread object in this case.
Thanks for your answer.Is it not possible to make this mingwm10.dll file staticaly linked?
Compile statical qt, first edit %qtdir%\mkspecs\win32-g++\qmake.conf and change
then recompile usingQt Code:
QMAKE_LFLAGS = -enable-stdcall-fixup -Wl,-enable-auto-import -Wl,-enable-runtime-pseudo-reloc QMAKE_LFLAGS = -static -enable-stdcall-fixup -Wl,-enable-auto-import -Wl,-enable-runtime-pseudo-relocTo copy to clipboard, switch view to plain text mode
important here is no-exceptions that tells to link mingwm10.dll. This command compile qt in release mode, add -debug if you want that to. Also properly set Path on windows env. That way everything works fine, assuming configure is success.Qt Code:
cd %qtdir% configure -static -release -no-exceptions -[other parameters like -mmx -sse -sse2 -3dnow etc...] make sub-srcTo copy to clipboard, switch view to plain text mode
Your project is then LGPL, that means if some one who buy/download your app ask you for sorce code you need to provide it to them. I don't know if mingw allso gave you some restriction, from license point of view.
Last edited by Talei; 18th April 2010 at 22:52.
There doesn't seem to be a static version of MinGW. You can get around the problem with a bit of messing about, but by far the easist way is to change compilers. You can download the free edition of Microsoft's Visual C++ for example.
Can you elaborate more about your first sentence? Because AFAIK (I can be wrong so please correct me) dll, such as mingwm10.dll, are by default static, and configuring qt to static means that every lib, not only mingwm10.dll but also QtCore4.dlll for release and QtCored4.dl for debug are copied at linking time into exe. And AFAIK only advantage of using msvc compilers vs ming is that msvc don't copy at link time full content of each source file, so assuming that in some source file you have two functions, and Your app use only one function of them, ming "copy" these two function into your exe, and msvc only the one you are using (so ming produce relatievely larger exe then msvc in static). Comments about that are more then welcome.
EDIT. I compile to static using mingw32 right now so I will post if something, like threads or so, don't work.(but I highly doubt about that)
EDIT. Compiled with mingw32 to static, threads, jpeg, etc... all works without any additional dll. (tested only to see if something changed from 4.4 version, that's when I last used static compiling)
Last edited by Talei; 19th April 2010 at 01:03.
DLL stands for "Dynamic Linked Library" - you can ONLY dynamically link to it. It is not possible to statically link to a DLL. To statically link you need a '.a' file (for GCC) or a .lib file (for MSVC++). This is why you must reconfigure & rebuild Qt if you want to statically link, as those '.a' files do not exist (or exist, but are only stubs).
Last time I looked, there was only DLL file for MinGW.
I read this post twice and maybe it's due to my bad eng, but I can't figure out last two post. First You write that there is "no static version of mingw" (this sentence in particular is confusing to me) and suggest using msvc, and in last post You write that there was only dll for mingw. Wouldn't that imply contradiction? Also I compiled qt, before posting to make sure, and msvc08 create lib's so either way no mater what compiler you use lib will be created for you (no surprise there). By static lib. I mean peace of code that is itself a whole, and don't rely on other peace of code. And due to my bad eng, I wrote something in different meaning than I actually meant.
Do I correctly assume that you previous advice was due to "not force user" to reconfigure qt? If so, and that's only my opinion, wouldn't that be way more hassle then simply reconfigure the whole thing?
Hello,
After some sleep I understood what you wrote, sorry about that, I need to get ride of habit of posting after 12h of coding, can't think straight.
Yes You are right that mingw (actually mingwm10, and so on, dll's) probably can't be statical compiled (I don't count trick to load dll from resource, so only one exe is deployed). But, and that's why I misunderstood You in the first place, You really don't need i.e. mingwm10.dll for Release build (they are not linked at all).
In short this dll handle exceptions and clean up after threads, but AFAIK, reference: http://old.nabble.com/mingwm10.dll-ts8920679.html , using:
prevent linker from linking it ( -no-exceptions ). Also, on posted thread, they are saying that mingwm10.dll clean up after threads, to prevent memory leak (24 * sizeof (void*) = 96byte, second post, and yes I know that thread was started in 2007 so probably information are outdated) for each catch in thread. So to summ it up, if no exceptions are used and no -mthreads is passed at compile time no need for mingwm10. (maybe I'm wrong?)Qt Code:
configure -static -release -no-exceptionsTo copy to clipboard, switch view to plain text mode
I wrote small test app, to see if something strange is going on with QThreads on static build, like mem leek and so on.
stat_test_dyn.exe (dynamic release build, require all dll like mingwm, QCore4 ...)
Qt Code:
qmake.exe stat_test.pro -spec win32-g++ -r CONFIG+=release mingw32-make.exe -w in \stat_test objdump.exe -j .idata -p stat_test_dyn.exe | sed -ne '/mingwm10/,/^$/{p;}' DLL Name: mingwm10.dll vma: Hint/Ord Member-Name Bound-ToTo copy to clipboard, switch view to plain text mode
stat_test_static.exe (static release build, don't require all dll like mingwm, QCore4 ...)
Program run 1000 times thread, one after another, and output values to progressbar (from 0 -> 100 ).Qt Code:
qmake.exe stat_test.pro -spec win32-g++ -r CONFIG+=release mingw32-make.exe -w in \stat_test objdump.exe -j .idata -p stat_test_static.exe | sed -ne '/mingwm10/,/^$/{p;}' no outputTo copy to clipboard, switch view to plain text mode
I run it ten times, so assuming mem leak of 96bytes on each thread * 1000 * 10 = 937KB mem leek.
statistics for stat_test_dyn.exe [DYNAMIC]
dyn_Snap1..jpgdyn_Snap2..jpg
after 10 runs mem usage is higher by168KB.
statistics for stat_test_static.exe [STATIC]
static_Snap1..jpgstatic_Snap2..jpg
after 10 runs mem usage is higher by120KB.
To sum it up 10000 thread's executed one after another. Test machine Windows XP SP3 32bit. Process Explorer v 11.33.
In attachment is src code if someone would want to test this by itself.
Of course there can be some error made by me, so you are welcome to point them out. stat_tst..zip
tetsuoii (4th January 2011)
Thanks for your answers![]()
Bookmarks