Mail Archives: cygwin/2005/07/11/22:18:07
On Mon, Jul 11, 2005 at 11:29:10PM +0200, Gerrit P. Haase wrote:
>Adye, TJ (Tim) wrote:
>>Thanks for the Perl update.
>>
>>Unfortunately this doesn't seem to fix the problem I reported earlier
>>("Perl Win32::Shortcut screws up fork"). My test script worked fine
>>after "rebaseall", but when I reinstalled Cygwin from scratch (including
>>Perl 5.8.7-2) it dies with
>>
>>C:\cygwin\bin\perl.exe (3772): *** unable to remap
>>C:\cygwin\lib\perl5\vendor_perl\5.8\cygwin\auto\Win32\Shortcut\Shortcut.
>>dll to same address as parent(0x950000) != 0xBF0000
>> 17 [main] perl 3448 fork_parent: child 3772 died waiting for dll
>>loading
>>
>>The addresses are now different, if that's any consolation (previously
>>it reported parent(0xBF0000) != 0x1110000).
>>
>>Presumably "rebaseall" will fix it again, but I'll keep the pristine
>>Cygwin installation for further tests if that's helpful.
>
>Jason said it in the "Perl Win32::Shortcut screws up fork" thread,
>auto-image-base helps but it doesn't resolve all issues. A certain
>amount of pad is required between the base DLL addresses and it seems
>that this is one of those cases where the padding is too small.
I really can't see why this padding would be needed for fork. If the dlls are
in the same place in the parent and the child (as should be the case after
an auto-image-base) then fork() shouldn't care where they're located. It is
only when some dlls are not correctly based and some are that I could see
problems.
In any event, if the problem really does occur, even with all dlls
correctly based, there's certainly no reason to stand on our heads trying
to accommodate cygwin behavior. We golly gee just might be able to fix
cygwin if we have a reproducible test case.
cgf
--
Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple
Problem reports: http://cygwin.com/problems.html
Documentation: http://cygwin.com/docs.html
FAQ: http://cygwin.com/faq/
- Raw text -