On Wed, Nov 16 2022 at 20:37, Jason Gunthorpe wrote: > On Wed, Nov 16, 2022 at 11:32:15PM +0100, Thomas Gleixner wrote: >> On Wed, Nov 16 2022 at 14:36, Jason Gunthorpe wrote: >> > On Fri, Nov 11, 2022 at 02:56:50PM +0100, Thomas Gleixner wrote: >> >> To support multiple MSI interrupt domains per device it is necessary to >> >> segment the xarray MSI descriptor storage. Each domain gets up to >> >> MSI_MAX_INDEX entries. >> > >> > This kinds of suggests that the new per-device MSI domains should hold >> > this storage instead of per-device xarray? >> >> No, really not. This would create random storage in random driver places >> instead of having a central storage place which is managed by the core >> code. We've had that back in the days when every architecture had it's >> own magic place to store and manage interrupt descriptors. Seen that, >> mopped it up and never want to go back. > > I don't mean shift it into the msi_domain driver logic, I just mean > stick an xarray in the struct msi_domain that the core code, and only > the core code, manages. > > But I suppose, on reflection, the strong reason not to do this is that > the msi_descriptor array is per-device, and while it would work OK > with per-device msi_domains we still have the legacy of global msi > domains and thus still need a per-device place to store the global msi > domain's per-device descriptors. I tried several approaches but all of them ended up having slightly different code pathes and decided to keep everything the same from legacy arch over global MSI and the modern per device MSI models. Due to that some of the constructs are slightly awkward, but the important outcome for me was that I ended up with as many shared code pathes as possible. Having separate code pathes for all variants is for one causing code bloat and what's worse it's a guarantee for divergance and maintenance nightmares. As this is setup/teardown management code and not the fancy hotpath where we really want to spare cycles, I went for the unified model. > You could have as many secondary domains as is required this way. Few > drivers would ever use a secondary domain, so it not really a big deal > for them to hold the pointer lifetime. > >> So what are you concerned about? > > Mostly API clarity, I find it very un-kernly to swap a clear pointer > for an ID #. We loose typing, the APIs become less clear and we now > have to worry about ID allocation policy if we ever need more than 2. I don't see an issue with that. id = msi_create_device_domain(dev, &template, ...); is not much different from: ptr = msi_create_device_domain(dev, &template, ...); But it makes a massive difference vs. encapsulation and pointer leakage. If you have a stale ID then you can't do harm, a stale pointer very much so. Aside of that once pointers are available people insist on fiddling in the guts. As I'm mopping up behind driver writers for the last twenty years now, my confidence in them is pretty close to zero. So I rather be defensive and work towards encapsulation where ever its possible. Interrupts are a source of hard to debug subtle bugs, so taking the tinkerers the tools away to cause them is a good thing IMO. Thanks, tglx