Mirsad Todorovac wrote:
Here are the test results on my box.
Test Run By mtodorov on 2007-02-13 22:15:43 Native configuration is i686-pc-linux-gnu (domac) gpc 20060325, based on gcc-4.1.1, flags: -g -O3 -W -Wall -Wno-unused TEST agettext2test.pas: SKIPPED: could not set locale `de_DE' TEST aregextest.pas: SKIPPED: librx not installed TEST backtracerr.pas: 14c14,71 < ./test_run: line 339: 20465 Killed ./"$A_OUT" "$1"
<snip> > failed > TEST fay.pas: 1c1,12 > < ./test_run: line 339: 420 Killed ./"$A_OUT" "$1" > --- <snip> > failed > TEST fjf165a.pas: SKIPPED: German locale not installed > TEST fjf206c.pas: failed: ./fjf206c.pas:2: error: arithmetical overflow > ./fjf206c.pas:2: error: constant overflow in expression > > TEST fjf322.pas: 'result_0.length./fjf322.pas: In function `o': > gpc1: warnings being treated as errors > ./fjf322.pas:8: warning: ' is used uninitialized in this function > failed > TEST fjf35.pas: ./test_run: line 339: 16467 Killed ./"$A_OUT" "$1" > TEST fjf395a.pas: a Value 2 > TEST fjf395b.pas: a Value -128 > TEST fjf403b.pas: failed: failed > > TEST fjf563e.pas: failed: failed > > TEST fjf587b.pas: 'concat_0._p_Schema_[3]{lb: 1 sz: 1}./fjf587b.pas: In procedure `Foo': > gpc1: warnings being treated as errors > ./fjf587b.pas:5: warning: ' is used uninitialized in this function > failed > TEST fjf779a.pas: failed: > TEST fjf779b.pas: failed: > TEST fjf779e.pas: failed: > TEST fjf779f.pas: failed: > TEST fjf779g.pas: failed: > TEST fproc.pas: 4c4,11 > < Stack frame: 0 formal print =./test_run: line 339: 1897 Killed ./"$A_OUT" "$1" <snip> > failed > TEST gmptest.pas: SKIPPED: libgmp (>=3.x) not installed > TEST knuth1.pas: ./test_run: line 339: 175 Killed ./"$A_OUT" "$1" > TEST nicola4c.pas: failed: > TEST nlgpp.pas: ./test_run: line 339: 21147 Killed ./"$A_OUT" "$1" > TEST nlgpp2.pas: 13c13,30 > < ./test_run: line 339: 12038 Killed ./"$A_OUT" "$1" <snip> > TEST t6334-2.pas: ./test_run: line 339: 27049 Killed ./"$A_OUT" "$1" > TEST t6p6p3p4.pas: ./test_run: line 339: 7676 Killed ./"$A_OUT" "$1" >
That looks bad. The 'Killed' messages shows that you have serious problem with nonlocal gotos. That is strange, as nonlocal gotos worked fine for me and other folks. Are you sure that you correctly applied patches? Also, is it fresh build (just after patching) or you patched failed build and re-run make?
I have rerun tests, and I've run /sbin/chpax -pemrxs a.out after each compile, but clumsy, since it is hard for me to modify test_run code.
I used gpc wrapper shell script, but I did it clumsy as I said and created some "a.out: No such file or directory" errors.
BUT THE GOOD NEWS is that there are no longer "Killed" error messages, so I think we've found the murderer: it was Linux's PAX kernel extension!
chpax has following options, so you will see why it could have affected nonlocal gotos:
------------------------------------------------------------------ mtodorov@domac:~/pascal/gcc-4.1.1/gcc/p/test$ /sbin/chpax -v /sbin/chpax 0.7 .::. Manage PaX flags for binaries Usage: /sbin/chpax OPTIONS FILE1 FILE2 FILEN ... -P enforce paging based non-executable pages -p do not enforce paging based non-executable pages -E emulate trampolines -e do not emulate trampolines -M restrict mprotect() -m do not restrict mprotect() -R randomize mmap() base [ELF only] -r do not randomize mmap() base [ELF only] -X randomize ET_EXEC base [ELF only] -x do not randomize ET_EXEC base [ELF only] -S enforce segmentation based non-executable pages -s do not enforce segmentation based non-executable pages -v view current flag mask -z zero flag mask (next flags still apply)
The flags only have effect when running the patched Linux kernel. mtodorov@domac:~/pascal/gcc-4.1.1/gcc/p/test$ --------------------------------------------------------------------
The wrapper is simplistic, it still does something wrong. It does not work in all cases, and I can investigate, but I believe Frank will know immediatelly the solution, provided he has enough time ... The wrapper:
p/test/gpc: ------------------------------------------------- #/bin/bash -f
/usr/local/bin/gpc $*
if [ -x a.out ]; then /sbin/chpax -pemrxs a.out fi -------------------------------------------------
This far we have located fault on PAX process killer, so I think the further work is the question whether to allow post-processing command to be executed in test_run script in a general manner, so chpax could be safely executed whenever $PC is.
I am waiting for further instructions. I saw some warnings about number of parms in format not matching parameter list, so I could concentrate on those.
Regards, Mirsad