Rui Ueyama via llvm-dev
2016-Dec-13  18:06 UTC
[llvm-dev] LLD status update and performance chart
On Tue, Dec 13, 2016 at 9:28 AM, Mehdi Amini <mehdi.amini at apple.com> wrote:> > > On Dec 13, 2016, at 5:55 AM, Rafael Avila de Espindola via llvm-dev < > llvm-dev at lists.llvm.org> wrote: > > > > Sean Silva via llvm-dev <llvm-dev at lists.llvm.org> writes: > >> This will also greatly facilitate certain measurements I'd like to do > >> w.r.t. different strategies for avoiding memory costs for input files > (esp. > >> minor faults and dTLB costs). I've almost gotten to the point of > >> implementing this just to do those measurements. > > > > If you do please keep it local. The bare minimum we have of library > > support is already disproportionately painful and prevents easier sharing > > with COFF. We should really not add more until the linker is done. > > This is so much in contrast with the LLVM development, I find it quite > hard to see this as an acceptable position on llvm-dev. >LLD is a subproject of the LLVM project, but as a product, LLD itself is not LLVM nor Clang, so some technical decisions that make sense to them are not directly be applicable or even inappropriate. As a person who spent almost two years on the old LLD and 1.5 years on the new LLD, I can say that Rafael's stance on focusing on making a good linker first really makes sense. I can easily imagine that if we didn't focus on that, we couldn't make this much progress over the past 1.5 year and would be stagnated at a very basic level. Do you know if I'm a person who worked really hard on the old (and probably "modular" whatever it means) linker so hard? I'm speaking based on the experience. If you have an concrete idea how to construct a linker from smaller modules, please tell me. I still don't get what you want. We can discuss concrete proposals, but "making it (more) modular" is too vague and not really a proposal, so it cannot be a productive discussion. That said, I think the current our "API" to allow users call our linker's main function hit the sweet spot. I know at least a few LLVM-based language developers who want to eliminate external dependencies and embed a linker to their compilers. That's a reasonable usage, and I think allowing them to pass a map from filename to MemoryBuffer objects makes sense, too. That would be done without affecting the overall linker architecture. I don't oppose to that idea, and if someone wrote a patch, I'm fine with that. -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161213/c44384de/attachment.html>
Mehdi Amini via llvm-dev
2016-Dec-13  19:02 UTC
[llvm-dev] LLD status update and performance chart
> On Dec 13, 2016, at 10:06 AM, Rui Ueyama <ruiu at google.com> wrote: > > On Tue, Dec 13, 2016 at 9:28 AM, Mehdi Amini <mehdi.amini at apple.com <mailto:mehdi.amini at apple.com>> wrote: > > > On Dec 13, 2016, at 5:55 AM, Rafael Avila de Espindola via llvm-dev <llvm-dev at lists.llvm.org <mailto:llvm-dev at lists.llvm.org>> wrote: > > > > Sean Silva via llvm-dev <llvm-dev at lists.llvm.org <mailto:llvm-dev at lists.llvm.org>> writes: > >> This will also greatly facilitate certain measurements I'd like to do > >> w.r.t. different strategies for avoiding memory costs for input files (esp. > >> minor faults and dTLB costs). I've almost gotten to the point of > >> implementing this just to do those measurements. > > > > If you do please keep it local. The bare minimum we have of library > > support is already disproportionately painful and prevents easier sharing > > with COFF. We should really not add more until the linker is done. > > This is so much in contrast with the LLVM development, I find it quite hard to see this as an acceptable position on llvm-dev. > > LLD is a subproject of the LLVM project, but as a product, LLD itself is not LLVM nor Clang, so some technical decisions that make sense to them are not directly be applicable or even inappropriate. As a person who spent almost two years on the old LLD and 1.5 years on the new LLD, I can say that Rafael's stance on focusing on making a good linker first really makes sense. I can easily imagine that if we didn't focus on that, we couldn't make this much progress over the past 1.5 year and would be stagnated at a very basic level. Do you know if I'm a person who worked really hard on the old (and probably "modular" whatever it means) linker so hard? I'm speaking based on the experience. If you have an concrete idea how to construct a linker from smaller modules, please tell me. I still don't get what you want. We can discuss concrete proposals, but "making it (more) modular" is too vague and not really a proposal, so it cannot be a productive discussion. > > That said, I think the current our "API" to allow users call our linker's main function hit the sweet spot. I know at least a few LLVM-based language developers who want to eliminate external dependencies and embed a linker to their compilers. That's a reasonable usage, and I think allowing them to pass a map from filename to MemoryBuffer objects makes sense, too. That would be done without affecting the overall linker architecture. I don't oppose to that idea, and if someone wrote a patch, I'm fine with that.I’m totally willing to believe you that it is not possible to write the fastest ELF linker on earth (or in the universe) with a library based and reusable components approach. But clang is not the fastest C/C++ compiler available, and LLVM is not the fastest compiler framework either! So as a project, it seems to me that LLVM has not put the tradeoff on the speed/efficiency historically when it was to the detriment of layering/component/modularity/reusability/… Writing the fastest linker possible is nice goal, I regret that a LLVM subproject is putting this goal above layering/component/modularity/reusability/… though. — Mehdi -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161213/efec955a/attachment.html>
David Chisnall via llvm-dev
2016-Dec-13  19:06 UTC
[llvm-dev] LLD status update and performance chart
On 13 Dec 2016, at 19:02, Mehdi Amini via llvm-dev <llvm-dev at lists.llvm.org> wrote:> > I’m totally willing to believe you that it is not possible to write the fastest ELF linker on earth (or in the universe) with a library based and reusable components approach. But clang is not the fastest C/C++ compiler available, and LLVM is not the fastest compiler framework either!I’m not how it compares now, but at least when I started contributing and for a year or two after the speed of clang (especially at O0, for fast compile-test-debug cycles) was one of its big selling points. David
Andrew Kelley via llvm-dev
2016-Dec-13  19:07 UTC
[llvm-dev] LLD status update and performance chart
On Tue, Dec 13, 2016 at 1:06 PM, Rui Ueyama via llvm-dev < llvm-dev at lists.llvm.org> wrote:> > That said, I think the current our "API" to allow users call our linker's > main function hit the sweet spot. I know at least a few LLVM-based language > developers who want to eliminate external dependencies and embed a linker > to their compilers. That's a reasonable usage, and I think allowing them to > pass a map from filename to MemoryBuffer objects makes sense, too. That > would be done without affecting the overall linker architecture. I don't > oppose to that idea, and if someone wrote a patch, I'm fine with that. >As an LLVM-based language developer, this is exactly what I want to do. In short: * Avoid depending on an external binary * Avoid a fork+exec * Avoid unnecessary use of the filesystem Does this feature compromise progress on the linker binary? Would it be reasonable for this feature to exist in the next minor version release of lld? -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161213/ccefcc31/attachment.html>
Rui Ueyama via llvm-dev
2016-Dec-13  19:08 UTC
[llvm-dev] LLD status update and performance chart
On Tue, Dec 13, 2016 at 11:02 AM, Mehdi Amini <mehdi.amini at apple.com> wrote:> > On Dec 13, 2016, at 10:06 AM, Rui Ueyama <ruiu at google.com> wrote: > > On Tue, Dec 13, 2016 at 9:28 AM, Mehdi Amini <mehdi.amini at apple.com> > wrote: > >> >> > On Dec 13, 2016, at 5:55 AM, Rafael Avila de Espindola via llvm-dev < >> llvm-dev at lists.llvm.org> wrote: >> > >> > Sean Silva via llvm-dev <llvm-dev at lists.llvm.org> writes: >> >> This will also greatly facilitate certain measurements I'd like to do >> >> w.r.t. different strategies for avoiding memory costs for input files >> (esp. >> >> minor faults and dTLB costs). I've almost gotten to the point of >> >> implementing this just to do those measurements. >> > >> > If you do please keep it local. The bare minimum we have of library >> > support is already disproportionately painful and prevents easier >> sharing >> > with COFF. We should really not add more until the linker is done. >> >> This is so much in contrast with the LLVM development, I find it quite >> hard to see this as an acceptable position on llvm-dev. >> > > LLD is a subproject of the LLVM project, but as a product, LLD itself is > not LLVM nor Clang, so some technical decisions that make sense to them are > not directly be applicable or even inappropriate. As a person who spent > almost two years on the old LLD and 1.5 years on the new LLD, I can say > that Rafael's stance on focusing on making a good linker first really makes > sense. I can easily imagine that if we didn't focus on that, we couldn't > make this much progress over the past 1.5 year and would be stagnated at a > very basic level. Do you know if I'm a person who worked really hard on the > old (and probably "modular" whatever it means) linker so hard? I'm speaking > based on the experience. If you have an concrete idea how to construct a > linker from smaller modules, please tell me. I still don't get what you > want. We can discuss concrete proposals, but "making it (more) modular" is > too vague and not really a proposal, so it cannot be a productive > discussion. > > That said, I think the current our "API" to allow users call our linker's > main function hit the sweet spot. I know at least a few LLVM-based language > developers who want to eliminate external dependencies and embed a linker > to their compilers. That's a reasonable usage, and I think allowing them to > pass a map from filename to MemoryBuffer objects makes sense, too. That > would be done without affecting the overall linker architecture. I don't > oppose to that idea, and if someone wrote a patch, I'm fine with that. > > > I’m totally willing to believe you that it is not possible to write the > fastest ELF linker on earth (or in the universe) with a library based and > reusable components approach. But clang is not the fastest C/C++ compiler > available, and LLVM is not the fastest compiler framework either! > > So as a project, it seems to me that LLVM has not put the tradeoff on the > speed/efficiency historically when it was to the detriment of > layering/component/modularity/reusability/… > > Writing the fastest linker possible is nice goal, I regret that a LLVM > subproject is putting this goal above layering/component/modularity/reusability/… > though. >I've never mentioned that creating the fastest linker is the only goal. Medhi, please tell how you would *actually* layer linkers with fine-grained components. You are just saying that the current LLD is worse than an imaginary super-beautiful linker. -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161213/16a0aa6f/attachment.html>
Rui Ueyama via llvm-dev
2016-Dec-13  19:20 UTC
[llvm-dev] LLD status update and performance chart
On Tue, Dec 13, 2016 at 11:07 AM, Andrew Kelley <superjoe30 at gmail.com> wrote:> On Tue, Dec 13, 2016 at 1:06 PM, Rui Ueyama via llvm-dev < > llvm-dev at lists.llvm.org> wrote: >> >> That said, I think the current our "API" to allow users call our linker's >> main function hit the sweet spot. I know at least a few LLVM-based language >> developers who want to eliminate external dependencies and embed a linker >> to their compilers. That's a reasonable usage, and I think allowing them to >> pass a map from filename to MemoryBuffer objects makes sense, too. That >> would be done without affecting the overall linker architecture. I don't >> oppose to that idea, and if someone wrote a patch, I'm fine with that. >> > > As an LLVM-based language developer, this is exactly what I want to do. In > short: > > * Avoid depending on an external binary > * Avoid a fork+exec > * Avoid unnecessary use of the filesystem > > Does this feature compromise progress on the linker binary? >I don't think so. There is a function in the driver to open input files, and you can make a change to that function. Would it be reasonable for this feature to exist in the next minor version> release of lld? >By the next minor release, do you mean the next LLVM release that's planned early next year? If you write a patch, I can review (and Rafael would want to take a look too). -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161213/64a57b41/attachment.html>
Rafael Avila de Espindola via llvm-dev
2016-Dec-13  20:30 UTC
[llvm-dev] LLD status update and performance chart
Andrew Kelley via llvm-dev <llvm-dev at lists.llvm.org> writes:> On Tue, Dec 13, 2016 at 1:06 PM, Rui Ueyama via llvm-dev < > llvm-dev at lists.llvm.org> wrote: >> >> That said, I think the current our "API" to allow users call our linker's >> main function hit the sweet spot. I know at least a few LLVM-based language >> developers who want to eliminate external dependencies and embed a linker >> to their compilers. That's a reasonable usage, and I think allowing them to >> pass a map from filename to MemoryBuffer objects makes sense, too. That >> would be done without affecting the overall linker architecture. I don't >> oppose to that idea, and if someone wrote a patch, I'm fine with that. >> > > As an LLVM-based language developer, this is exactly what I want to do. In > short: > > * Avoid depending on an external binary > * Avoid a fork+exec > * Avoid unnecessary use of the filesystem > > Does this feature compromise progress on the linker binary? > > Would it be reasonable for this feature to exist in the next minor version > release of lld?I would please ask for it to wait. It requires designing how the linker script parser and the thin archive system will fetch new files as they are found. Also, please consider what is so bad about writing a file. If your language has anything like translation unites than most of the program should already be in .o files. Cheers, Rafael
Sean Silva via llvm-dev
2016-Dec-14  04:03 UTC
[llvm-dev] LLD status update and performance chart
On Tue, Dec 13, 2016 at 11:02 AM, Mehdi Amini <mehdi.amini at apple.com> wrote:> > On Dec 13, 2016, at 10:06 AM, Rui Ueyama <ruiu at google.com> wrote: > > On Tue, Dec 13, 2016 at 9:28 AM, Mehdi Amini <mehdi.amini at apple.com> > wrote: > >> >> > On Dec 13, 2016, at 5:55 AM, Rafael Avila de Espindola via llvm-dev < >> llvm-dev at lists.llvm.org> wrote: >> > >> > Sean Silva via llvm-dev <llvm-dev at lists.llvm.org> writes: >> >> This will also greatly facilitate certain measurements I'd like to do >> >> w.r.t. different strategies for avoiding memory costs for input files >> (esp. >> >> minor faults and dTLB costs). I've almost gotten to the point of >> >> implementing this just to do those measurements. >> > >> > If you do please keep it local. The bare minimum we have of library >> > support is already disproportionately painful and prevents easier >> sharing >> > with COFF. We should really not add more until the linker is done. >> >> This is so much in contrast with the LLVM development, I find it quite >> hard to see this as an acceptable position on llvm-dev. >> > > LLD is a subproject of the LLVM project, but as a product, LLD itself is > not LLVM nor Clang, so some technical decisions that make sense to them are > not directly be applicable or even inappropriate. As a person who spent > almost two years on the old LLD and 1.5 years on the new LLD, I can say > that Rafael's stance on focusing on making a good linker first really makes > sense. I can easily imagine that if we didn't focus on that, we couldn't > make this much progress over the past 1.5 year and would be stagnated at a > very basic level. Do you know if I'm a person who worked really hard on the > old (and probably "modular" whatever it means) linker so hard? I'm speaking > based on the experience. If you have an concrete idea how to construct a > linker from smaller modules, please tell me. I still don't get what you > want. We can discuss concrete proposals, but "making it (more) modular" is > too vague and not really a proposal, so it cannot be a productive > discussion. > > That said, I think the current our "API" to allow users call our linker's > main function hit the sweet spot. I know at least a few LLVM-based language > developers who want to eliminate external dependencies and embed a linker > to their compilers. That's a reasonable usage, and I think allowing them to > pass a map from filename to MemoryBuffer objects makes sense, too. That > would be done without affecting the overall linker architecture. I don't > oppose to that idea, and if someone wrote a patch, I'm fine with that. > > > I’m totally willing to believe you that it is not possible to write the > fastest ELF linker on earth (or in the universe) with a library based and > reusable components approach. But clang is not the fastest C/C++ compiler > available, and LLVM is not the fastest compiler framework either! > > So as a project, it seems to me that LLVM has not put the tradeoff on the > speed/efficiency historically when it was to the detriment of > layering/component/modularity/reusability/… > > Writing the fastest linker possible is nice goal, I regret that a LLVM > subproject is putting this goal above layering/component/modularity/reusability/… > though. >I think you are misunderstanding. None of the things you object to are not done for performance reasons, but rather for reducing code complexity and making the code easier to read (believe it or not). In fact, Rui is usually the first one to reject performance improvements if they make the code harder to maintain. -- Sean Silva> > — > Mehdi > > >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20161213/ee996bfe/attachment-0001.html>