[PATCH] D44464: allow custom OptBisect classes set to LLVMContext
Andy Kaylor via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Apr 3 12:07:02 PDT 2018
andrew.w.kaylor added inline comments.
================
Comment at: include/llvm/IR/LLVMContext.h:324
+ /// analysis.
+ void setOptPassGate(OptPassGate&);
+
----------------
yrouban wrote:
> andrew.w.kaylor wrote:
> > It seems like a bad idea to pass this in by reference. How is the lifetime of this object going to be managed? I don't think it's correct for the LLVMContext to have a reference to anything outside the LLVMContext. If you're going to pass in an object, I think LLVMContext must take ownership of the object, as happens with LLVMContext::setDiagnosticHandler().
> Andy, can you please explain why LLVMContext should not have a ref to outside? The OptBisect, for example, is one single global object that is outside of LLVMContext.
> What if a user wants to set one OptPassGate to several contexts?
> I would suggest that we accept this minimal design and see if there will be any demand for ownership.
>
My concern is lifetime management. If the LLVMContext receives a reference to an object, the lifetime of that object must be guaranteed to extend as long as the lifetime of the LLVMContext. That was always true with the OptBisect object, but with an arbitrary input from any caller we can't be sure of that. This feels like a weak spot in the interface.
https://reviews.llvm.org/D44464
More information about the llvm-commits
mailing list