llvmbot wrote:

<!--LLVM PR SUMMARY COMMENT-->

@llvm/pr-subscribers-clang

Author: Ebin Jose (ebinjose02)

<details>
<summary>Changes</summary>

Fixes #<!-- -->166325
Diagnose malformed '#pragma clang loop vectorize_width' lists. Avoids crash in 
HandlePragmaLoopHint, emit clear diagnostic and added regression test.

---
Full diff: https://github.com/llvm/llvm-project/pull/169473.diff


2 Files Affected:

- (modified) clang/lib/Parse/ParsePragma.cpp (+1-1) 
- (added) clang/test/Parser/pragma-loop-vectorize.cpp (+13) 


``````````diff
diff --git a/clang/lib/Parse/ParsePragma.cpp b/clang/lib/Parse/ParsePragma.cpp
index 7c2b9280f0b76..7e8b339f5be49 100644
--- a/clang/lib/Parse/ParsePragma.cpp
+++ b/clang/lib/Parse/ParsePragma.cpp
@@ -1531,7 +1531,7 @@ bool Parser::HandlePragmaLoopHint(LoopHint &Hint) {
         PP.Lex(Tok); // ,
 
         StateInfo = Tok.getIdentifierInfo();
-        IsScalableStr = StateInfo->getName();
+        IsScalableStr = StateInfo ? StateInfo->getName() : "";
 
         if (IsScalableStr != "scalable" && IsScalableStr != "fixed") {
           Diag(Tok.getLocation(),
diff --git a/clang/test/Parser/pragma-loop-vectorize.cpp 
b/clang/test/Parser/pragma-loop-vectorize.cpp
new file mode 100644
index 0000000000000..39f7e84323f5f
--- /dev/null
+++ b/clang/test/Parser/pragma-loop-vectorize.cpp
@@ -0,0 +1,13 @@
+// RUN: not %clang_cc1 -fsyntax-only %s 2>&1 | FileCheck %s
+
+void sum_vector(unsigned int A[], unsigned int B[], unsigned int sum[]) {
+    #pragma clang loop vectorize_width(4,8,16) vectorize(assume_safety)
+    for (int k = 0; k < 64; k++) {
+        sum[k] = A[k] + 3 * B[k];
+    }
+}
+
+// CHECK: error: vectorize_width loop hint malformed; use
+// CHECK-SAME: vectorize_width(X, fixed) or vectorize_width(X, scalable) where 
X is an integer, or
+// CHECK-SAME: vectorize_width('fixed' or 'scalable')
+// CHECK: warning: extra tokens at end of '#pragma clang loop vectorize_width'

``````````

</details>


https://github.com/llvm/llvm-project/pull/169473
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to