tentzen marked an inline comment as not done.
tentzen added a comment.

thank you for the thorough review again.  My answer for each comment below:



================
Comment at: clang/lib/CodeGen/CGCleanup.cpp:1341
+  llvm::FunctionCallee SehCppScope =
+      CGM.CreateRuntimeFunction(FTy, "llvm.seh.scope.begin");
+  EmitSehScope(*this, SehCppScope);
----------------
rjmccall wrote:
> We generally prefer to get intrinsic functions with `CGM.getIntrinsic`.
Does this really matter? there are more than 200 uses of 
CGM.CreateRuntimeFunction().


================
Comment at: clang/lib/CodeGen/CGException.cpp:465
     if (const CapturedDecl* CD = dyn_cast_or_null<CapturedDecl>(D)) {
-      if (CD->isNothrow())
+      if (CD->isNothrow() && !getLangOpts().EHAsynch /* !IsEHa */)
         EHStack.pushTerminate();
----------------
rjmccall wrote:
> Please remove the comment here.  The option name should be sufficiently 
> self-descriptive.
> 
> Anyway, I don't think this change is right, because we *do* still need to 
> push a terminate scope: we need C++ exceptions to trigger a call to 
> `std::terminate`.  It's just that such scopes aren't fully terminal when 
> async exceptions are enabled, because MSVC defines those exceptions as 
> passing through `noexcept` and so on.  (I assume that's true; can you link to 
> documentation about it?)
Yes, MSVC terminate() runtime bypasses HW exceptions to its caller.
Hmm, it's been a whole. I think I placed that code there because Clang's 
terminate runtime does not dispatch HW exception to caller when I tried a year 
ago.  It issues an unhandled exception.  I felt if a user explicitly specify 
-EHa, HW exception probably is more significant than C++ noexcept/nothrow 
directive.
Anyways, I can undo this code and let terminate-runtime handler it one way or 
the other.


================
Comment at: clang/lib/CodeGen/CGException.cpp:554
+  if (isNoexceptExceptionSpec(EST) && Proto->canThrow() == CT_Cannot &&
+      !EHStack.empty() /* possible empty when -EHa */) {
     EHStack.popTerminate();
----------------
rjmccall wrote:
> Again, please try to refer to this in a more driver-agnostic way: "under 
> async exceptions" rather than "when -EHa".  But actually as mentioned above I 
> think this is incorrect.
will do.


================
Comment at: clang/lib/CodeGen/CGException.cpp:1668
+      } else if (isa<llvm::MemIntrinsic>(J)) {
+        auto *MCI = cast<llvm::MemIntrinsic>(J);
+        MCI->setVolatile(llvm::ConstantInt::get(Builder.getInt1Ty(), 1));
----------------
rjmccall wrote:
> Please use `dyn_cast` for all of these.
ok will fix them. thanks.


================
Comment at: clang/lib/CodeGen/CGException.cpp:1678
+      VolatilizeTryBlocks(TI->getSuccessor(I), V);
+  }
+}
----------------
rjmccall wrote:
> Volatilizing every block that's reachable from the `try` block seems like it 
> makes a lot of assumptions about where branches within the `try` can reach.  
> For example, a `goto` could certainly go to a block that's already been 
> emitted, as could `break` or `continue` if the emitter just makes slightly 
> different decisions about emission order.  Please look at how 
> `FragileHazards` (in the ObjC emission code) collects blocks in order to do 
> its transforms — I think you can probably extract a reasonable common base 
> out.  Alternatively, I think you could handle this directly in the insertion 
> callback (`CodeGenFunction::InsertHelper`) when we're in an appropriate `try` 
> scope.
A _try region is a Single Entry Multiple Exits regions. this code starts from 
Entry block and follows control-flow to reach all successors.  Yes a block 
could have multi-predecessors.  Note the 2nd line of this function: a visit 
flag is marked and checked
   !V.insert(BB).second /* already visited */ 

As long as it follows control-flows, it does not matter what the lexical order 
is.


================
Comment at: clang/lib/CodeGen/CGException.cpp:603
+
+      //  For IsEHa catch(...) must handle HW exception
+      //  Adjective = HT_IsStdDotDot (0x40), only catch C++ exceptions
----------------
rjmccall wrote:
> asmith wrote:
> > nit - extra space after //
> The comment here isn't explaining anything, it's just repeating what the code 
> is doing.  If you want a useful comment, you could explain why it's important 
> to mark the scope.
Yes, will do. thanks.


================
Comment at: clang/lib/Driver/ToolChains/Clang.cpp:6584
+    if (EH.Asynch)
+      CmdArgs.push_back("-feh-asynch");
   }
----------------
rjmccall wrote:
> For consistency with the existing options, please spell this option 
> `-fasync-exceptions`, and please spell the corresponding LangOption 
> `AsyncExceptions`.
OK will do.


================
Comment at: clang/lib/Frontend/CompilerInvocation.cpp:2786
   Opts.CXXExceptions = Args.hasArg(OPT_fcxx_exceptions);
+  Opts.EHAsynch = Args.hasArg(OPT_feh_asynch);
 
----------------
rjmccall wrote:
> You should emit an error if this is enabled on targets that are not in the 
> appropriate Windows environment, since we don't (yet) support it there.  I 
> assume that's just the MSVC Windows environment and that this can't easily be 
> supported on e.g. MinGW?
> 
> Does it have other target restrictions, like i386-only?
are you sure it's better to emit an error? I think some users would like it 
being ignored on non-Window platforms so they can have a single option set 
across platforms. 


================
Comment at: clang/lib/Sema/JumpDiagnostics.cpp:935
+    LabelStmt *Label = cast<LabelStmt>(To);
+    Label->setSideEntry(true);
   }
----------------
rjmccall wrote:
> This doesn't seem like a reasonable assertion in the abstract.  Even if we 
> really only currently emit warnings with jumps to labels, that doesn't seem 
> like something we should write code that relies on.  And I'm sure this 
> problem can come up with switch cases, unless that's structurally outlawed in 
> some other way.
> 
> Also, you're making the correct setting of this flag dependent on whether 
> we're emitting a warning vs. an error.  Seems like we should be setting it 
> regardless.
> 
> What conditions exactly do you want this flag set on?  I would naturally 
> assume it's specifically branches from a block outside the `try`, and you 
> don't care about branches within the `try`?  If the label is used in multiple 
> places, do you need to be careful to only set the flag on those branches that 
> come from outside the `try`?
A _try scope must be a (SEME) Single-Entry-Multi-Exits region.  Branching into 
a _try is not allowed; it triggers an error. Clang handles it properly.
What we want to flag here is an branch (either initiated by a 
go-to/break/continue) from inner _try to outer _try. 
This flag is set in this If-statement because that is exactly the place issue 
the warning we want to catch. 


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D80344

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

Reply via email to