Solved

LNK2001 error after upgrade to VS2008 and XP64 from VS2005 and XP32

Posted on 2008-10-24
3
2,178 Views
Last Modified: 2013-11-26
I have a Win32 DLL project which builds perfectly on my VS2005(pro) machine running XP32(pro). On a newer machine with VS2008(standard)  running XP64 the same code fails to link with the following errors:

asl.lib(AAFAlgorithm2.obj) : error LNK2001: unresolved external symbol "unsigned int (__stdcall* ATL::g_pfnGetThreadACP)(void)" (?g_pfnGetThreadACP@ATL@@3P6GIXZA)
...
asl.lib(AAFInfo.obj) : error LNK2001: unresolved external symbol "unsigned int (__stdcall* ATL::g_pfnGetThreadACP)(void)" (?g_pfnGetThreadACP@ATL@@3P6GIXZA)

where asl.lib is a third-party 32bit library.
I can register the successfully built DLL on the newer machine and it works fine, but I can't seem to build it on the newer machine. I don't know if this is a XP32-XP64 issue, or a VS05-VS08 issue. I've read a lot of advice from the internet about these LNK2001 errors, but nothing has worked yet. I'm open to all suggestions no matter how obvious they may seem.

Thanks
Compiler command line:

/Od /I "..\..\Inc" /D "WIN32" /D "_DEBUG" /D "_WINDOWS" /D "WINVER=0x0501" /D "_CRT_SECURE_NO_DEPRECATE" /D "_VC80_UPGRADE=0x0600" /D "_WINDLL" /D "_MBCS" /Gm /EHsc /RTC1 /MTd /Yu"stdafx.h" /Fp".\Debug/AlgorithmDLL.pch" /Fo".\Debug/" /Fd".\Debug/" /W3 /nologo /c /ZI /errorReport:prompt

 

 

Link command line:

/OUT:"Debug/ColorFilter.dll" /INCREMENTAL /NOLOGO /LIBPATH:"..\..\lib\debug" /LIBPATH:"..\..\lib" /DLL /MANIFEST /MANIFESTFILE:".\Debug\ColorFilter.dll.intermediate.manifest" /MANIFESTUAC:"level='asInvoker' uiAccess='false'" /NODEFAULTLIB:"libc" /NODEFAULTLIB:"nafxcw" /NODEFAULTLIB:"msvcrt" /NODEFAULTLIB:"mfc42" /NODEFAULTLIB:"mfcs42" /NODEFAULTLIB:"libcmt" /NODEFAULTLIB:"libcd" /DEF:".\AlgorithmDLL.def" /DELAYLOAD:"OleAcc.dll" /DEBUG /PDB:".\Debug/ColorFilter.pdb" /SUBSYSTEM:WINDOWS /DYNAMICBASE:NO /IMPLIB:".\Debug/ColorFilter.lib" /MACHINE:X86 /ERRORREPORT:PROMPT libtiff.lib base.lib ail.lib winmm.lib wsock32.lib asl.lib lcmsd.lib DelayImp.lib

Open in new window

0
Comment
Question by:Croow
  • 2
3 Comments
 
LVL 19

Accepted Solution

by:
drichards earned 500 total points
ID: 22806171
Unforunately, g_pfnGetThreadACP is removed from VS2008.  Since you say asl.lib is third party, you'll need to keep building with VS2005, get a newer version of the third party library that is built with VS2008, build a custom version of ATL, or modify the third party source code yourself if that is an option.

Look at the differences between the two version of atlconv.h at the
 "#if(n)def _CONVERSION_DONT_USE_THREAD_LOCALE"
to see the differences.  Logic was greatly simplified in VS2008 and g_pfnGetThreadACP was obsoleted.
0
 
LVL 19

Expert Comment

by:drichards
ID: 22806178
Since it looks like you are building the third party library, you could just change the call or replicate the old g_pfnGetThreadACP  function in a library of your own and add the new library to the link dependency list of the third party library.
0
 
LVL 1

Author Comment

by:Croow
ID: 22806503
It's a big relief to confirm this isn't an XP64 issue.
I will keep working with VS05 until our vendor provides a new library.

Thanks
0

Featured Post

Do You Know the 4 Main Threat Actor Types?

Do you know the main threat actor types? Most attackers fall into one of four categories, each with their own favored tactics, techniques, and procedures.

Join & Write a Comment

Normally the drop down box control found in the .Net framework tools is able to select just one data and value at a time, which is displayed on the text area.   But what if you want to have multiple values to be selected in the drop down box? As …
Today I had a very interesting conundrum that had to get solved quickly. Needless to say, it wasn't resolved quickly because when we needed it we were very rushed, but as soon as the conference call was over and I took a step back I saw the correct …
This video gives you a great overview about bandwidth monitoring with SNMP and WMI with our network monitoring solution PRTG Network Monitor (https://www.paessler.com/prtg). If you're looking for how to monitor bandwidth using netflow or packet s…
When you create an app prototype with Adobe XD, you can insert system screens -- sharing or Control Center, for example -- with just a few clicks. This video shows you how. You can take the full course on Experts Exchange at http://bit.ly/XDcourse.

708 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

Need Help in Real-Time?

Connect with top rated Experts

13 Experts available now in Live!

Get 1:1 Help Now