On Fri, Dec 09, 2011 at 09:55:18AM -0500, Ryan Johnson wrote:
>> On 09/12/2011 5:58 AM, Denis Excoffier wrote:
>> >I use the latest packages and cygwin snapshots. The problem described
>> >below began several snapshots in the past, around beginning of December.
>> >
>> >The following program, with static allocation of a reasonable amount
>> >of data, segfaults, maybe in alloca(). With a smaller size
>> >(eg 10000) it's ok. With new/malloc (even with 100 times more) it's
>> >ok. With C or C++. 100% reproducible.
>> >   unsigned int const SIZE = 689471;
>> >   int foo[SIZE];
>> Reasonable? You're trying to stack-allocate 2.5MB of data. Don't do
>> that -- stack sizes are 2MB or less in most operating systems.
>> Besides, doing anything useful with a buffer that size would
>> completely drown out the overhead of calling malloc.

You're right.

% ulimit -a
core file size          (blocks, -c) unlimited
data seg size           (kbytes, -d) unlimited
file size               (blocks, -f) unlimited
open files                      (-n) 256
pipe size            (512 bytes, -p) 8
stack size              (kbytes, -s) 2034
cpu time               (seconds, -t) unlimited
max user processes              (-u) 256
virtual memory          (kbytes, -v) unlimited
% ulimit -s 3000
sh: ulimit: stack size: cannot modify limit: Invalid argument
%

Regards,

Denis Excoffier.

--
Problem reports:       http://cygwin.com/problems.html
FAQ:                   http://cygwin.com/faq/
Documentation:         http://cygwin.com/docs.html
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple

Reply via email to