efriedma added inline comments.

================
Comment at: clang/lib/CodeGen/CGDeclCXX.cpp:572
     PrioritizedCXXGlobalInits.push_back(std::make_pair(Key, Fn));
+  } else if (D->hasConstantInitialization() && !(D->hasAttr<ConstInitAttr>())) 
{
+    OrderGlobalInitsOrStermFinalizers Key(201,
----------------
zahiraam wrote:
> efriedma wrote:
> > zahiraam wrote:
> > > efriedma wrote:
> > > > zahiraam wrote:
> > > > > efriedma wrote:
> > > > > > How is ConstInitAttr relevant here?
> > > > > This change made (without the !(D->hasAttr<ConstInitAttr>()) made the 
> > > > > LIT behavior of aix-static-init.cpp. The IR generated for 
> > > > > namespace test3 {
> > > > >   struct Test3 {
> > > > >     constexpr Test3() {};
> > > > >     ~Test3() {};
> > > > >   };
> > > > > 
> > > > >   constinit Test3 t;
> > > > > } // namespace test3
> > > > > 
> > > > > was different. I would have thought that the change we made for 
> > > > > constexpr wouldn't affter constinit? 
> > > > I think the significant bit there isn't the use of constinit; it's the 
> > > > non-trivial destructor.  I think the priority modification should only 
> > > > affect constructors, not destructors.  (Not sure how to make that work, 
> > > > at first glance.)
> > > Let's see if this is an acceptable solution.
> > To fake constant initialization, we need to initialize the variable before 
> > anything else runs.  But the rearranged prioritization isn't supposed to 
> > affect the destructor.  From [basic.start.term]: "If an object is 
> > initialized statically, the object is destroyed in the same order as if the 
> > object was dynamically initialized."
> > 
> > What you're doing here isn't exactly implementing that.  What you're doing 
> > here is delaying both the initialization and the destruction if the 
> > variable has a non-trivial destructor.  We need to separate the two to get 
> > the behavior we want.
> Could we consider adding a field to EvaluatedStmt called 
> "HasTrivialDestrutor" and only perform the prioritization change when 
> !D->HasTrivialDesctructor?  Instead of using the test for 
> D->hasConstantInitialization(). This seems to be englobing to many cases.
> 
> I considered returning null for HasConstantInitialization in case of var has 
> a non-trivial destructor but that doesn't seem to work.
Once you separate out the initialization from the destruction, the rest should 
come together naturally, I think? I'm not sure what other cases could be caught 
by hasConstantInitialization().


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

https://reviews.llvm.org/D137107

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

Reply via email to