Talk About Network

Google


Register and Login
Nick
Password
Register create new account Sign up is FREE and you can post replies, new topics, bookmark posts and more!
Recover lost password


Programming > Compilers LCC > Re: What can I ...
Latest [ Topics | Posts ] Archive Post A New Topic Post a Reply
<< Topic < Post Post 8 of 23 Topic 955 of 1070
Post > Topic >>

Re: What can I do?

by Giorgos Keramidas <keramida@[EMAIL PROTECTED] > Jun 3, 2007 at 03:33 PM

On Sun, 03 Jun 2007 00:16:04 +0200, Gregor H. <nomail@[EMAIL PROTECTED]
> wrote:
>On Sun, 03 Jun 2007 00:09:22 +0200, jacob navia
><jacob@[EMAIL PROTECTED]
> wrote:
>>
>> Consider this program:
>>
>> int fn(int a)
>> {
>>
>>         if (a == 6 || a == 7 || a == 4 || a == 67 || a == 78 &&
>>         a == 6 || a == 7 || a == 4 || a == 67 || a == 78 &&
>>         a == 6 || a == 7 || a == 4 || a == 67 || a == 78 &&
>>         a == 6 || a == 7 || a == 4 || a == 67 || a == 78 &&
>>
>>         /* 4955 lines exactly the same as above elided */
>>
>>         a == 6 || a == 7 || a == 4 || a == 67 || a == 78 &&
>>         a == 6 || a == 7 || a == 4 || a == 67 || a == 78 )
>>                 return 1;
>>         return 0;
>> }
>>
>> This program makes the lcc compiler crash with stack overflow.
>> The evaluation of this SINGLE statement is recursive, each clause
>> calls recursively the expr3() function in expr.c.
>>
>> What can I do here?
>>
>> Fixing this would have to change drastically the design of the
>> compiler. In the other hand leaving this as is would leave a
>> compiler that can crash in some cir***stances.
>
> Would be interesting to see how gcc (and some other c compilers)
> deal with this construction (with, say, >10.000 lines). :-)

gcc 4.2.0 on FreeBSD 7.0 works fine with at least 16384 lines:

% $ gcc -v
% Using built-in specs.
% Target: i386-undermydesk-freebsd
% Configured with: FreeBSD/i386 system compiler
% Thread model: posix
% gcc version 4.2.0 20070514 [FreeBSD]
% $ expand foo.c | \
%   fgrep '    a == 6 || a == 7 || a == 4 || a == 67 || a == 78 &&' | \
%   wc -l
%    16384
% $ for count in `jot 10 1 10` ; do \
%       /usr/bin/time gcc -ansi -pedantic -c foo.c ; \
%   done
%         6.14 real         5.36 user         0.74 sys
%         4.57 real         4.11 user         0.45 sys
%         4.57 real         4.24 user         0.31 sys
%         4.56 real         3.57 user         0.98 sys
%         4.56 real         3.94 user         0.60 sys
%         4.57 real         3.60 user         0.96 sys
%         4.56 real         3.81 user         0.74 sys
%         4.52 real         4.03 user         0.48 sys
%         4.57 real         4.09 user         0.47 sys
%         4.56 real         3.72 user         0.83 sys
% $

It does require and use a big amount of memoty (more than 140 MB of
virtual process size in some cases), but at least it doesn't crash.

The memory needed for building the function shoots as high as 512 MB
with more then 65536 lines, but given enough time and virtual memory
space GCC completes building the function after some time (when it
starts using large amounts of swap space, performance drops to a crawl
though).
 




 23 Posts in Topic:
What can I do?
jacob navia <jacob@[EM  2007-06-03 00:09:22 
Re: What can I do?
Gregor H. <nomail@[EMA  2007-06-03 00:16:04 
Re: What can I do?
Gregor H. <nomail@[EMA  2007-06-03 00:26:29 
Re: What can I do?
Gregor H. <nomail@[EMA  2007-06-03 00:39:23 
Re: What can I do?
jacob navia <jacob@[EM  2007-06-03 09:06:35 
Re: What can I do?
Gregor H. <nomail@[EMA  2007-06-03 15:29:35 
Re: What can I do?
John Nagle <nagle@[EMA  2007-06-02 15:34:37 
Re: What can I do?
Giorgos Keramidas <ker  2007-06-03 15:33:48 
Re: What can I do?
richard@[EMAIL PROTECTED]  2007-06-02 22:23:21 
Re: What can I do?
jacob navia <jacob@[EM  2007-06-03 09:08:00 
Re: What can I do?
Eric Schmidt <eric4129  2007-06-02 16:54:03 
Re: What can I do?
"Rod Pemberton"  2007-06-02 22:28:28 
Re: What can I do?
richard@[EMAIL PROTECTED]  2007-06-03 15:58:59 
Re: What can I do?
"Rod Pemberton"  2007-06-03 12:43:25 
Re: What can I do?
Hallvard B Furuseth <h  2007-06-03 21:22:48 
Re: What can I do?
Cesar Rabak <csrabak@[  2007-06-03 02:18:53 
Re: What can I do?
Keith Thompson <kst-u@  2007-06-03 00:00:00 
Re: What can I do?
jacob navia <jacob@[EM  2007-06-03 09:15:16 
Re: What can I do?
CBFalconer <cbfalconer  2007-06-03 02:09:14 
Re: What can I do?
Dave Hanson <drhanson@  2007-06-03 14:53:50 
Re: What can I do?
Hallvard B Furuseth <h  2007-06-03 21:44:46 
Re: What can I do?
Keith Thompson <kst-u@  2007-06-03 13:08:36 
Re: What can I do?
"christian.bau"  2007-06-03 14:32:10 

Post A Reply:
  Go here to Signup

AddThis Feed Button


About - Advertising - Contact - Frequently Asked Questions - Privacy Policy - Terms of Use - Signup

Contact
tan12V112 Tue Oct 7 12:46:43 CDT 2008.