On Tue, Nov 23, 2021 at 04:40:06PM -0800, Dan Williams wrote: > Let me ask a clarifying question coming from the other direction that > resulted in the creation of the auxiliary bus architecture. Some > background. RDMA is a protocol that may run on top of Ethernet. No, RDMA is a concept. Linux supports 2 and a half RDMA protocols that run over ethernet (RoCE v1 and v2 and iWarp). > Consider the case where you have multiple generations of Ethernet > adapter devices, but they all support common RDMA functionality. You > only have the one PCI device to attach a unique Ethernet driver. What > is an idiomatic way to deploy a module that automatically loads and > attaches to the exported common functionality across adapters that > otherwise have a unique native driver for the hardware device? The whole aux bus drama is mostly because the intel design for these is really fucked up. All the sane HCAs do not use this model. All this attchment crap really should not be there. > Another example, the Native PCIe Enclosure Management (NPEM) > specification defines a handful of registers that can appear anywhere > in the PCIe hierarchy. How can you write a common driver that is > generically applicable to any given NPEM instance? Another totally messed up spec. But then pretty much everything coming from the PCIe SIG in terms of interface tends to be really, really broken lately.