On Fri, Sep 10, 2021 at 06:10:27PM +0200, Daniel Vetter wrote: > Forgot to add dri-devel. > > On Fri, Sep 10, 2021 at 6:09 PM Daniel Vetter <daniel.vetter@xxxxxxxx> wrote: > > > > On Fri, Sep 10, 2021 at 9:58 AM Greg Kroah-Hartman > > <gregkh@xxxxxxxxxxxxxxxxxxx> wrote: > > > On Fri, Sep 10, 2021 at 10:26:56AM +0300, Oded Gabbay wrote: > > > > Hi Greg, > > > > > > > > Following our conversations a couple of months ago, I'm happy to tell you that > > > > Habanalabs has open-sourced its TPC (Tensor Processing Core) LLVM compiler, > > > > which is a fork of the LLVM open-source project. > > > > > > > > The project can be found on Habanalabs GitHub website at: > > > > https://github.com/HabanaAI/tpc_llvm > > > > > > > > There is a companion guide on how to write TPC kernels at: > > > > https://docs.habana.ai/en/latest/TPC_User_Guide/TPC_User_Guide.html > > > > > > That's great news, thanks for pushing for this and releasing it all! > > > > Yeah this is neat. > > > > There's still the problem that we spent the past 2.5 years pissing off > > a lot of people for an imo questionable political project, bypassing > > all the technical review and expertise. Now that the political > > nonsense is resolved I think we need to look at at least the technical > > cleanup. The angered people are much harder to fix, so let's maybe > > ignore that (or perhaps a ks topic, no idea, I'm honestly not super > > motivated to rehash this entire story again). Here's what I think we > > should do: > > > > - move drivers/misc/habanalabs under drivers/gpu/habanalabs and > > review/discussions on dri-devel Wait, why move into gpu? Are we going to do that for all hardware accelerators that we currently have in the kernel tree? These things are not GPUs in the sense of them being "do some work and write out to a screen", which is what I would associate with a GPU (G does stand for "Graphical", right?) Yes, GPUs can do things that some accelerators can do, but they can do things that accelerators can not do, and the other way around as well. I doubt you want all of the existing gpu drivers to be only treated as an "accelerator driver" now, as where would the logic that has to happen to get the bits out to a screen live? And since we have a long history of accepting accelerator drivers (I see some in our tree since 2018 at the least), and there is no common userspace collation trying to make a common userspace api, why do they have to live in the same place? What makes them common except for the fact that they use the kernel as a semi-dumb pipe to send work to and from a different processor? Look at drivers/misc/cxl/ and drivers/misc/ocxl and drivers/misc/uacce/ and drivers/misc/sgi-gru and drivers/misc/bcm-vk/ even drivers/misc/mei/ as that is an off-load engine we talk to, right? What about the drivers/fpga/ api we have, it handles accelerators as well. I'm sure we have many other examples in the kernel tree as well, I just did a quick look and found these. All the above accelerators do things in different ways because their hardware is different, so they need different user/kernel apis, right? How are we going to unify them? Who is going to unify them? So drivers/accel/ perhaps? I would be able to get rid of loads of drivers/misc/ code that way :) Who is going to be the new maintainer of this subsystem? So far they have all been going into drivers/misc/ because no one else stepped up to do the review of them except me. I would _LOVE_ the help here as I end up reviewing a new one every kernel release at the least, but companies do not seem to be willing to fund developers to be maintainers these days :( And yes, I have been reviewing the fpga code as well, even though they do have a good maintainer, as those patches flow through my tree due to historical reasons. I know the fpga developers would have loved some help with review of those patches. > > - grandfather the entire current situation in as-is, it's not the only > > driver we have with a funny uapi of its own (but the other driver did > > manage to get their compiler into upstream llvm even, and not like 2 > > years late) We have many many accelerator drivers with odd uapis as they all work differently. Are we going to have to have any new company that comes along use one of the existing apis we have (and if so, which one?) or do we allow them to create their own as everyone does do things differently, which really is fine as far as a kernel is concerned (again, semi-dumb pipe.) > > - review the dma-buf stuff on dri-devel and then land it through > > standard flows, not the gregk-misc bypass Are dma-bufs somehow required to be reviewed on dri-devel? As others have asked in the past, they are already being used in other subsystems (like IB) today, did those authors also get review there? If so, great, if not, that feels odd to me, as I am seeing lots of out-of-tree drivers start to use these structures, which is why the api was created (to stop the roll-your-own-implementations.) Does dri-devel want me to have those vendors cc: you all when those get submitted? > > - close drivers/misc backdoor for further accel driver submissions, > > I'd like to focus on technical stuff in this area going forward and > > not pointless exercises in bypassing due process and all that I will be glad to not accept any more, but as I say above, what are the new requirements going to be so that those companies that do want to submit their code know what to do? And what exactly are we using as a definition of an accelerator? We have networking cards that are "accelerators" as well as crypto "accelerators" :) > > I expect we'll have a proper discussion what the stack should look > > like with the next submission (from a different vendor maybe), that > > ship kinda sailed with habanalabs. Who is going to define this stack? As there is no industry standard, why would we define this? thanks, greg k-h