* dll.sgml: Refine dll build instructions.
* ntsec.html: Correct some typos.
This commit is contained in:
parent
62012a3f31
commit
d3106bef0a
|
@ -1,3 +1,11 @@
|
||||||
|
2002-06-22 Joshua Daniel Franklin <joshuadfranklin@yahoo.com>
|
||||||
|
|
||||||
|
* dll.sgml: Refine dll build instructions.
|
||||||
|
|
||||||
|
2002-08-21 Christopher Faylor <cgf@redhat.com>
|
||||||
|
|
||||||
|
* ntsec.html: Correct some typos.
|
||||||
|
|
||||||
2002-07-23 Nicholas Wourms <nwourms@netscape.net>
|
2002-07-23 Nicholas Wourms <nwourms@netscape.net>
|
||||||
|
|
||||||
* calls.texinfo: Add fcloseall and fcloseall_r.
|
* calls.texinfo: Add fcloseall and fcloseall_r.
|
||||||
|
|
|
@ -41,52 +41,40 @@ For this example, we'll use a single file
|
||||||
|
|
||||||
<para>Now compile everything to objects:</para>
|
<para>Now compile everything to objects:</para>
|
||||||
|
|
||||||
<screen>
|
<screen>gcc -c myprog.c
|
||||||
gcc -c myprog.c
|
gcc -c mydll.c</screen>
|
||||||
gcc -c mydll.c
|
|
||||||
</screen>
|
|
||||||
|
|
||||||
<para>Unfortunately, the process for building a dll is, well, convoluted.
|
<para>Fortunately, with the latest gcc and binutils the process for building a dll
|
||||||
You have to run five commands, like this:</para>
|
is now much simpler. Say you want to build this minimal function in mydll.c:</para>
|
||||||
|
|
||||||
<screen>
|
<screen>int WINAPI
|
||||||
gcc -s -Wl,--base-file,mydll.base -o mydll.dll mydll.o -Wl,-e,_mydll_init@12
|
|
||||||
dlltool --base-file mydll.base --def mydll.def --output-exp mydll.exp --dllname mydll.dll
|
|
||||||
gcc -s -Wl,--base-file,mydll.base,mydll.exp -o mydll.dll mydll.o -Wl,-e,_mydll_init@12
|
|
||||||
dlltool --base-file mydll.base --def mydll.def --output-exp mydll.exp --dllname mydll.dll
|
|
||||||
gcc -Wl,mydll.exp -o mydll.dll mydll.o -Wl,-e,_mydll_init@12
|
|
||||||
</screen>
|
|
||||||
|
|
||||||
<para>The extra steps give <filename>dlltool</filename> the
|
|
||||||
opportunity to generate the extra sections (exports and relocation)
|
|
||||||
that a dll needs. After this, you build the import library:</para>
|
|
||||||
|
|
||||||
<screen>
|
|
||||||
dlltool --def mydll.def --dllname mydll.dll --output-lib mydll.a
|
|
||||||
</screen>
|
|
||||||
|
|
||||||
<para>Now, when you build your program, you link against the import
|
|
||||||
library:</para>
|
|
||||||
|
|
||||||
<screen>
|
|
||||||
gcc -o myprog myprog.o mydll.a
|
|
||||||
</screen>
|
|
||||||
|
|
||||||
<para>Note that we linked with <command>-e _mydll_init@12</command>.
|
|
||||||
This tells the OS what the DLL's "entry point" is, and this is a
|
|
||||||
special function that coordinates bringing the dll to life withing the
|
|
||||||
OS. The minimum function looks like this:</para>
|
|
||||||
|
|
||||||
<screen>
|
|
||||||
#include <windows.h>
|
|
||||||
|
|
||||||
int WINAPI
|
|
||||||
mydll_init(HANDLE h, DWORD reason, void *foo)
|
mydll_init(HANDLE h, DWORD reason, void *foo)
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}</screen>
|
||||||
</screen>
|
|
||||||
|
|
||||||
|
<para>First compile mydll.c to object code:</para>
|
||||||
|
|
||||||
|
<screen>gcc -c mydll.c</screen>
|
||||||
|
|
||||||
|
<para>Then, tell gcc that it is building a shared library:</para>
|
||||||
|
|
||||||
|
<screen>gcc -shared -o mydll.dll mydll.o</screen>
|
||||||
|
|
||||||
|
<para>That's it! However, if you are building a dll as an export library,
|
||||||
|
you will probably want to use the complete syntax:</para>
|
||||||
|
|
||||||
|
<screen>gcc -shared -o cyg${module}.dll \
|
||||||
|
-Wl,--out-implib=lib${module}.dll.a \
|
||||||
|
-Wl,--export-all-symbols \
|
||||||
|
-Wl,--enable-auto-import \
|
||||||
|
-Wl,--whole-archive ${old_lib} \
|
||||||
|
-Wl,--no-whole-archive ${dependency_libs}</screen>
|
||||||
|
|
||||||
|
<para>Where ${module} is the name of your DLL, ${old_lib} are all
|
||||||
|
your object files, bundled together in static libs or single object
|
||||||
|
files and the ${dependency_libs} are import libs you need to
|
||||||
|
link against, e.g '-lpng -lz -L/usr/local/special -lmyspeciallib'.</para>
|
||||||
</sect2>
|
</sect2>
|
||||||
|
|
||||||
<sect2 id="dll-link"><title>Linking Against DLLs</title>
|
<sect2 id="dll-link"><title>Linking Against DLLs</title>
|
||||||
|
|
|
@ -286,9 +286,9 @@ powerusers::547:
|
||||||
</screen>
|
</screen>
|
||||||
</example>
|
</example>
|
||||||
|
|
||||||
<para>As you can see I've changed my primary group membership from 513 (None)
|
<para>As you can see, I've changed my primary group membership from 513 (None)
|
||||||
to 547 (powerusers). So all file I created inside of Cygwin were now owned
|
to 547 (powerusers). So all file I created inside of Cygwin were now owned
|
||||||
by the powerusers group instead of None. This is the way I liked it.<para>
|
by the powerusers group instead of None. This is the way I liked it.</para>
|
||||||
|
|
||||||
<para>Groups may be mentioned in the passwd file, too. This has two
|
<para>Groups may be mentioned in the passwd file, too. This has two
|
||||||
advantages:</para>
|
advantages:</para>
|
||||||
|
|
Loading…
Reference in New Issue