> -----Original Message----- > From: Mika Westerberg [mailto:mika.westerb...@linux.intel.com] > Sent: Tuesday, February 13, 2018 11:00 AM > To: linux-kernel@vger.kernel.org > Cc: Andreas Noever <andreas.noe...@gmail.com>; Michael Jamet > <michael.ja...@intel.com>; Yehezkel Bernat <yehezkel.ber...@intel.com>; Bjorn > Helgaas <bhelg...@google.com>; Limonciello, Mario > <mario_limoncie...@dell.com>; Radion Mirchevsky > <radion.mirchev...@intel.com>; Mika Westerberg > <mika.westerb...@linux.intel.com> > Subject: [PATCH 06/18] thunderbolt: Wait a bit longer for ICM to authenticate > the > active NVM > > Sometimes during cold boot ICM has not yet authenticated the active NVM > image leading to timeout and failing the driver probe. Allow ICM to take > some more time and increase the timeout to 3 seconds before we give up. > > While there fix icm_firmware_init() to return the real error code > without overwriting it with -ENODEV. > > Signed-off-by: Mika Westerberg <mika.westerb...@linux.intel.com> > --- > drivers/thunderbolt/icm.c | 7 +++++-- > 1 file changed, 5 insertions(+), 2 deletions(-) > > diff --git a/drivers/thunderbolt/icm.c b/drivers/thunderbolt/icm.c > index 1183321586c5..611d28e8e5f2 100644 > --- a/drivers/thunderbolt/icm.c > +++ b/drivers/thunderbolt/icm.c > @@ -736,14 +736,14 @@ static bool icm_ar_is_supported(struct tb *tb) > static int icm_ar_get_mode(struct tb *tb) > { > struct tb_nhi *nhi = tb->nhi; > - int retries = 5; > + int retries = 60; > u32 val; > > do { > val = ioread32(nhi->iobase + REG_FW_STS); > if (val & REG_FW_STS_NVM_AUTH_DONE) > break; > - msleep(30); > + msleep(50); > } while (--retries); > > if (!retries) { > @@ -1063,6 +1063,9 @@ static int icm_firmware_init(struct tb *tb) > break; > > default: > + if (ret < 0) > + return ret; > + > tb_err(tb, "ICM firmware is in wrong mode: %u\n", ret); > return -ENODEV; > } > -- > 2.15.1
Mika, Some of your patches in this series already have the stable tag, but I think especially this one is probably a good candidate to add to @stable.