[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