Index: clang/lib/Sema/SemaExprCXX.cpp =================================================================== --- clang/lib/Sema/SemaExprCXX.cpp +++ clang/lib/Sema/SemaExprCXX.cpp @@ -2654,13 +2654,11 @@ // FIXME: Should the Sema create the expression and embed it in the syntax // tree? Or should the consumer just recalculate the value? // FIXME: Using a dummy value will interact poorly with attribute enable_if. - IntegerLiteral Size( - Context, - llvm::APInt::getZero( - Context.getTargetInfo().getPointerWidth(LangAS::Default)), - Context.getSizeType(), SourceLocation()); - AllocArgs.push_back(&Size); + QualType SizeTy = Context.getSizeType(); + unsigned SizeTyWidth = Context.getTypeSize(SizeTy); + IntegerLiteral Size(Context, llvm::APInt::getZero(SizeTyWidth), SizeTy, + SourceLocation()); QualType AlignValT = Context.VoidTy; if (PassAlignment) { DeclareGlobalNewDelete();