whizard is hosted by Hepforge, IPPP Durham

Opened 10 years ago

Closed 10 years ago

Last modified 10 years ago

#591 closed defect (fixed)

Reconsider scan command: catch seg fault in structure_5 in quad precision with gfortran 4.7.0

Reported by: Juergen Reuter Owned by: Juergen Reuter
Priority: P0 Milestone: v2.2.0
Component: core Version: 2.1.1
Severity: critical Keywords:
Cc:

Description

|  |  |  |  +  KEYWORD     '=>'  = [keyword] =>
|  |  |  |  +  SEQUENCE    <expr>  =  <term>
|  |  |  |  |  +  SEQUENCE    <term>  =  <factor>
|  |  |  |  |  |  +  SEQUENCE    <factor>  =  <integer_value>
|  |  |  |  |  |  |  +  SEQUENCE    <integer_value>  =  <integer_literal>
|  |  |  |  |  |  |  |  +  INTEGER     <integer_literal>  = 900
|  |  |  |  +  SEQUENCE    <step_spec>  =  '/+/' <expr>
|  |  |  |  |  +  KEYWORD     '/+/'  = [keyword] /+/

Program received signal SIGSEGV: Segmentation fault - invalid memory reference.

Backtrace for this error:
#0  0x7FA3B76DDE97
#1  0x7FA3B76DE464
#2  0x3A0BA3299F
#3  0x7FA43258E700
#4  0x7FA43258E73F
#5  0x7FA432AA2B5D
#6  0x7FA432AA896C
#7  0x7FA432AF9CB0
#8  0x7FA432AF99CE
#9  0x7FA433D984AD
#10  0x7FA433D9905E
#11  0x3A0BA1ED1C
./run_whizard.sh: line 26: 11311 Segmentation fault      (core dumped) ../src/whizard --logfile $basename.log --no-banner --library ${libname}_lib --rebuild $* $script.sin
91,105c91,103
< sqrts =  2.500000000000E+02
< sqrts =  3.000000000000E+02
< sqrts =  3.500000000000E+02
< sqrts =  4.000000000000E+02
< sqrts =  4.500000000000E+02
< sqrts =  5.000000000000E+02
< sqrts =  6.000000000000E+02
< sqrts =  7.000000000000E+02
< sqrts =  8.000000000000E+02
< sqrts =  9.000000000000E+02
< sqrts =  1.000000000000E+03
< sqrts =  1.000000000000E+04
< sqrts =  1.000000000000E+05
< | WHIZARD run finished.
< |=============================================================================|
---
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00

Change History (18)

comment:1 Changed 10 years ago by Juergen Reuter

In 4.7.3 it doesn't segfault with quadruple precision, but it gives the wrong output:

91,103c91,103
< sqrts =  2.500000000000E+02
< sqrts =  3.000000000000E+02
< sqrts =  3.500000000000E+02
< sqrts =  4.000000000000E+02
< sqrts =  4.500000000000E+02
< sqrts =  5.000000000000E+02
< sqrts =  6.000000000000E+02
< sqrts =  7.000000000000E+02
< sqrts =  8.000000000000E+02
< sqrts =  9.000000000000E+02
< sqrts =  1.000000000000E+03
< sqrts =  1.000000000000E+04
< sqrts =  1.000000000000E+05
---
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00
> sqrts =  0.000000000000E+00

This is a blocker :((((

comment:2 Changed 10 years ago by Juergen Reuter

Summary: Seg fault in structure_5 in quad precision with gfortran 4.7.0Reconsider scan command: catch seg fault in structure_5 in quad precision with gfortran 4.7.0

comment:3 Changed 10 years ago by Juergen Reuter

This works both with 4.9.0 and 4.8.0. So it seems that only 4.7.x (entirely) has a problem with it.

comment:4 Changed 10 years ago by Juergen Reuter

So what do we do with this? Veto against 4.7.x and quadruple? or, WK, could you try to program around this ugly thingy... ?

comment:5 Changed 10 years ago by Juergen Reuter

Owner: changed from kilian to Juergen Reuter
Status: newassigned

I might have a viable solution: throwing a warning for scanning in quadruple precision with gfortran 4.7 and disabling the corresponding test in that case. Hope all worked fine.

comment:6 Changed 10 years ago by Juergen Reuter

Resolution: fixed
Status: assignedclosed

Done as described above in r5095. Closing (if someone is unhappy, we can open it again.)

comment:7 Changed 10 years ago by kilian

Resolution: fixed
Status: closedreopened

happens that I've solved the problem at the same time you were checking in the warning stuff .. testing right now

comment:8 Changed 10 years ago by kilian

ok, tests run nevertheless. That was an unfortunate coincidence -- should I remove the warning again?

comment:9 Changed 10 years ago by Juergen Reuter

It killed several of my hours. VERY UNFORTUNATE and again a severe crash. IFFFF you are sure you can remove all the changes correctly, I did (incl. ./update etc.) then go ahead. Could you also do the show(real)???? Just in case we clash again. What about the gfortran bug report. I'm frustrated like hell ...

comment:10 Changed 10 years ago by Juergen Reuter

BTW, Jenkins is going down for hours now.... Marco is not reachable. So no checks at the moment. I don't know what to do.

Last edited 10 years ago by Juergen Reuter (previous) (diff)

comment:11 Changed 10 years ago by Juergen Reuter

When does this happen???? Tests also with 4.7.0?????

comment:12 Changed 10 years ago by kilian

sorry - but I didn't know you were working on this (was offline). The last message I got was

WK, could you try to program around this ugly thingy... ?

so I tried.

The resolution is simple. In gfortran 4.7, polymorphic scalars are ok, but polymorphic arrays are broken. So I wouldn't trust the original code in any case. I eliminated the polymorphic array at the cost of only a slight increase in complexity. The finalizer is now also reinstated and works with 4.7.2, showing that the memory corruption issue was really there, even for the tests that did work.

comment:13 Changed 10 years ago by Juergen Reuter

Again, time is AWFULLY sparse: what about 4.7.0? what about the warnings? and the configure changes? (Jenkins back up again, understood what was wrong. Was a configuration error)

comment:14 Changed 10 years ago by kilian

My current minimal solution which I would like to check in: keep the m4/fortran.m4 macro (I added a comment and run ./update, no other mod), but disable it in configure.ac

This macro may be become useful if we encounter another difficulty w/ 4.7 etc. Just in case.

After I removed the polymorphic array, I guess it will work with 4.7.0. This I can't check. I did check double+quadruple w/ 4.7.2.

comment:15 Changed 10 years ago by Juergen Reuter

What about the tests dir??? Close to check in myself now. Eliminated all the stuff again from fortran.m4 !!!!

comment:16 Changed 10 years ago by Juergen Reuter

Dachte ich mir .... Scheissdreck da !!!!

comment:17 Changed 10 years ago by Juergen Reuter

Resolution: fixed
Status: reopenedclosed

Corrected the corrections of the corrections of the clashes of the corrections to the clashes ... All seems to work now again. Closing.

comment:18 Changed 10 years ago by kilian

@JR: Thanks!

Note: See TracTickets for help on using tickets.