-
Notifications
You must be signed in to change notification settings - Fork 15.4k
[flang][OpenMP] Don't allow DO CONCURRENT inside of a loop nest #144506
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from 1 commit
Commits
Show all changes
4 commits
Select commit
Hold shift + click to select a range
3649ab1
[flang][OpenMP] Don't allow DO CONCURRENT inside of a loop nest
tblah ab3fba8
Allow do concurrent in loop constructs, but not loop nests
tblah eed0acb
Revert "Allow do concurrent in loop constructs, but not loop nests"
tblah 5dbfe27
Allow do concurrent with LOOP construct
tblah File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,19 @@ | ||
| !RUN: %python %S/../test_errors.py %s %flang -fopenmp | ||
|
|
||
| integer :: i, j | ||
| !$omp parallel do collapse(2) | ||
| do i = 1, 1 | ||
| ! ERROR: DO CONCURRENT loops cannot form part of a loop nest. | ||
| do concurrent (j = 1:2) | ||
| print *, j | ||
| end do | ||
| end do | ||
|
|
||
| !$omp parallel do | ||
| do i = 1, 1 | ||
| ! This should not lead to an error because it is not part of a loop nest: | ||
| do concurrent (j = 1:2) | ||
| print *, j | ||
| end do | ||
| end do | ||
| end |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
DO CONCURRENT is allowed in the LOOP construct, although, IIUC, only as the top-level loop.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ab3fba8 allows do concurrent as a single loop construct but not as part of a loop nest. Does that match your understanding of the standard?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The test for this is https://github.com/llvm/llvm-project/blob/main/flang/test/Lower/OpenMP/Todo/omp-doconcurrent.f90
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it's allowed in any worksharing-loop construct, only in the LOOP construct [6.0:424:1] "The collapsed loop may be a DO CONCURRENT loop." No other constructs in that chapter have this annotation.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for pointing this out.
I am taking this to mean that DO CONCURRENT is allowed with LOOP, but not when LOOP has a COLLAPSE clause. "Collapsed loop" seems elsewhere to refer to anything enclosed by the LOOP construct.