Solved

How to increase link speed for a large c++ dll in VS 2005?

Posted on 2010-11-11
5
718 Views
Last Modified: 2012-05-10
I have to support a quite large C++ application (win dll). I use MS Visual Studio 2005 as IDE.

The app is structured (under VS 2005) as a solution with 7 o 8 projects and about 400 files (200 .h or .hpp and 200 .cpp).

A full rebuild in release mode takes around 5 minutes to compile and 15 minutes to link (in an Intel Core2 Duo PC with 2GB RAM).

So reducing linking time is desirable.  Are there any tips for improving the link time?

Even more annoying is that the same slowness happens in debug mode (also in link time).

The size of the release dll is around 11 MB (20 MB debug dll).

All this slow linking started to happen when I upgraded VS from 2003 to 2005. With VC++ 2003, a full release rebuild use to take less than 10 minutes.

I am using precompiled headers (pch). Most of the code is written as c++ templates.

Most of the projects compile to static libraries. It seems the use of static libraries prevents VS2005 from using incremental linking, so even with incremental linking turned on it does a full link every time.

Any idea to reduce linking time?
0
Comment
Question by:JorgeMarreroMorejon
5 Comments
 
LVL 8

Expert Comment

by:JIEXA
ID: 34118047
1. Templates are extremely complicated at linkage time. If you can use non-templated code, this will reduce linkage time.
2. Get procmon from sysinternals.com. At the linkage time trace what files are open/read/written. This may give you some clues.
0
 
LVL 5

Expert Comment

by:greatsubash
ID: 34118185
0
 
LVL 8

Accepted Solution

by:
JIEXA earned 500 total points
ID: 34118250
In addition to my comment: if you see a big activity to some files in procmon, you can put them to RAM-drive (in case you have a lot of memory, 64-bit OS) or to SSD disk (if you have one or can buy).
0
 
LVL 16

Expert Comment

by:HooKooDooKu
ID: 34120860
Can you down grade back to VS2003 or upgrade your computer?

I know that seems like sort of a silly response, but I'm not suprized that a Microsoft UPGRADE results in a DOWNGRADE in performance.  From what I've seen, MS is all about features, and lets advancements in hardware take care of "performance issues".  (Haven't you heard the phrase "What Intel Giveth, Microsoft Taketh?).

But seriously, unless there is something you NEED out of VS2005, if the upgrade is what killed your perfomance, then downgrade back until you can upgrade both the hardware and the software is my suggestion.
0
 

Author Closing Comment

by:JorgeMarreroMorejon
ID: 34141585
The clue to improve performance has been to check the IO activity. It seems the corporative antivirus is slowing down the writing of temporary files generated both by cl.exe and link.exe. I managed myself to disable the AV and now the full release is taking 15 minutes to build. That is, half time less than before.
Thanks
0

Featured Post

Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

The following diagram presents a diamond class hierarchy: As depicted, diamond inheritance denotes when two classes (e.g., CDerived1 and CDerived2), separately extending a common base class (e.g., CBase), are sub classed simultaneously by a fourt…
IntroductionThis article is the second in a three part article series on the Visual Studio 2008 Debugger.  It provides tips in setting and using breakpoints. If not familiar with this debugger, you can find a basic introduction in the EE article loc…
The goal of the tutorial is to teach the user how to use functions in C++. The video will cover how to define functions, how to call functions and how to create functions prototypes. Microsoft Visual C++ 2010 Express will be used as a text editor an…
The viewer will be introduced to the member functions push_back and pop_back of the vector class. The video will teach the difference between the two as well as how to use each one along with its functionality.

786 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question