rsmith added a comment.

It would be really useful to provide these extra parameters to 
`FindAllocationFunctions` too. For example, we could support direct dispatch to 
a size-class-specific allocation function:

  void *operator new(std::size_t n) __attribute__((enable_if(n == 16, 
"optimized allocator for 16-byte objects")));



================
Comment at: clang/lib/AST/ExprConstant.cpp:14469
+  if (!E->getType()->isIntegralOrUnscopedEnumerationType() &&
+      !E->getType()->isAlignValT()) {
+    if (Loc)
----------------
This is wrong and may result in user-visible non-conformance; an expression of 
type `std::align_val_t` should never return `true` from 
`isIntegerConstantExpr`, because `align_val_t` is a scoped enumeration.

Can we instead change the caller (presumably the checking for the `alloc_align` 
attribute) to call a more general evaluation function rather than requiring an 
ICE?


================
Comment at: clang/lib/Sema/SemaExprCXX.cpp:2086-2088
+    // conjure them. For size, we can't do anything better than just passing a
+    // nullptr, but for alignment we can either also pass a nullptr, or 
actually
+    // materialize the alignment we'll pass into the call.
----------------
If this is not an array new, or it's an array new with a constant array bound, 
we can pass in a correct size. For the remaining (runtime array bound) cases, 
please conjure up an `OpaqueValueExpr` as the corresponding argument here 
rather than working around the `nullptr` argument in `EvaluateWithSubstitution`.


================
Comment at: clang/lib/Sema/SemaExprCXX.cpp:2097-2104
+      auto *AlignmentLiteral = IntegerLiteral::Create(
+          Context,
+          llvm::APInt(Context.getTypeSize(SizeTy),
+                      Alignment / Context.getCharWidth()),
+          SizeTy, SourceLocation());
+      auto *DesiredAlignmnet = ImplicitCastExpr::Create(
+          Context, AlignValT, CK_IntegralCast, AlignmentLiteral,
----------------
Please put these on the stack rather than `ASTContext`-allocating them. Both of 
these classes already support stack allocation.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D73020/new/

https://reviews.llvm.org/D73020



_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to