lebedev.ri marked an inline comment as done.
lebedev.ri added inline comments.


================
Comment at: clang/test/CodeGen/windows-seh-EHa-CppCondiTemps.cpp:3
 
+// FIXME: this check appears to be miscompiled?
+// XFAIL: *
----------------
tentzen wrote:
> lebedev.ri wrote:
> > efriedma wrote:
> > > lebedev.ri wrote:
> > > > tentzen wrote:
> > > > > lebedev.ri wrote:
> > > > > > This test broke once we always started adding (outermost) UB scope 
> > > > > > for nounwind functions.
> > > > > > I don't quite get what is going wrong. It could be a bug in SEH 
> > > > > > handling.
> > > > > > Can someone who has some idea about that code take a look and 
> > > > > > suggest a fix?
> > > > > > @tentzen ?
> > > > > By definition, non-unwind function I think is for Synchronous EH. So 
> > > > > this Sanitizer check should exclude Asynchronous EH functions, those 
> > > > > with option -fasync-exceptions.
> > > > >  
> > > > I do not understand.
> > > > If the function can unwind, then why is it marked `nounwind`?
> > > > This kind of thing is exactly what i was afraid of with those SEH 
> > > > patches.
> > > clang should not be marking functions "nounwind" in -fasync-exceptions 
> > > mode; if it is, I'd consider that a bug.  (I assume someone just forgot 
> > > to add a check to some code that adds nounwind.)
> > My thoughts precisely. @tentzen please fix :)
> This is copied from LLVM reference manual:
> 
> nounwind
> This function attribute indicates that the function never raises an 
> exception. If the function does raise an exception, its runtime behavior is 
> undefined. However, functions marked nounwind may still trap or generate 
> asynchronous exceptions. Exception handling schemes that are recognized by 
> LLVM to handle asynchronous exceptions, such as SEH, will still provide their 
> implementation defined semantics.
> 
> So I think nounwind only implies no synchronous/software unwind, not HW traps 
> etc.
Ok, good point.
But i'm still not quite sure why the test is getting miscompiled.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D137381

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

Reply via email to