FIX: MSDEV Crashes When Converting VC++ 4.0 Projects
ID: Q166285
|
The information in this article applies to:
-
Microsoft Visual C++, 32-bit Editions, version 5.0
SYMPTOMS
When you convert a Visual C++ 4.x project, the following error messages may
appear:
On Windows NT 4.0:
MSDEV.EXE - Application Error
The instruction at :0x00000004" referenced memory at "0x00000004". The
memory could not be read.
After selecting OK you may get the following error:
MSDEV.EXE - Application Error
The instruction at :0x5f402181" referenced memory at "0x00000004". The
memory could not be read.
On Windows 95:
This program has performed an illegal operation and will be shut down.
Details shows:
MSDEV caused an invalid page fault in module <unknown> at
00de:00000009
After selecting OK you get the following error:
This program has performed an illegal operation and will be shut down.
Details shows:
MSDEV caused an invalid page fault in module <unknown> at
0137:5f402181
-or-
This program has performed an illegal operation and will be shut down.
Details shows:
MSDEV caused an invalid page fault in module SSSCC.DLL at
0137:48248c18.
Note that in both cases the address in the first message may vary, but the
second one will be consistent.
CAUSE
There are two cases that will reproduce this problem:
Case 1
Projects that are missing a top-level project in the directory where the
.MDP and .MAK files are located crash.
Case 2
Projects for which the .MDP and .MAK files have been renamed and have a
subdirectory with the same name as the upper-level original project.
RESOLUTIONSteps to Reproduce Case 1
- In Visual C++ 4.0, create a workspace called Test of the Application
type.
- Insert a top-level project called Top of any type.
- Using the Build|Configurations menu, remove the Test project and then
close the project.
- In Visual C++ 5.0, open the Test workspace's Test.mdp file. Visual C++
5.0 converts the project. MSDEV crashes and the error messages noted
above appear.
Resolution for Case 1
- Under the Test directory which was created for the Test workspace there
is a "Top" subdirectory. Rename this the "Top" subdirectory to "x" (any
name is acceptable).
- In Visual C++ 5.0, open the Test workspace's Test.mdp file. Visual C++
5.0 converts the project.
- Rename the "x" subdirectory to the original name and the project will
work as expected.
In the general case, you may have several projects. Renaming any one of the
subdirectories as shown above will work around this bug.
Steps to Reproduce Case 2
- In Visual C++ 4.0, create a workspace called Test of the Application
type. It should be located in the Test directory.
- Insert a subproject of any type called Sub.
- Close the workspace.
- In the Test directory, rename Test.m?? to foo.*
- Create a subdirectory called Test\Test.
- In Visual C++ 5.0 open foo.mdp. MSDEV crashes and the error messages
noted above appear.
Resolution of Case 2
- Rename the Test\Test subdirectory to Test\[anything].
- Convert the project using Visual C++ 5.0. Now you can restore the
subdirectory name to Test\Test.
Please note that for case 2 the upper-level directory name is of no
consequence. What is important is that there is a subdirectory with the
same name as the original project name.
These scenarios apply to all versions of Visual C++ 4.x.
STATUS
Microsoft has confirmed this to be a bug in the Microsoft products listed
at the beginning of this article. This bug has been corrected in Visual
Studio 97 Service Pack 1.
For additional information about the Visual Studio 97 Service Pack 1,
please see the following article in the Microsoft Knowledge Base:
Q170365
INFO: Visual Studio 97 Service Packs - What, Where, and Why
Additional query words:
gpf ipf av
Keywords : kbtool kbide kbVC kbVC500bug kbVS97sp1fix kbVS97sp2fix kbGrpDSTools
Version : 5.0
Platform : NT WINDOWS
Issue type : kbbug
|