PRB: Issue Specific to Using Windows Sockets from a DLL (237572)
The information in this article applies to:
- Microsoft Windows 95
- Microsoft Windows 98
- Microsoft Windows NT Server 4.0
- Microsoft Windows NT Server 4.0 SP4
- Microsoft Windows NT Workstation 4.0
- Microsoft Windows NT Workstation 4.0 SP4
This article was previously published under Q237572 This article discusses a Beta release of a Microsoft product. The information in this article is provided as-is and is subject to change without notice.
No formal product support is available from Microsoft for this Beta product. For information about how to obtain support for a Beta release, see the documentation that is included with the Beta product files, or check the Web location from which you downloaded the release. SYMPTOMS
When WSAStartup name-resolution functions such as gethostbyname and WSACleanup are called in a loop on Windows 9x or Windows NT 4.0, there is a small memory leak in each iteration.
CAUSE
The Hostent structure that is allocated by the Winsock name-space provider is not freed after WSACleanup is called, because the memory is allocated on a per-thread basis and is freed only when the thread exits. If WSAStartup is called again before the thread exits, another Hostent structure is allocated.
RESOLUTION
You rarely need to call WSAStartup and WSACleanup more than once in a application; however, it may be necessary to call WSAStartup and WSACleanup multiple times when writing a DLL where the developer chooses to wrap the entire Winsock call sequence within a DLL.
The most straight-forward way to trigger calling WSAStartup and WSACleanup in the intermediate DLL is to include procedures in the intermediate DLL interface to initiate and conclude use of the DLL.
If it is not possible to determine the first call from the application to the intermediate DLL, then calling WSAStartup and WSACleanup is more difficult. The scenario becomes much more complex if there are multiple threads in the DLL and each thread is loading a Winsock DLL by calling WSAStartup.
One possible workaround is to use the synchronization objects in a manner similar to mutex objects to synchronize the calls between the DLLs.
Please note that calling WSAStartup and WSACleanup in DLL_PROCESS_ATTACH and DLL_PROCESS_DETACH is not recommended, because this method can have an adverse affect on the application, giving rise to thread deadlocking.
Please refer to the Platform SDK documentation on DllMain. STATUS
This behavior is by design.
The problem has been fixed in Windows 2000. The memory for Winsock name resolution is allocated on a per-thread basis. It is freed when the thread exits. In the case where WSAStartup and WSACleanup are called repeatedly without exiting the thread, new memory won't be allocated at additional WSAStartup calls.
Modification Type: | Minor | Last Reviewed: | 12/20/2004 |
---|
Keywords: | kbDSWNET2003Swept kbBug kbDLL kbprb kbWinsock KB237572 |
---|
|