[clang] [compiler-rt] [ubsan] Display correct runtime messages for negative _BitInt (PR #96240)

Jakub JelĂ­nek via cfe-commits cfe-commits at lists.llvm.org
Mon Sep 2 06:47:26 PDT 2024


================
@@ -125,6 +137,25 @@ class TypeDescriptor {
     return 1 << (TypeInfo >> 1);
   }
 
+  const char *getBitIntBitCountPointer() const {
+    DCHECK(isBitIntTy());
+    DCHECK(isSignedBitIntTy());
+    // Scan Name for zero and return the next address
+    const char *p = getTypeName();
+    while (*p != '\0')
+      ++p;
+    // Return the next address
+    return p + 1;
+  }
+
+  unsigned getIntegerBitCount() const {
+    DCHECK(isIntegerTy());
+    if (isSignedBitIntTy())
+      return *reinterpret_cast<const u32 *>(getBitIntBitCountPointer());
----------------
jakubjelinek wrote:

If it isn't performance critical, guess using internal_memcpy is an option as well.

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


More information about the cfe-commits mailing list