[clang] [compiler-rt] [UBSan] Diagnose assumption violation (PR #104741)

Vitaly Buka via cfe-commits cfe-commits at lists.llvm.org
Tue Sep 17 19:47:57 PDT 2024


================
@@ -633,9 +633,11 @@ static void handleInvalidBuiltin(InvalidBuiltinData *Data, ReportOptions Opts) {
 
   ScopedReport R(Opts, Loc, ET);
 
-  Diag(Loc, DL_Error, ET,
-       "passing zero to %0, which is not a valid argument")
-    << ((Data->Kind == BCK_CTZPassedZero) ? "ctz()" : "clz()");
+  if (Data->Kind == BCK_AssumePassedFalse)
+    Diag(Loc, DL_Error, ET, "assumption is violated during execution");
+  else
+    Diag(Loc, DL_Error, ET, "passing zero to %0, which is not a valid argument")
+        << ((Data->Kind == BCK_CTZPassedZero) ? "ctz()" : "clz()");
----------------
vitalybuka wrote:

I suggest introduce `__ubsan::__ubsan_handle_invalid_assume` and we don't need enum here and in Clang.

Also  `__ubsan::__ubsan_handle_invalid_abort` is likely prints garbage.

Would you like to upload a separate patch to fix abort?

https://github.com/llvm/llvm-project/pull/104741


More information about the cfe-commits mailing list