HOWTO: Share All Data in a DLL

ID: Q109619


The information in this article applies to:
  • Microsoft Win32 Application Programming Interface (API), included with:
    • Microsoft Windows NT versions 3.5, 3.51, 4.0
    • Microsoft Windows 95, version 4.0
    • Microsoft Windows 2000


SUMMARY

Win32 dynamic-link libraries (DLLs) use instance data by default, meaning that each application that uses a DLL gets its own copy of the DLL's data. However, it is possible to share the DLL data among all applications that use the DLL.

If you need to share only some of the DLL data, Microsoft recommends creating a new section and sharing it instead.
If you want to share all of the DLL static data, it is important to do two things:

  • First, the DLL must use the DLL version of the C run-time (for example Crtdll.lib or Msvcrt.lib). Please see your product documentation for more information about using the C run-time in a DLL.

    NOTE: Crtdll.lib is no longer part of the SDK, starting with Windows NT 3.51. It was last released on the April 1995 MSDN 3.5 SDK. Win32 now requires users to specify their own version of C run-time LIBs supplied by their own compiler vender.


  • Second, you need to specify that both .data and .bss are shared. Often, this is done in the "SECTIONS" portion of the .def file. For example:
    
       SECTIONS
          .bss  READ WRITE SHARED
          .data READ WRITE SHARED 
    If you are using Visual C++ 32-bit Edition, you must specify this using the -section switch on the linker. For example:
    
    link -section:.data,rws -section:.bss,rws 


Only static data is shared. Memory allocated dynamically with calls to such APIs/functions as GlobalAlloc() and malloc() are still specific to the calling process.

The system tries to load the shared memory block at the same address in each process. However, if the block cannot be loaded into the same memory address, the system maps the shared section into a different memory address. The memory is still shared. Note that the pointers inside the shared section are invalid under this circumstance and cannot be placed in shared sections.


MORE INFORMATION

The C run-time uses global variables. If the CRT is statically linked to the DLL, these variables will be shared among all clients of the DLL and will most likely cause an exception c0000005.

You need to specify both .data and .bss as shared because they each hold different types of data. The .data section holds initialized data and the .bss section holds the uninitialized data.

One reason for sharing all data in a DLL is to have consistent behavior in the DLL between Win32 (running on Windows NT) and Win32s (running on Windows 3.1). When running on Win32s, a 32-bit DLL shares its data among all of the processes that use the DLL.

Note that it is not necessary to share all data to behave identically between Win32 and Win32s. The DLL can use thread local storage (TLS) on Win32s to store variables as instance data.

For additional information, please see the following article in the Microsoft Knowledge Base:

Q109620 Creating Instance Data in a Win32s DLL

Additional query words: 3.10 3.50

Keywords : kbDLL kbIPC kbKernBase kbWinOS2000 kbDSupport kbGrpKernBase
Version : winnt:3.5,3.51,4.0
Platform : winnt
Issue type : kbhowto


Last Reviewed: December 30, 1999
© 2000 Microsoft Corporation. All rights reserved. Terms of Use.