weiwang added a comment.

In D144680#4149149 <https://reviews.llvm.org/D144680#4149149>, @ChuanqiXu wrote:

> BTW, what is the conclusion for the concern about sanitizers? Would change 
> make sanitizers to perform false positive diagnostics?

This change is limited to the `await.suspend` block, which only does codegen 
for `awaiter.await_suspend(coroutine_handle<p>::from_promise(p))`. In this 
case, I think the only asan check removed by the change is the conditional 
marker for cleanup the temporary `coroutine_handler` used as the parameter of 
`await_suspend`, so my understanding is that it shouldn't affect asan 
diagnostic.

To show the difference it makes to the source from issue #59181

Before:

  %ref.tmp25 = alloca %"struct.std::__1::coroutine_handle.6", align 8
  ...
  // asan check inserted here
  bool cond_cleanup_marker = false;
  
  if (cond) {
      // get awaiter
      ...
  
      if (!awaiter.await_ready()) {
          call void @llvm.lifetime.start.p0(i64 8, ptr %ref.tmp25)
          
          // asan check inserted here
        cond_cleanup_marker = true;
        
          // store handler to %ref.tmp25
        ...
        
          awaiter.await_suspend();
  
          // asan check inserted here
        if (cond_cleanup_marker)
            call void @llvm.lifetime.end.p0(i64 8, ptr %ref.tmp25)
          call i8 @llvm.coro.suspend(...)
        ...
      }
      ...
  } else {
      ... 
  }
  ...
  lpad:
      ...
      // asan check inserted here
      if (cond_cleanup_marker)
          call void @llvm.lifetime.end.p0(i64 8, ptr %ref.tmp25)

The issue is only reproduced in `-O0`, because ``cond_cleanup_marker` is 
optimized away in `-O1` or up opt level.

After:

  %ref.tmp25 = alloca %"struct.std::__1::coroutine_handle.6", align 8
  ...
  
  call void @llvm.lifetime.start.p0(i64 8, ptr %ref.tmp25)
  
  if (cond) {
      ...
      if (!awaiter.await_ready()) {
          // store handler to %ref.tmp25
        ...
  
        awaiter.await_suspend();
        call void @llvm.lifetime.end.p0(i64 8, ptr %ref.tmp25)
        call i8 @llvm.coro.suspend(...)
        ...
      }
      ...
  } else {
      ... 
  }
  ...
  lpad:
      call void @llvm.lifetime.end.p0(i64 8, ptr %ref.tmp25)

This also matches with the IR without asan.



================
Comment at: clang/lib/CodeGen/CGExpr.cpp:544
       // so that it's unconditional. Don't do this with sanitizers which need
       // more precise lifetime marks.
       ConditionalEvaluation *OldConditional = nullptr;
----------------
ChuanqiXu wrote:
> We should add comment to explain why we add a forward path for coroutines.
Will do


================
Comment at: clang/lib/CodeGen/CodeGenFunction.h:336
     std::unique_ptr<CGCoroData> Data;
+    bool InSuspendBlock = false;
     CGCoroInfo();
----------------
bruno wrote:
> Should this live inside CGCoroData instead?
`CGCoroData` is forward declared here, so it does not know what's inside.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D144680

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

Reply via email to