On Thu, Nov 19 2020 at 19:56, John Garry wrote: >>>> 3) Interrupt has already been switched to managed. Double init is not >>>> really a good sign either. >>> I just tested that and case 3) would be a problem. I don't see us >>> clearing the managed flag when free'ing the interrupt. So with >>> CONFIG_DEBUG_TEST_DRIVER_REMOVE=y, we attempt this affinity update >>> twice, and error from the irqd_affinity_is_managed() check. >> That means the interrupt is not deallocated and reallocated, which does >> not make sense to me. >> > > Just mentioning a couple of things here, which could be a clue to what > is going on: > - the device is behind mbigen secondary irq controller > - the flow in the LLDD is to allocate all 128 interrupts during probe, > but we only register handlers for a subset with device managed API Right, but if the driver is removed then the interrupts should be deallocated, right? Thanks, tglx