Microsoft KB Archive/887569

= A request may return a null pointer to the IFontDisp interface when a program that uses the Windows XP SP2 version of the Atl.dll file requests access to the ambient font property =

Article ID: 887569

Article Last Modified on 8/29/2007

-

APPLIES TO


 * Microsoft Windows XP Service Pack 2
 * Microsoft Windows XP Service Pack 2

-





SYMPTOMS
You may experience the following problem when a program uses the Microsoft Windows XP Service Pack 2 (SP2) version of the Atl.dll file to host ActiveX controls. When a program that uses this version of the Atl.dll file requests access to the ambient font property that is in an Active Template Library (ATL) host container, the request may return a null pointer to the IFontDisp interface.

When the null pointer is returned, an access violation may occur because most ActiveX controls do not recognize a null pointer. The program may stop responding. Or, the ActiveX controls may not work correctly.



CAUSE
This problem occurs because of a regression in the version of the Atl.dll file that is included with Windows XP SP2.

The control makes a call to the IAxWinAmbientDispatch::get_Font method. This call then causes the ATL!ATL::CAxHostWindow::get_Font method to be called. The call to the ATL!ATL::CAxHostWindow::get_Font method returns an S_OK HRESULT result. However, a null pointer is returned to the IFontDisp interface. Programs typically assume that a valid pointer is returned if the interface returns an S_OK HRESULT result. However, the control does not recognize the null pointer that is returned to the IFontDisp interface. Therefore, you experience the problems that are described in the &quot;Symptoms&quot; section.



Hotfix information
A supported hotfix is now available from Microsoft. However, this hotfix is intended to correct only the problem that is described in this article. Apply this hotfix only to systems that are experiencing this specific problem. This hotfix might receive additional testing. Therefore, if you are not severely affected by this problem, we recommend that you wait for the next service pack that contains this hotfix.

To resolve this problem, submit a request to Microsoft Online Customer Services to obtain the hotfix. To submit an online request to obtain the hotfix, visit the following Microsoft Web site:

http://go.microsoft.com/?linkid=6294451

Note If additional issues occur or any troubleshooting is required, you might have to create a separate service request. The usual support costs will apply to additional support questions and issues that do not qualify for this specific hotfix. To create a separate service request, visit the following Microsoft Web site:

http://support.microsoft.com/contactus/?ws=support

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 tool in Control Panel.

Date        Time   Version            Size    File name - 11-Jan-2005 23:25  3.5.2284.1         58,880  Atl.dll



STATUS
Microsoft has confirmed that this is a problem in the Microsoft products that are listed in the &quot;Applies to&quot; section.



MORE INFORMATION
For additional information, click the following article number to view the article in the Microsoft Knowledge Base:

824684 Description of the standard terminology that is used to describe Microsoft software updates

Keywords: kbbug kbfix kbqfe kbwinxpsp3fix kbhotfixserver KB887569

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.