Article ID: 820252
Article Last Modified on 11/16/2007
APPLIES TO
- Microsoft Windows Server 2003, Standard Edition (32-bit x86)
- Microsoft Windows Server 2003, Enterprise Edition (32-bit x86)
- Microsoft Windows XP Professional
- Microsoft Windows XP Home Edition
- Microsoft Visual Basic 6.0 Learning Edition
- Microsoft Visual Basic 6.0 Professional Edition
- Microsoft Visual Basic 6.0 Enterprise Edition
SYMPTOMS
A program window may not be visible if the program stops responding (hangs). A program is considered to be hung if the program does not respond to window messages within several seconds, and a status of "Not Responding" appears in Windows Task Manager. In the problem state, the Win32 IsWindowVisible function does not return the WS_VISIBLE flag.
A Microsoft Visual Basic program may report the following error when the program tries to use the SetFocus method on a window:
Run-time error '5': Invalid procedure call or argument.
CAUSE
The Ghost Window feature creates ghost windows on behalf of a program when the program does not respond correctly to window messages within several seconds and is considered to be hung. The original program window's visibility state may not be restored before the program starts processing.
RESOLUTION
Windows Server 2003
Service pack information
To resolve this problem, obtain the latest service pack for Windows Server 2003. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
889100 How to obtain the latest service pack for Windows Server 2003
Windows XP
Service pack information
To resolve this problem, obtain the latest service pack for Windows XP. For more information, click the following article number to view the article in the Microsoft Knowledge Base:
322389 How to obtain the latest Windows XP service pack
Hotfix information
Prerequisites
To apply this hotfix, you must have Windows XP Service Pack 1 (SP1) installed on the computer.
Restart requirement
You must restart the computer after you apply this hotfix.
Hotfix replacement information
This hotfix does not replace any other hotfixes.
File information
The English version of this hotfix has the file attributes (or later file attributes) that are listed in the following table. The dates and times for these files are listed in Coordinated Universal Time (UTC). When you view the file information, it is converted to local time. To find the difference between UTC and local time, use the Time Zone tab in the Date and Time item in Control Panel.
Date Time Version Size File name -------------------------------------------------------- 09-May-2003 09:38 5.1.2600.1220 529,408 User32.dll 09-May-2003 09:23 5.1.2600.1220 1,677,056 Win32k.sys
WORKAROUND
You can use the Application Compatibility Toolkit to create and install a custom Application Compatibility database to disable the Ghost Window feature for your program. To download the Application Compatibility Toolkit, visit the following Microsoft Web site:
To create a custom Application Compatibility database:
- Install and run the Compatibility Administrator tool (add the /x switch to the command line for advanced features).
- Right-click Custom Database, and then click New.
- Right-click the new database, and then click Rename.
- Type noghost as the name of the database.
- Right-click New Database, click Create New, and then click Application Fix. Type the name of the program to be fixed.
- Type the name of the program manufacturer.
- Locate and then click the appropriate program (.exe) file.
- Click Next.
- In the Compatibility Modes window, click None, and then click Next.
- In the Compatibility Fixes list, click NoGhost.
- Click either Test Run or Finish. Clicking Test Run starts the program with the Application Compatibility setting. Clicking Finish adds the compatibility fix to your database.
- On the File menu, click Save to save the database. Or, copy the database to the C:\Windows\AppPatch folder.
- Right-click the database, and then click Install. Or, run the sdbinst c:\windows\apppatch\noghost.sdb -q command to install the database.
STATUS
Microsoft has confirmed that this is a problem in the Microsoft products that are listed in the "Applies to" section. This problem was first corrected in Microsoft Windows XP Service Pack 2. This problem was first corrected in Windows Server 2003 Service Pack 1.
MORE INFORMATION
The following information about the GetMessage function is documented for the Ghost Window feature in Windows XP. For more information, visit the following Microsoft Web site:
GetMessage function
If a top-level window stops responding to messages for more than several seconds, the system considers the window to be hung and replaces it with a ghost window that has the same z-order, location, size, and visual attributes. This allows the user to move it, resize it, or even close the application. However, these are the only actions available because the application is actually hung. When in the debugger mode, the system does not generate a ghost window.
Keywords: kbhotfixserver kbqfe kbwinxpsp2fix kbwinxppresp2fix kbfix kbbug KB820252