<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/133260>133260</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
flang does not add implicit SAVE attribute to program scope variable
</td>
</tr>
<tr>
<th>Labels</th>
<td>
miscompilation,
flang
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
DavidSpickett
</td>
</tr>
</table>
<pre>
Split out of https://github.com/llvm/llvm-project/issues/60219.
The following program:
```
program emptyif
logical c
! This should implcitly be:
! logical, save :: c
! but Flang does not add this, which leaves c in an undefined state.
if (c) then
c = .true.
elseif (c) then
c = .true.
end if
end program
```
Does not compile correctly with Flang, but does with GFortran: https://godbolt.org/z/GsPrMev18
Flang should be treating `c` as if it had the `SAVE` attribute. It does not, so `main` is now UB which means it calls _FortranAProgramStart, but then just falls off the end of main into whatever is next.
See https://j3-fortran.org/doc/year/18/18-007r1.pdf 8.5.16 SAVE attribute point 4.
> A variable, common block, or procedure pointer declared in the scoping unit of a main program, module, or
> submodule implicitly has the SAVE attribute, which may be confirmed by explicit specification. If a common block
> has the SAVE attribute in any other kind of scoping unit, it shall have the SAVE attribute in every scoping unit that > is not of a
> main program, module, or submodule.
Adding "save" to `c` in the source code works around the problem.
</pre>
<img width="1" height="1" alt="" src="http://email.email.llvm.org/o/eJycVcGO4zYM_RrlQoxhy4mTHHzwzqwXeyiwQLa9FrJEx5qRTUOik02_vpDtzOxMFwVaIEgiiSL53iMpFYI9D4il2H0Su6eNmrgjXz6pizWn0eoXZN40ZG7laXSWgSYGaqFjHoPIKyFrIeuz5W5qEk29kLVzl_vPw-jpGTULWdsQJgxC1kUqs2Mi0kqk1fcOoSXn6GqHM4yezl710WtaiSJdP2m1HgD2I99sK9IKABydrVYO9LIUMoPvnQ0QOpqcAduPTlt2N2hw8bgarfeEfISgLgjxMK9-dtNMDLVTwxkMYYCBGJQxwJ0N8da1s7oDh-qCATTYAdQA02CwtQMaCKwYV3wAYFsQ8qCFPAJ3OCybAKBB5E-QsJ9mYwBAF_A_WA8GZirinztz72l7umevqR-tQ9DkPerIydVyt2CMiCLgGeq8_aUmz14NkZUPMpNpyHFC_ixk_ZeQ9Zfwzf-Gl-yw4F1YWxVoENij4iitKFItihRUiIRYhk5FQjEenKo_Ps9nzN42E2MCX_mV-lknina9skO0s3H_Cr9_WpXoUQ0h-tTKuQB_rulX3xZSTqw831FGUuF5CgztbExtO6cRSaQWYgiwAxNcO8V4QT9Hwx-8CnpC_MDJc_7QLgFXWgxpIesbKi9knR3mr4c03fssGU0Lh2SXZAVE0G-IYSQ7MGzXKCL_DBVclLeqcRhz19T3NEDjSL_ENfmouUYz-fUyejConfJoYklGUEHTGMmfBjv3rFrw3YtFPkJPZloCkF_jhqlZducOsksLdSrMHt9n_dYMvYptBpqG1voeDTQ3wB_LdQgjattardjSkMDXmMg7PEvgX8dY2usGxB16eLGLTj8ji1nEKJ1yDrrY0b_2EtW8veeEO8UQY9ulTyJHazb_xtQbR6telTFzkUsZJ4qQEpheS_4uBk1eR4oMwpX8SwDlaRqWLhg9NQ77ZGPK3Bzzo9pgme23eXoodsfdpisx328PWbFP20al6oC7nVaZxO2hMNm22e83tpSp3KW53GfbbZ7tkrZIi6M-5ErpbZG2jdim2CvrkjiXY6lu5olcZnkui3TjVIMuzI-AlL0Ny8iYJRNSCvkopGyXeSHjM-HLeb430zmIbeps4PDmmS07LNt_jtB7SX2Uh-nO9SwQvtb-ZvKu_P9vzQruUsq_AwAA__-0Hj5x">