[clang] [llvm] [Clang][OpenMP] Non-contiguous strided update (PR #144635)
Alexey Bataev via cfe-commits
cfe-commits at lists.llvm.org
Mon Jun 23 04:52:26 PDT 2025
================
@@ -7384,7 +7384,40 @@ class MappableExprsHandler {
// dimension.
uint64_t DimSize = 1;
- bool IsNonContiguous = CombinedInfo.NonContigInfo.IsNonContiguous;
+ // Detects non-contiguous updates due to strided accesses.
+ // Sets the 'IsNonContiguous' flag so that the 'MapType' bits are set
+ // correctly when generating information to be passed to the runtime. The
+ // flag is set to true if any array section has a stride not equal to 1, or
+ // if the stride is not a constant expression (conservatively assumed
+ // non-contiguous).
+ bool IsNonContiguous = false;
+ for (const auto &Component : Components) {
+ const auto *OASE =
+ dyn_cast<ArraySectionExpr>(Component.getAssociatedExpression());
+ if (OASE) {
+ const Expr *StrideExpr = OASE->getStride();
+ if (StrideExpr) {
+ // Check if the stride is a constant integer expression
+ if (StrideExpr->isIntegerConstantExpr(CGF.getContext())) {
----------------
alexey-bataev wrote:
You're answering wrong question. I'm asking if this check is required and is not covered by `StrideExpr->getIntegerConstantExpr(` already?
https://github.com/llvm/llvm-project/pull/144635
More information about the cfe-commits
mailing list