[clang] [compiler-rt] [UBSAN] add null and alignment checks for aggregates (PR #164548)

Vitaly Buka via llvm-commits llvm-commits at lists.llvm.org
Sat Nov 15 22:26:55 PST 2025


================
@@ -2249,6 +2249,22 @@ void CodeGenFunction::EmitAggregateCopy(LValue Dest, LValue Src, QualType Ty,
                                         bool isVolatile) {
   assert(!Ty->isAnyComplexType() && "Shouldn't happen for complex");
 
+  // Sanitizer checks to verify source and destination pointers are
+  // non-null and properly aligned before copying.
+  // Without these checks, undefined behavior from invalid pointers goes undetected.
+  Address SrcAddr = Src.getAddress();
+  Address DestAddr = Dest.getAddress();
+
+  // Check source pointer for null and alignment violations
+  EmitTypeCheck(TCK_Load, SourceLocation(),
+                SrcAddr.emitRawPointer(*this), Ty, SrcAddr.getAlignment(),
+                SanitizerSet());
----------------
vitalybuka wrote:

SanitizerSet() is default

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


More information about the llvm-commits mailing list