This supports the common block in OpenMP private clause by making each
common block member host-associated privatization and adds the test case.
Details
Diff Detail
Event Timeline
@kiranchandramohan Hi Kiran, could you please help commandeer this patch? I cannot continue working on it due to work changes.
Sure. Thanks, Nimish. But I think this needs review before landing. @kiranchandramohan What do you think?
Thanks @peixin for your work here. If @NimishMishra can rebase, then I will review it.
Hello @kiranchandramohan and @peixin. I was working towards rebasing this patch. I observed that createHostAssociateVarClone has changed considerably. Basically, present version of createHostAssociateVarClone has none of the following operations:
mlir::Region &curRegion = getFirOpBuilder().getRegion();
mlir::Value oldVal = fir::getBase(getExtendedValue(hsb));
mlir::Value cloneVal = fir::getBase(exv);
for (auto &oper : curRegion.getOps()) {
  for (unsigned int ii = 0; ii < oper.getNumOperands(); ++ii) {
    if (oper.getOperand(ii) == oldVal) {
      oper.setOperand(ii, cloneVal);
    }
  }
}As such, I was wondering if it would be a better approach to tackle this problem as done here: https://github.com/NimishMishra/f18-llvm-project/commit/10e5acf5ed91375b651951a384cd04b7029b36e8. Basically, instead of working with createHostAssociateVarClone, we work with the argument to this function. Let me know if this sounds cleaner. Or whether there can be some problems in this approach?
The code you are pointing to above was a temporary HACK to support the privatisation of the worksharing loop operands. Its removal would not otherwise alter the functionality of createHostAssociateVarClone. If this patch works without big changes, I would prefer that. You can always submit an improvement after that.
| flang/lib/Lower/OpenMP.cpp | ||
|---|---|---|
| 206 ↗ | (On Diff #541529) | @kiranchandramohan Do you have any suggestion on how to figure out whether a common block is private or firstprivate at this place in the code? I looked at the flags for the symbols as well, but unfortunately, we don't have any way to do this as far as I can see. I have marked two test cases as XFAIL to let the build pass, but we need a better solution at this. | 
One of the gfortran-testsuite tests started failing after this. I have disabled the test for now.
https://lab.llvm.org/buildbot/#/builders/198/builds/4206
https://github.com/llvm/llvm-test-suite/commit/867cb3ed7ee45376799d4d4af418aee31b6596da
I went through the test at https://github.com/llvm/llvm-test-suite/blob/main/Fortran/gfortran/regression/gomp/appendix-a/a.23.4.f90.
Seems like the same variable can't be both in common block as well as in a separate private(.). Is that so?
In any case, should I create an issue and fix this? It seems to be a semantics check with common blocks, and hence perhaps aligns with OpenMP 1.1.
Nit: Add braces here.