Add the atomic subroutine, atomic_fetch_or, to the list of
intrinsic subroutines. Add new enumerators to deal with the rank
of the atom dummy argument, and the kind of atomic_int_kind.
Details
Diff Detail
Event Timeline
In this patch, in flang/lib/Evaluate/intrinsics.cpp, I would like to be able to bring in and use the value atomic_int_kind from the iso_fortran_env module. I have drafted my solution in this patch where I declare a variable with the value of atomic_int_kind but with the bind(c) attribute in a new Fortran module and then use an extern int in a .h file to theoretically grab that value. However, I have not done much Fortran/C interoperability and am not sure how to do the right CMake changes to make my idea work. At the moment, I commented out the extern int and am just using a magic number. Would anyone be able to help me figure out how to make the right CMake changes so I can use that extern int? Or is there a totally different and better way to get a value equivalent to atomic_int_kind that is not a magic number?
Maybe @klausler has an idea to manage computing atomic_int_kind in https://github.com/llvm/llvm-project/blob/main/flang/include/flang/Runtime/magic-numbers.h and use that in both the module file and the compiler (I don't) ?
As an alternative however, instead of the cmake gymnastic, I would suggest moving the definition of atomic_int_kind parameter as __builting_atomic_int_kind in https://github.com/llvm/llvm-project/blob/main/flang/module/__fortran_builtins.f90, rename it as atomic_int_kind in https://github.com/llvm/llvm-project/blob/main/flang/module/iso_fortran_env.f90, and extract the builtin parameter symbol and its value in a similar way as it is done for builtin types in GetBuiltinDerivedType defined here: https://github.com/llvm/llvm-project/blob/2944f8ef049fa83ee96159c390fa893f251558da/flang/lib/Evaluate/intrinsics.cpp#L1202.
| flang/lib/Evaluate/intrinsics.cpp | ||
|---|---|---|
| 1637 | I am not well versed in coarrays, and the standard phrasing "shall be a scalar coarray or coindexed object" is a bit ambiguous to me. Are you sure the "scalar" part does not also apply to coindexed objects ? It is not entirely clear to me why it would apply on Corarray and not coarray references. | |
@jeanPerier Thank you for the feedback! I think the idea to use flang/module/__fortran_builtins.f90 seems like a great idea and I will pursue that option. Thank you for pointing out how that could be useful in this case.
| flang/lib/Evaluate/intrinsics.cpp | ||
|---|---|---|
| 1637 | @jeanPerier, As you saw, the interpretation I took is that in that sentence in the standard, scalar only modifies coarray and not coindexed-object, but I am not sure that this interpretation is correct. I can see your point that this interpretation doesn't make as much sense. @rouson, can you give feedback on this coarray question? Do you know whether "shall be a scalar coarray or coindexed object" in 16.9.25 in the 2018 standard means that a coindexed-object shall also be scalar? Or just if it is a coarray? | |
| flang/lib/Evaluate/intrinsics.cpp | ||
|---|---|---|
| 1637 | I debated whether "scalar" modifies just "coarray" or also "coindexed object" and concluded that the most reasonable answer is that "scalar" modifies both. Otherwise, the standard would be treating coindexed data entities differently from non-coindexed ones, which would create the odd circumstance that we could do something with coindexed entities even in single-image execution that we could not do with non-coindexed entities. | |
I will updated my patch based on reviewer feedback on the implementation of one of the new errors and the implementation of the atomic_int_kind check.
| flang/lib/Evaluate/intrinsics.cpp | ||
|---|---|---|
| 1637 | That is a good point about the single-image execution. Thank you @jeanPerier and @rouson for this discussion. I will change the way I implement my error check for that sentence in the standard to work based on the interpretation that scalar modifies both coarray and coindexed-object. | |
Update patch based on reviewer feedback:
- Update the implementation of checks surrounding atomic_int_kind
- Update implementation of checks on the rank of the atom argument
- Update atomic_fetch_or test with new error messages and an additional non-standard conforming call.
A nit and a question, otherwise looks good to me.
| flang/lib/Evaluate/intrinsics.cpp | ||
|---|---|---|
| 1632 | nit: argOk = rank == 0 && (IsCoarray(*arg) || ExtractCoarrayRef(*arg)); would be readable and shorter. | |
| flang/module/iso_fortran_env.f90 | ||
| 20 | Is there a reason to define new parameters instead of doing renaming here (e.g., `atomic_int_kind  If renames are possible, I think they should be favored because they avoid "spilling" the builtin symbols. With the current patch, a user using iso_fortran_env could directly use __builtin_atomic_int_kind and __builtin_atomic_logical_kind, and I do not think we should allow that to make it impossible for users to start relying on the builtin names for any weird reason as if it was an extension. | |
- Add a check for a coindexed-object for the optional dummy argument 'stat', which "shall be a noncoindexed integer scalar".
- Updates based on reviewer feedback
| flang/module/iso_fortran_env.f90 | ||
|---|---|---|
| 20 | No, there is no reason to define new parameters, but I didn't even think about taking out the original definition fully. Thanks for the great feedback! | |
nit: argOk = rank == 0 && (IsCoarray(*arg) || ExtractCoarrayRef(*arg)); would be readable and shorter.