Article: Q29844
Product(s): See article
Version(s): 5.10 | 5.10
Operating System(s): MS-DOS | OS/2
Keyword(s): ENDUSER | | mspl13_c
Last Modified: 15-JAN-1991
The following information is from "Section 5: Creating Dynamic-Link
Libraries" of the Microsoft C version 5.10 MTDYNA.DOC file.
5.2.3 Using a Multiple-Thread Dynamic-Link Library
Once a C run-time multiple-thread dynamic-link library has been
created (Section 5.2.2), it can be used by a program and associated
dynamic-link libraries. The process of using this C run-time
dynamic-link library is shown below:
1. Compile the main program. When creating executable and dynamic-link
library files that will use the dynamically linked C run-time
library, the C compiler must be called with the multiple-thread
versions of the include files. Additionally, stack checking must be
turned off if your code is being compiled as small or compact
models. Stack checking can only be supported in the dynamically
linked C run-time library using far calls (medium/large memory
models). The C compiler is invoked with something like this:
cl /I\include\mt /AS /Gs2 /DDLL /c mtmain.c
The /Gs option specifies no stack checking. The /DDLL option
defines the DLL symbol. The /AS option specifies small memory
model. The /I\include\mt option specifies that the special
multiple-thread include files are to be used.
2. Link the main program to produce MTMAIN.EXE. The following files
are linked together:
mtmain.obj Output from step 1
crtexe.obj Start-up code for executable files
crtlib.lib Customized C run-time library (Section 5.2.2)
doscalls.lib OS/2 support library
mtmain.def Definition file for mtmain.c
mtmain.exe Output from LINK
The linker is invoked with something like this:
link mtmain+crtexe,/noi,,crtlib.lib doscalls.lib/nod,mtmain.def;
3. Compile the dynamic-link-library module. When creating executable
and dynamic-link library files that will use the dynamically linked
C run- time library, the C compiler must be called with the
multiple-thread versions of the include files. Additionally, stack
checking must be turned off if your code is being compiled as small
or compact model. Stack checking can only be supported in the
dynamically linked C run-time library using far calls
(medium/large memory models.) The C compiler is invoked with
something like this:
cl /I\include\mt /Alfw /G2 /DDLL /c mtdll.c
The /Alfw option specifies large code-pointer size, far
data-pointer size and a segment setup of SS not equal to DS; DS
fixed. The /DDLL option defines the DLL symbol. The /I\include\mt
option specifies that the special multiple-thread include files are
to be used.
4. Link the dynamic-link-library module to produce MTDLL.DLL. The
following files are linked together:
mtdll.obj Output from step 3
crtdll.obj Start-up code for dynamic-link library files
crtlib.lib Customized C run-time library (Section 5.2.2)
doscalls.lib OS/2 support library
mtdll.def Dynamic-link library definition file
mtdll.dll Output from LINK
The linker is invoked with something like this:
link mtdll+crtdll,mtdll.dll/noi,,crtlib.lib doscalls.lib/nod,mtdll.def;
5. Place the MTDLL.DLL file (from step 4) and the CRTLIB.DLL file
(from Section 5.2.2) in a directory on your LIBPATH so OS/2 can
find it. Then run the program MTMAIN.EXE. If either dynamic-link
library file is not in your LIBPATH, OS/2 will not be able to run
MTMAIN.EXE.
Note: The LIBPATH is set in your CONFIG.SYS or CONFIG.OS2 file,
depending on which version of OS/2 you are using. LIBPATH is not part
of your environment strings like the LIB, INCLUDE and PATH variables.