저는 Fortran 응용 프로그램에서 valgrind (memcheck 도구 사용)를 실행하고 있습니다. 나는 의심스러운 아무것도 찾을 수 없습니다Valgrind는 포트란 코드에서 초기화되지 않은 변수를 표시합니다.
==17072== at 0x806C4A2: prove_ (t10_isb.f90:1948)
==17072== by 0x804E9F3: anal1_ (t10_isb.f90:2721)
==17072== by 0x808EECC: MAIN__ (t10_isb.f90:6)
==17072== by 0x808EF14: main (t10_isb.f90:8)
==17072== Uninitialised value was created by a stack allocation
==17072== at 0x805ECDC: relplm_ (t10_isb.f90:3402)
==17072==
==17072==
==17072== ---- Attach to debugger ? --- [Return/N/n/Y/y/C/c] ---- y
소스 코드를 보면 : 다음과 같은 오류가 Valgrind의으로 표시됩니다 여기에
이 라인 1948, 초기화되지 않은 변수가 사용됩니다, 그래서 그것을 어느 것 같아요 ER 또는 EZ :
1943 if(NIT.eq.0) then
1944 ER=ER/ekran
1945 EZ=EZ/ekran
1946 end if
1947
1948 EM=DSQRT(ER*ER+EZ*EZ)
1949 ENO=-ER*PK(IEM*9-7)+EZ*PK(IEM*9-5)
1950
1951 IF(PK(IEM*9-8).GE.0.5D0) THEN
1952 ESS=(ER*(PK(IEM*9-4)-F1)+EZ*(PK(IEM*9-6)-F2))
그러나, 호출 스택을 가고, 우리는 이러한 변수가 바로 판명 서브 루틴을 호출로 초기화되는 것을 볼 수 있습니다.
2716
2717 CALL VECMUL(SQ,JJK,CUR,NTP)
2718
2719 ER=0.D0
2720 EZ=0.D0
2721 CALL PROVE(E0,ES1,EN2,TE,TEPR,TEMI,TEMA,RB,ZB,QS,QP,R1P,Z1P,RONAT,ROHQ,RNQ,ZNQ,QNQ,NQ,IM1,IM2,IM3,IM4,IM5,IQQ,NTP,NIT,US,NFR,NTPE,NEM,NR,KEYP,MSYS,ekran,UK,RK,ZK,ER,EZ,F1,F2)
2722
2723 NPPP=NPAOLD+1
2724 DO I=NPPP,NPA
2725 N=I-NPAOLD
여기에 무엇이 누락 되었습니까?
valgrind와 memcheck를 읽은 후,이 비트에 더주의를 기울여야합니다. 초기화되지 않은 값은 0x805ECDC : relplm_ (t10_isb.f90 : 3402)의 스택 할당에 의해 만들어졌습니다. 변수 ER 및 EZ는 일부 초기화되지 않은 변수에서 계산되는 것으로 보입니다 (어떤 변수를 찾으려면 더 자세히 조사해야합니다). – Eldar
'-Wuninitialized' 플래그로 컴파일 했습니까? – steabert
예, 몇 가지 문제가 표시되었지만이 문제는 아닙니다. 결국, RELPLM 서브 루틴은 정적 인 것으로 예상되는 몇 가지 변수를 사용했지만 실제로는 그렇지 않았습니다. – Eldar