two 4GB mallocs => SEGV
Peter Wemm
peter at wemm.org
Wed Oct 27 10:05:23 PDT 2004
On Tuesday 26 October 2004 02:32 pm, David O'Brien wrote:
> On Tue, Oct 26, 2004 at 12:55:06PM -0500, James R. Van Artsalen wrote:
> > David O'Brien wrote:
> > >malloc.c:map_pages() calls brk(2) and this is where it goes to
> > > la-la land.
> >
> > The brk() kernel call is probably failing due to ulimit being
> > exceeded and not anything mysterious.
>
> # ulimit -a | grep virt
> virtual memory (kbytes, -v) unlimited
The data size limit is 8GB though.
> BTW, a statically built binary (ie, using libc.a) just hangs in the
> brk(2) call.
Yes, and that is rather worrying.
> > A few months ago I posted this bug in the libc brk(2) code - the
> > stack is not balanced if the kernel returns an error. I'm not
> > running current code at the moment but see if you brk.S has a stack
> > issue at the err: label. Stick in this pop if so and report if
> > malloc(3c) then returns NULL instead of crashing, then up your
> > ulimit and try again and see if all works without error.
> >
> > --- lib/libc/amd64/sys/brk.S.~1~ Sat May 24 12:35:23 2003
> > +++ lib/libc/amd64/sys/brk.S Fri Apr 9 02:02:22 2004
> > @@ -78,6 +78,7 @@
> > popq %rdi
> > ret
> > err:
> > + popq %rdi
> > #ifdef PIC
> > movq PIC_GOT(HIDENAME(cerror)),%rdx
> > jmp *%rdx
>
> Today's code has:
>
> err:
> addq $8, %rsp
> #ifdef PIC
> movq PIC_GOT(HIDENAME(cerror)),%rdx
> jmp *%rdx
>
>
> so the stack should be OK.
Where do you see the addq? Its not in cvs that I can see.. Oh, its in
sbrk.S - this patch is against brk.S.
--
Peter Wemm - peter at wemm.org; peter at FreeBSD.org; peter at yahoo-inc.com
"All of this is for nothing if we don't go to the stars" - JMS/B5
More information about the freebsd-amd64
mailing list