On Thu, Apr 09, 2020 at 11:10:44PM +0200, Hans de Goede wrote: > Since commit dda8b2af395b ("tpm: Revert "tpm_tis_core: Set > TPM_CHIP_FLAG_IRQ before probing for interrupts"") we no longer set > the TPM_CHIP_FLAG_IRQ ever. > > So the whole IRQ probing code is not useful, worse we rely on the > IRQ-test path of tpm_tis_send() to call disable_interrupts() if > interrupts do not work, but that path never gets entered because we > never set the TPM_CHIP_FLAG_IRQ. > > So the remaining IRQ probe code calls request_irq() and never calls > free_irq() even when the interrupt is not working. > > On some systems, e.g. the Lenovo X1 8th gen, the interrupt we try > to use and never free creates an interrupt storm followed by > an "irq XX: nobody cared" oops. > > Since it is non-functional at the moment anyways, lets just completely > disable the IRQ code in tpm_tis_core for now. > > Fixes: dda8b2af395b ("tpm: Revert "tpm_tis_core: Set TPM_CHIP_FLAG_IRQ before probing for interrupts"") > Signed-off-by: Hans de Goede <hdegoede@xxxxxxxxxx> > --- > Note I'm working with Lenovo to try and get to the bottom of this. > --- OK if I recall correctly the reason for reverting was that the fixes Stefan was sending were broken and no access to hardware were the issues would be visible. The reason for not doing anything til this day is that we don't have T490 available. The lack of devm_free_irq() is an by itself, so please instead send a fix that adds that to the code instead of "#if 0" crap. Thank you. /Jarkko