delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/1998/02/03/22:25:52

From: fjh AT cs DOT mu DOT OZ DOT AU (Fergus Henderson)
Subject: Re: Initialising gnuwin DLLs
3 Feb 1998 22:25:52 -0800 :
Message-ID: <19980204161353.62787.cygnus.gnu-win32@mundook.cs.mu.OZ.AU>
References: <199802031421 DOT OAA15917 AT jaguar DOT rpms DOT ac DOT uk>
Mime-Version: 1.0
To: Matthew Brett <mbrett AT wren DOT rpms DOT ac DOT uk>
Cc: gnu-win32 AT cygnus DOT com

On 03-Feb-1998, Matthew Brett <mbrett AT wren DOT rpms DOT ac DOT uk> wrote:
> Dear Mikey,
> 
> "struct _reent for each dll needs to be initialized from
> main() before any calls to dll funcs that use the
> std file handles, see the perl5 patch for details."
> 
> Thanks for this reply.  Does this mean that for any program
> to use a gnuwin generated DLL, main() needs to know that it is
> a gnuwin DLL and initialise struct _reent?  This would mean 
> that you could not use gnuwin DLLs with code that did not
> know about _reent, I guess.  Could you not can you not 
> intialise _reent from the DLL code - e.g in the
> PROCESS_ATTACH routine - to initialise the Cygwin DLL from
> our new DLL?
>
> Does anyone have some skeletal code that does this?

Well, you can initialize each DLL's _impure_ptr so that
it points to reent_data -- this at least lets you use gnuwin
generated DLLs in gnuwin programs without main() needing to
jump through special hoops.  Of course, that won't initialize
the reent_data itself; I don't know if it's possible to do that
from within the dll_entry() function.

From Makefile.DLLs version 0.6 (see
<http://www.cs.mu.oz.au/~fjh/gnu-win32/how-to-build-dlls.html>):

# Windows requires each DLL to have an initialization function
# that is called at certain points (thread/process attach/detach).
# This one just initializes `_impure_ptr'.
dll_init.c:
	echo '#include <stdio.h>' 				> dll_init.c
	echo 'extern struct _reent *_impure_ptr;'		>> dll_init.c
	echo 'extern struct _reent *__imp_reent_data;'		>> dll_init.c
	echo '__attribute__((stdcall))'				>> dll_init.c
	echo 'int dll_entry(int handle, int reason, void *ptr)'	>> dll_init.c
	echo '{ _impure_ptr=__imp_reent_data; return 1; }'	>> dll_init.c

-- 
Fergus Henderson <fjh AT cs DOT mu DOT oz DOT au>   |  "I have always known that the pursuit
WWW: <http://www.cs.mu.oz.au/~fjh>   |  of excellence is a lethal habit"
PGP: finger fjh AT 128 DOT 250 DOT 37 DOT 3         |     -- the last words of T. S. Garp.
-
For help on using this list (especially unsubscribing), send a message to
"gnu-win32-request AT cygnus DOT com" with one line of text: "help".

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019