| www.delorie.com/archives/browse.cgi | search |
| X-Spam-Check-By: | sourceware.org |
| From: | "Dave Korn" <dave DOT korn AT artimi DOT com> |
| To: | <cygwin AT cygwin DOT com> |
| Subject: | RE: simple test triggers fork errs for me in 5/27 snapshot |
| Date: | Mon, 29 May 2006 14:03:43 +0100 |
| Message-ID: | <023801c68320$50831d80$a501a8c0@CAM.ARTIMI.COM> |
| MIME-Version: | 1.0 |
| X-Mailer: | Microsoft Office Outlook 11 |
| In-Reply-To: | <022d01c6830f$61ca8c10$a501a8c0@CAM.ARTIMI.COM> |
| Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
| List-Unsubscribe: | <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com> |
| List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
| List-Archive: | <http://sourceware.org/ml/cygwin/> |
| List-Post: | <mailto:cygwin AT cygwin DOT com> |
| List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/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 |
On 29 May 2006 12:03, Dave Korn wrote:
Ok, it's real weird.
> Here's the nonsense command sequence again:
>
> cd /tmp;echo -ne '#!/bin/bash -u\nfoo "$@"\n' >bar;chmod +x bar
> foo() { for f ;do bash -c true ;done ; } ; export -f foo
> find /usr -print0|xargs -0 ./bar
I found that it also works just as well to run "find /usr -print0 >
file.txt" first, let it run until it's about half a meg, and then can
reproduce the problem each time with
xargs -a file.txt -0 ./bar.sh
I managed to get one caught in windbg by putting a breakpoint in the error
message code:
5 [main] bash 2760 child_info_fork::alloc_stack_hard_way: fork: can't
rese
rve memory for stack 0x23C580 - 0x240000, Win32 error 487
I really can't understand why it won't let us allocate the memory. Here's
the surrounding area info from !vadump:
BaseAddress: 00230000
AllocationBase: 00230000
AllocationProtect: 00000002 PAGE_READONLY
RegionSize: 00003000
State: 00001000 MEM_COMMIT
Protect: 00000002 PAGE_READONLY
Type: 00040000 MEM_MAPPED
BaseAddress: 00233000
AllocationBase: 00000000
RegionSize: 0000d000
State: 00010000 MEM_FREE
Protect: 00000001 PAGE_NOACCESS
BaseAddress: 00240000
AllocationBase: 00240000
AllocationProtect: 00000004 PAGE_READWRITE
RegionSize: 00013000
State: 00001000 MEM_COMMIT
Protect: 00000004 PAGE_READWRITE
Type: 00020000 MEM_PRIVATE
So AFAICT the memory is free and should be allocatable, but it really isn't
going to let us:
0:000> !address 0x23C580
00233000 : 00233000 - 0000d000
Type 00000000
Protect 00000001 PAGE_NOACCESS
State 00010000 MEM_FREE
Usage RegionUsageFree
0:000> !vprot 0x23C580
BaseAddress: 0023c000
AllocationBase: 00000000
RegionSize: 00004000
State: 00010000 MEM_FREE
Protect: 00000001 PAGE_NOACCESS
0:000> .dvalloc /b 0x23C580 /r 0x00003a80
Allocation failed, Win32 error 487
"Attempt to access invalid address."
0:000> .dvalloc /b 0x23C580 /r 0x00003a00
Allocation failed, Win32 error 487
"Attempt to access invalid address."
Anyone got any good ideas?
cheers,
DaveK
--
Can't think of a witty .sigline today....
--
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/
| webmaster | delorie software privacy |
| Copyright © 2019 by DJ Delorie | Updated Jul 2019 |