sammccall added a comment. In D153493#4450191 <https://reviews.llvm.org/D153493#4450191>, @ymandel wrote:
> I don't want to block the progress you're making elsewhere and I think the > concerns here are sufficiently localized to revisit another time. So, feel > free to reify any suggestions/disagreements in FIXMEs and submit. > > In D153493#4449993 <https://reviews.llvm.org/D153493#4449993>, @sammccall > wrote: > >>> Regarding the design. This looks like an optimal solution in terms of >>> copying but introduces lifetime risks and complexity that I'm uncomfortable >>> with. >> >> FWIW I agree with the complexity (not the lifetime risks). >> I think it ultimately stems from having too many interacting types & >> functions with complicated and inconsistent signatures & constraints >> (TypeErasedDataflowAnalysisState, Environment, TypeErasedLattice, Lattice, >> the various join functions, etc) so we resort to case-bashing. >> However this system is difficult to make changes to, and getting consensus >> as to what changes are good also doesn't seem easy. So I think we need to be >> able to fix bugs within the existing design (where copies need to be avoided >> ad-hoc). > > I realize the complexity is frustrating, but I don't see how that's related > to the issue here. The complexity of the `JoinedStateBuilder` is caused by > the desire to minimize copies. The multiple cases come directly from the > algorithm itself, most particularly that we may or may not be in an initial > state, and the previous block may or may not have an environment we care > about. At least, that is the specific issue I'm concerned with. We have 9 state transitions (3 states x 3 operations). Each would be less than half as complicated if it didn't have to deal with Lattice's join being mutating and Environment's being non-mutating. I believe further simplifications are possible (essentially: back at the callsite track `vector<const Env*> All` plus `deque<Environment> Owned` for owned copies, special case `All.size() == 0` and `All.size() == 1` and otherwise `joinVec(All)`. However with Lattice's mutating join involved this no longer works, and after addressing that it's no longer simpler. >>> There's a lot of flexibility here and I wonder if we can reduce that >>> without (substantially?) impacting the amount of copying. Specifically, I >>> wonder if we can have the builder *always* own an environment, which >>> simplifies the handling of CurrentState and, generally, the number of cases >>> to consider. It costs more in principle, but maybe negligible in practice? >> >> I don't understand the specific suggestion: >> >> - if we create the builder lazily, we're just moving handling this extra >> state into the callsites >> - if the builder owns a copy of initenv, its FC token will end up in the >> result FC >> - if the builder owns a copy of initenv and detects when it should discard >> it, that just sounds like nullptr with extra steps >> >> can you clarify? > > I suppose I'm thinking along the lines of: > >> - if the builder owns a copy of initenv, its FC token will end up in the >> result FC > > Can you expand on why this is a problem? That would help motivate the > complexity. The purpose of this change is to stop introducing meaningless variables into the FC, because they impede debugging and slow down the SAT solver. An extra join with a copy of InitEnv introduces up to 3 extra variables: one for InitEnv, one for the copy, one for the join. > "join with InitEnv" should reduce to the identity function, so if its not, > that feels like a problem we're sweeping under the rug. Only in a mathematical sense - in reality humans need to read these SAT systems, and we're using a solver that can't perform that reduction. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153493/new/ https://reviews.llvm.org/D153493 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits