================ @@ -4022,8 +4169,36 @@ LValue CodeGenFunction::EmitArraySubscriptExpr(const ArraySubscriptExpr *E, ArrayLV = EmitArraySubscriptExpr(ASE, /*Accessed*/ true); else ArrayLV = EmitLValue(Array); + auto *Idx = EmitIdxAfterBase(/*Promote*/true); + if (SanOpts.has(SanitizerKind::ArrayBounds)) { ---------------- efriedma-quic wrote:
So instead of a GEP from the base to "array", then a GEP from the base to "count", you emit a GEP from the base to "array", then a GEP from the "array" to the "count"? That's basically just rearranging the math; instead of "a + b", you compute "a + c + (b - c)". Maybe it saves refactoring some code, though. https://github.com/llvm/llvm-project/pull/73730 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits