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