delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2003/03/03/12:55:05

Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sources.redhat.com/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sources.redhat.com/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com
Date: Mon, 3 Mar 2003 17:57:01 +0000
From: "Steven O'Brien" <steven DOT obrien2 AT ntlworld DOT com>
To: cygwin AT cygwin DOT com
Subject: dll_list::load_after_fork()
Message-Id: <20030303175701.5d862291.steven.obrien2@ntlworld.com>
Mime-Version: 1.0
Note-from-DJ: This may be spam

--Multipart_Mon__3_Mar_2003_17:57:01_+0000_10180360
Content-Type: text/plain; charset=US-ASCII
Content-Transfer-Encoding: 7bit

Hi

On Sun, 2 Mar 2003 12:31:49 -0500, Christopher Faylor wrote:
> I don't see how a change which checks for a valid error condition
> could be considered "wrong".

My apologies for not giving more details, I realize that last message
was a little curt. There are two issues with the current CVS revision of
dll_init.cc:
- it is possible for the child to continue even though it has loaded a
dll to the wrong address, with possible disastrous results (line 324,
the return value of LoadLibrary is not checked);
- the change does not address the problem I raised with unbalanced
PROCESS_ATTACH and PROCESS_DETACH calls to the cygwin entry point
function.

The second issue is the one I want to pursue here. It is clear to me
from reading the MDSN library docs combined with my own experiments
that, on Win 9x/Me only, the sequence:
h = LoadLibraryEx(d.name, NULL, DONT_RESOLVE_DLL_REFERENCES);
FreeLibrary(h);
always results in a call to DllMain() with PROCESS_DETACH even though
there has been no corresponding call to DllMain() with PROCESS_ATTACH.
This *may* cause a segv or data corruption, depending on what the DLL
initialisation/finalisation code does. The only way to avoid this is to
not use LoadLibraryEx(d.name, NULL, DONT_RESOLVE_DLL_REFERENCES) on WIn
9x/Me.

I have also thought through the algorithm of this function some more,
and have (hopefully) identified all the different failure conditions
with appropriate actions.

I have included the text of my proposed function here, so if anyone has
time to read through it I would appreciate any constructive criticism. I
have also attached a patch against the current CVS, so anyone using
run-time loaded DLLS can check its behaviour on both 9x and NT. For me,
this change gets the gnome desktop working for the first time on win ME.

Regards,
Steven

void
dll_list::load_after_fork (HANDLE parent, dll *first)
{
  in_forkee = 1;
  dll d;

  void *next = first;
  while (next)
    {
      DWORD nb;
      /* Read the dll structure from the parent. */
      if (!ReadProcessMemory (parent, next, &d, sizeof (dll), &nb) ||
	  nb != sizeof (dll))
	return;

      /* We're only interested in dynamically loaded dlls.
	 Hopefully, this function wouldn't even have been called unless
	 the parent had some of those. */
      if (d.type == DLL_LOAD)
	{
	  HMODULE h;
	  if (wincap.is_winnt())
	    {
	      /* On NT/2K/XP we first test-load the DLL to see if if goes to
the right
	         address. We have to do this because if we load it fully and
its at the
	         wrong address then the later code that tries to adjust the
load address 
	         fails. */
	      h = LoadLibraryEx (d.name, NULL, DONT_RESOLVE_DLL_REFERENCES);
	      if (h == d.handle)
	        {
	          /* We got the right address first time. So now load it
properly */
	          FreeLibrary(h);
	          h = LoadLibrary(d.name);
	        }
	    }
	  else
	    {
	      /* Win 9x/Me does not support the DONT_RESOLVE_DLL_REFERENCES
flag,
	         so we have to load the DLL straight up */
	      h = LoadLibrary (d.name);
	    }
	  
	  if (h != d.handle)
	  {
	    /* We treat each error case differently */
	    if (h == NULL)
	      {
	      	/* Some major failure. We cannot recover from this, so we bale
out */
	        api_fatal ("child unable to load %s", d.name);
	      }
	      
	    if (h > d.handle)
	      {
	        /* Loaded too high. We cannot fix this, so we bale out */
	        api_fatal ("unable to remap %s to same address as parent(%p) !=
%p",
		           d.name, d.handle, h);
	      }
	      
	    /* If the thread reaches here, then the DLL loaded too low.
	       We can attempt to fix this by unloading it, reserving all free
	       memory up to the address we want, then re-loading it and finally
	       releasing the reserved memory. Sometimes this works, sometimes 
	       it dont. */
	    FreeLibrary (h);
	    reserve_upto (d.name, (DWORD) d.handle);
	    h = LoadLibrary(d.name);
	    release_upto (d.name, (DWORD) d.handle);
	    if (h != d.handle)
	      {
	      	/* If its still the wrong address, then there's nothing more we
	      	   can do. Bale out */
	        api_fatal ("unable to remap %s to same address as parent(%p) !=
%p",
		           d.name, d.handle, h);
	      }
	  }
	}
      next = d.next;	/* Get the address of the next DLL. */
    }
  in_forkee = 0;
}


--Multipart_Mon__3_Mar_2003_17:57:01_+0000_10180360
Content-Type: application/octet-stream;
 name="dll_init.cc-patch"
Content-Disposition: attachment;
 filename="dll_init.cc-patch"
Content-Transfer-Encoding: base64

SW5kZXg6IGRsbF9pbml0LmNjCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KUkNTIGZpbGU6IC9jdnMvc3JjL3NyYy93aW5z
dXAvY3lnd2luL2RsbF9pbml0LmNjLHYKcmV0cmlldmluZyByZXZpc2lvbiAxLjM2CmRpZmYgLXUg
LXAgLXIxLjM2IGRsbF9pbml0LmNjCi0tLSBkbGxfaW5pdC5jYwkyIE1hciAyMDAzIDE4OjM3OjE3
IC0wMDAwCTEuMzYKKysrIGRsbF9pbml0LmNjCTMgTWFyIDIwMDMgMTc6NDU6MjIgLTAwMDAKQEAg
LTI4Nyw3ICsyODcsNiBAQCB2b2lkCiBkbGxfbGlzdDo6bG9hZF9hZnRlcl9mb3JrIChIQU5ETEUg
cGFyZW50LCBkbGwgKmZpcnN0KQogewogICBpbl9mb3JrZWUgPSAxOwotICBpbnQgdHJ5MiA9IDA7
CiAgIGRsbCBkOwogCiAgIHZvaWQgKm5leHQgPSBmaXJzdDsKQEAgLTMwNCw0OCArMzAzLDYxIEBA
IGRsbF9saXN0Ojpsb2FkX2FmdGVyX2ZvcmsgKEhBTkRMRSBwYXJlbnQKIAkgdGhlIHBhcmVudCBo
YWQgc29tZSBvZiB0aG9zZS4gKi8KICAgICAgIGlmIChkLnR5cGUgPT0gRExMX0xPQUQpCiAJewot
CSAgYm9vbCB1bmxvYWQgPSB0cnVlOwotCSAgSE1PRFVMRSBoID0gTG9hZExpYnJhcnlFeCAoZC5u
YW1lLCBOVUxMLCBET05UX1JFU09MVkVfRExMX1JFRkVSRU5DRVMpOwotCi0JICBpZiAoIWgpCi0J
ICAgIHN5c3RlbV9wcmludGYgKCJjYW4ndCByZWxvYWQgJXMiLCBkLm5hbWUpOwotCSAgLyogU2Vl
IGlmIERMTCB3aWxsIGxvYWQgaW4gcHJvcGVyIHBsYWNlLiAgSWYgc28sIGZyZWUgaXQgYW5kIHJl
bG9hZAotCSAgICAgaXQgdGhlIHJpZ2h0IHdheS4KLQkgICAgIEl0IHNvcnQgb2Ygc3RpbmtzIHRo
YXQgd2UgY2FuJ3QgaW52ZXJ0IHRoZSBvcmRlciBvZiB0aGUgRnJlZUxpYnJhcnkKLQkgICAgIGFu
ZCBMb2FkTGlicmFyeSBzaW5jZSBNaWNyb3NvZnQgZG9jdW1lbnRhdGlvbiBzZWVtcyB0byBpbXBs
eSB0aGF0IHRoYXQKLQkgICAgIHNob3VsZCBkbyB3aGF0IHdlIHdhbnQuICBIb3dldmVyLCBzaW5j
ZSB0aGUgbGlicmFyeSB3YXMgbG9hZGVkIGFib3ZlLAotCSAgICAgdGhlIHNlY29uZCBMb2FkTGli
cmFyeSBkb2VzIG5vdCBleGVjdXRlIGl0J3Mgc3RhcnR1cCBjb2RlIHVubGVzcyBpdAotCSAgICAg
aXMgZmlyc3QgdW5sb2FkZWQuICovCi0JICBlbHNlIGlmIChoID09IGQuaGFuZGxlKQorCSAgSE1P
RFVMRSBoOworCSAgaWYgKHdpbmNhcC5pc193aW5udCgpKQogCSAgICB7Ci0JICAgICAgaWYgKHVu
bG9hZCkKLQkJewotCQkgIEZyZWVMaWJyYXJ5IChoKTsKLQkJICBMb2FkTGlicmFyeSAoZC5uYW1l
KTsKLQkJfQorCSAgICAgIC8qIE9uIE5ULzJLL1hQIHdlIGZpcnN0IHRlc3QtbG9hZCB0aGUgRExM
IHRvIHNlZSBpZiBpZiBnb2VzIHRvIHRoZSByaWdodAorCSAgICAgICAgIGFkZHJlc3MuIFdlIGhh
dmUgdG8gZG8gdGhpcyBiZWNhdXNlIGlmIHdlIGxvYWQgaXQgZnVsbHkgYW5kIGl0cyBhdCB0aGUK
KwkgICAgICAgICB3cm9uZyBhZGRyZXNzIHRoZW4gdGhlIGxhdGVyIGNvZGUgdGhhdCB0cmllcyB0
byBhZGp1c3QgdGhlIGxvYWQgYWRkcmVzcyAKKwkgICAgICAgICBmYWlscy4gKi8KKwkgICAgICBo
ID0gTG9hZExpYnJhcnlFeCAoZC5uYW1lLCBOVUxMLCBET05UX1JFU09MVkVfRExMX1JFRkVSRU5D
RVMpOworCSAgICAgIGlmIChoID09IGQuaGFuZGxlKQorCSAgICAgICAgeworCSAgICAgICAgICAv
KiBXZSBnb3QgdGhlIHJpZ2h0IGFkZHJlc3MgZmlyc3QgdGltZS4gU28gbm93IGxvYWQgaXQgcHJv
cGVybHkgKi8KKwkgICAgICAgICAgRnJlZUxpYnJhcnkoaCk7CisJICAgICAgICAgIGggPSBMb2Fk
TGlicmFyeShkLm5hbWUpOworCSAgICAgICAgfQogCSAgICB9Ci0JICBlbHNlIGlmICh0cnkyKQot
CSAgICBhcGlfZmF0YWwgKCJ1bmFibGUgdG8gcmVtYXAgJXMgdG8gc2FtZSBhZGRyZXNzIGFzIHBh
cmVudCglcCkgIT0gJXAiLAotCQkgICAgICAgZC5uYW1lLCBkLmhhbmRsZSwgaCk7CiAJICBlbHNl
CiAJICAgIHsKLQkgICAgICAvKiBJdCBsb2FkZWQgaW4gdGhlIHdyb25nIHBsYWNlLiAgRHVubm8g
d2h5IHRoaXMgaGFwcGVucyBidXQgaXQgYWx3YXlzCi0JCSBzZWVtcyB0byBoYXBwZW4gd2hlbiB0
aGVyZSBhcmUgbXVsdGlwbGUgRExMcyBhdHRlbXB0aW5nIHRvIGxvYWQgaW50bwotCQkgdGhlIHNh
bWUgYWRkcmVzcyBzcGFjZS4gIEluIHRoZSAiZm9ya2VkIiBwcm9jZXNzLCB0aGUgc2Vjb25kIERM
TCBhbHdheXMKLQkJIGxvYWRzIGludG8gYSBkaWZmZXJlbnQgbG9jYXRpb24uICovCi0JICAgICAg
RnJlZUxpYnJhcnkgKGgpOwotCSAgICAgIC8qIEJsb2NrIGFsbCBvZiB0aGUgbWVtb3J5IHVwIHRv
IHRoZSBuZXcgbG9hZCBhZGRyZXNzLiAqLwotCSAgICAgIHJlc2VydmVfdXB0byAoZC5uYW1lLCAo
RFdPUkQpIGQuaGFuZGxlKTsKLQkgICAgICB0cnkyID0gMTsJCS8qIEFuZCB0cnkgKi8KLQkgICAg
ICBjb250aW51ZTsJCS8qICBhZ2Fpbi4gKi8KLQkgICAgfQotCSAgLyogSWYgd2UgcmVhY2hlZCBo
ZXJlLCBhbmQgdHJ5MiBpcyBzZXQsIHRoZW4gdGhlcmUgaXMgYSBsb3Qgb2YgbWVtb3J5IHRvCi0J
ICAgICByZWxlYXNlLiAqLwotCSAgaWYgKHRyeTIpCi0JICAgIHsKLQkgICAgICByZWxlYXNlX3Vw
dG8gKGQubmFtZSwgKERXT1JEKSBkLmhhbmRsZSk7Ci0JICAgICAgdHJ5MiA9IDA7CisJICAgICAg
LyogV2luIDl4L01lIGRvZXMgbm90IHN1cHBvcnQgdGhlIERPTlRfUkVTT0xWRV9ETExfUkVGRVJF
TkNFUyBmbGFnLAorCSAgICAgICAgIHNvIHdlIGhhdmUgdG8gbG9hZCB0aGUgRExMIHN0cmFpZ2h0
IHVwICovCisJICAgICAgaCA9IExvYWRMaWJyYXJ5IChkLm5hbWUpOwogCSAgICB9CisJICAKKwkg
IGlmIChoICE9IGQuaGFuZGxlKQorCSAgeworCSAgICAvKiBXZSB0cmVhdCBlYWNoIGVycm9yIGNh
c2UgZGlmZmVyZW50bHkgKi8KKwkgICAgaWYgKGggPT0gTlVMTCkKKwkgICAgICB7CisJICAgICAg
CS8qIFNvbWUgbWFqb3IgZmFpbHVyZS4gV2UgY2Fubm90IHJlY292ZXIgZnJvbSB0aGlzLCBzbyB3
ZSBiYWxlIG91dCAqLworCSAgICAgICAgYXBpX2ZhdGFsICgiY2hpbGQgdW5hYmxlIHRvIGxvYWQg
JXMiLCBkLm5hbWUpOworCSAgICAgIH0KKwkgICAgICAKKwkgICAgaWYgKGggPiBkLmhhbmRsZSkK
KwkgICAgICB7CisJICAgICAgICAvKiBMb2FkZWQgdG9vIGhpZ2guIFdlIGNhbm5vdCBmaXggdGhp
cywgc28gd2UgYmFsZSBvdXQgKi8KKwkgICAgICAgIGFwaV9mYXRhbCAoInVuYWJsZSB0byByZW1h
cCAlcyB0byBzYW1lIGFkZHJlc3MgYXMgcGFyZW50KCVwKSAhPSAlcCIsCisJCSAgICAgICAgICAg
ZC5uYW1lLCBkLmhhbmRsZSwgaCk7CisJICAgICAgfQorCSAgICAgIAorCSAgICAvKiBJZiB0aGUg
dGhyZWFkIHJlYWNoZXMgaGVyZSwgdGhlbiB0aGUgRExMIGxvYWRlZCB0b28gbG93LgorCSAgICAg
ICBXZSBjYW4gYXR0ZW1wdCB0byBmaXggdGhpcyBieSB1bmxvYWRpbmcgaXQsIHJlc2VydmluZyBh
bGwgZnJlZQorCSAgICAgICBtZW1vcnkgdXAgdG8gdGhlIGFkZHJlc3Mgd2Ugd2FudCwgdGhlbiBy
ZS1sb2FkaW5nIGl0IGFuZCBmaW5hbGx5CisJICAgICAgIHJlbGVhc2luZyB0aGUgcmVzZXJ2ZWQg
bWVtb3J5LiBTb21ldGltZXMgdGhpcyB3b3Jrcywgc29tZXRpbWVzIAorCSAgICAgICBpdCBkb250
LiAqLworCSAgICBGcmVlTGlicmFyeSAoaCk7CisJICAgIHJlc2VydmVfdXB0byAoZC5uYW1lLCAo
RFdPUkQpIGQuaGFuZGxlKTsKKwkgICAgaCA9IExvYWRMaWJyYXJ5KGQubmFtZSk7CisJICAgIHJl
bGVhc2VfdXB0byAoZC5uYW1lLCAoRFdPUkQpIGQuaGFuZGxlKTsKKwkgICAgaWYgKGggIT0gZC5o
YW5kbGUpCisJICAgICAgeworCSAgICAgIAkvKiBJZiBpdHMgc3RpbGwgdGhlIHdyb25nIGFkZHJl
c3MsIHRoZW4gdGhlcmUncyBub3RoaW5nIG1vcmUgd2UKKwkgICAgICAJICAgY2FuIGRvLiBCYWxl
IG91dCAqLworCSAgICAgICAgYXBpX2ZhdGFsICgidW5hYmxlIHRvIHJlbWFwICVzIHRvIHNhbWUg
YWRkcmVzcyBhcyBwYXJlbnQoJXApICE9ICVwIiwKKwkJICAgICAgICAgICBkLm5hbWUsIGQuaGFu
ZGxlLCBoKTsKKwkgICAgICB9CisJICB9CiAJfQogICAgICAgbmV4dCA9IGQubmV4dDsJLyogR2V0
IHRoZSBhZGRyZXNzIG9mIHRoZSBuZXh0IERMTC4gKi8KICAgICB9Cg==


--Multipart_Mon__3_Mar_2003_17:57:01_+0000_10180360
Content-Type: text/plain; charset=us-ascii

--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Bug reporting:         http://cygwin.com/bugs.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/
--Multipart_Mon__3_Mar_2003_17:57:01_+0000_10180360--

- Raw text -


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