rnk added inline comments.

================
Comment at: clang/test/CodeGen/attr-nomerge.cpp:8
+  [[clang::nomerge]] void f();
+  [[clang::nomerge]] virtual void g();
+  [[clang::nomerge]] static void f1();
----------------
zequanwu wrote:
> rnk wrote:
> > Hm, virtual functions, there's something worth thinking about. In this 
> > case, the attribute must appear on the call site if we want it to work as 
> > the user expects. I don't see the indirect call site for the virtual call 
> > in the IR below. I think it's worth testing for that. Consider taking `A*` 
> > and `B*` parameters to defeat any frontend devirtualization optimizations.
> If devirtualization failed, then only statement attribute would work.
Fair enough, that is similar to how `not_tail_called` works. Can you also 
update AttrDocs.td to mention the limitation?


================
Comment at: clang/test/CodeGen/attr-nomerge.cpp:17
+
+[[clang::nomerge]] bool bar() {
+  return true;
----------------
zequanwu wrote:
> rnk wrote:
> > I would leave this declaration as it was, so that all the statement 
> > attribute test cases you wrote below remain as they were, and the attribute 
> > continues to appear at the call site.
> > 
> > The `f` declaration below gives you coverage of the free function 
> > declaration case.
> I added `[[clang::nomerge]]` to `bar` in order to test that the generated IR 
> should attach `nomerge` to call-sites which callee function already has this 
> attribute.
Well, from the tests below, it seems like the attribute is *not* present on the 
call sites. Is that what you intended?


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D92800

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

Reply via email to