Hi Jim
On 10/02/16 17:02, Jim Ingham wrote:
On Feb 10, 2016, at 3:45 AM, Luke Drummond <luke.drumm...@codeplay.com> wrote:
ldrumm added a comment.
In http://reviews.llvm.org/D17027#347487, @jingham wrote:
This seems fine as a generic instrumentation point. Obviously, the onus in on
the passes, since they could totally ruin the expression evaluation if they
don't do their job right... But I'm not sure there's any good way to make this
not a sharp tool. But you should wait on Sean to weigh in as well...
I appreciate this, and I think that if a runtime provides passes, the
expectation should be that the runtime knows what it's doing because this
really //is// a powertool - as you say. I think it's a generally useful
mechanism for better modularity/encapsulation of language-specific behaviours
that are required during expression evaluation. For example, there are
presently a large number of language-specific fixups in the clang-based
expression evaluator, that could be factored out into individual
`EarlyPasses/LatePasses` provided by their runtime, leaving `IRForTarget` and
friends a lot cleaner and more maintainable.
Yes, that seems reasonable.
One question, what is the force of the "legacy" in "llvm::legacy::PassManager? Is there
some more "modern" way to do this, is this going to go away at some point?
The legacy pass manager is fully functional and tested. Using the new version
does not work unfortunately in this instance. We can certainly move to the new
version as it matures and becomes ready for general use, but I tried this
implementation with both `llvm::PassManager` and the the
`llvm::legacy::PassManager`, and unfortunately the new PassManager did not work
here.
Did you file bugs with llvm on these issues? It would be good to file a "move to
the new pass manager when ready" bug on lldb, but it should be blocked on the
relevant llvm bugs.
Not yet. I believe it's best to wait this until this revision is
accepted before reporting bugs on its implementation. Though I'm happy
to do so, I'll prefer to wait for yours and Sean's final comments.
Let me know your thoughts.
Best
Luke
_______________________________________________
lldb-commits mailing list
lldb-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits