Date: Sun, 25 May 2003 23:31:41 -0400 (EDT) From: Daniel Eischen <eischen@pcnet1.pcnet.com> To: Andrew MacIntyre <andymac@bullseye.apana.org.au> Cc: alane@freebsd.org Subject: Re: setting stacksize in "initial" thread (pthreads, 4.8R) Message-ID: <Pine.GSO.4.10.10305252329450.14009-100000@pcnet1.pcnet.com> In-Reply-To: <20030526084710.A57768@bullseye.apana.org.au>
next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, 26 May 2003, Andrew MacIntyre wrote:
> On Sun, 25 May 2003, Daniel Eischen wrote:
>
> > On Sun, 25 May 2003, Andrew MacIntyre wrote:
> >
> > > I have a situation with a Python interpreter built from Python
> > > CVS sources that is hitting the stack limit for the "initial" thread
> > > imposed by libc_r: PTHREAD_STACK_INITIAL in
> > > /usr/src/lib/libc_r/uthread/pthread_private.h is set to 1MB (0x100000).
>
> {...}
>
> > Is this something that is common to all python scripts, or is
> > it just your own script(s) that is(are) getting caught. It
> > seems 1MB is an awful lot to be on the stack, and perhaps some
> > things are better malloc'd.
>
> The problem actually occurs with recursive matches in Python's regex
> engine. Python has a hardcoded regex recursion limit, which has trapped
> ballistic matches before running out of the default stack. However a
> couple of recent fixes to the regex engine have increased stack
> consumption, and the hard limit has to be lowered.
How do you know it is the main thread stack and not a different
thread stack that is getting exceeded? By default, threads
other than main get a 64K stack, and this is totally configurable
by the application.
--
Dan Eischen
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.GSO.4.10.10305252329450.14009-100000>
