<div dir="ltr"><div>Hi William,</div><div><br></div><div>I think this is a really cool project and worthy of being in LLVM. For now it's a plugin pass, which goes well with incubator projects, but it could very well be a standard IR pass that is enabled by flags, etc. We have similar examples for OpenCL, OpenMP, etc. which need integration on both Clang and LLVM. Shouldn't be too messy.</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Tue, 12 Jan 2021 at 22:14, William Moses via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Obviously integration into the monorepo itself would fix this for subsequent versions so it's somewhat of a chicken-and-the egg issue. I'd love to hear any thoughts from folks on how something like this might be eventually handled. I'd also like to see upstream users (for example to differentiate MLIR -- ideally with nice integration for reductions, see comment below regarding parallelism).<br></div></blockquote><div><br></div><div>I think long term you should split support for older versions with the trunk version. Once (and if) it gets merged into the monorepo, we can keep the incubation repo with the previous versions only, and only to official versions, mostly static and for historical value. People should be encouraged to use the newer versions that have native support.</div><div><br></div><div>Differentiating MLIR would probably be a separate infrastructure, not sure using the same libraries? I haven't dug too much, but I expect some of the analysis to be tailored to LLVM's operations and types, which have fixed semantics and are very different from MLIR, with custom dialects, operations and types. But it would be really nice if we had that at the MLIR level, at least for the standard upstream dialects, as it would be a major boost for ML compilers to start using MLIR more aggressively.</div><div><br></div><div>cheers,</div><div>--renato</div></div></div>