On Tue, Feb 13, 2018 at 05:21:33PM +0000, [email protected] wrote: > > -----Original Message----- > > From: Mika Westerberg [mailto:[email protected]] > > Sent: Tuesday, February 13, 2018 11:00 AM > > To: [email protected] > > Cc: Andreas Noever <[email protected]>; Michael Jamet > > <[email protected]>; Yehezkel Bernat <[email protected]>; > > Bjorn > > Helgaas <[email protected]>; Limonciello, Mario > > <[email protected]>; Radion Mirchevsky > > <[email protected]>; Mika Westerberg > > <[email protected]> > > 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 <[email protected]> > > --- > > 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.
You are right. I'll add stable tag for v2.

