nfp: correct return codes when msleep gets interrupted
authorJakub Kicinski <jakub.kicinski@netronome.com>
Wed, 22 Mar 2017 00:59:13 +0000 (17:59 -0700)
committerDavid S. Miller <davem@davemloft.net>
Wed, 22 Mar 2017 19:59:08 +0000 (12:59 -0700)
msleep_interruptible() returns time left to wait, not error
code.  Return ERESTARTSYS when interrupted.

While at it correct a comment and make the polling a bit
more aggressive.

Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/netronome/nfp/nfpcore/nfp_nsp.c

index 34c50987c377c6e721d82621b51702457a629781..17822ae4a17f35c5da2f1127785072e154dd0b58 100644 (file)
@@ -209,9 +209,8 @@ nfp_nsp_wait_reg(struct nfp_cpp *cpp, u64 *reg,
                if ((*reg & mask) == val)
                        return 0;
 
-               err = msleep_interruptible(100);
-               if (err)
-                       return err;
+               if (msleep_interruptible(25))
+                       return -ERESTARTSYS;
 
                if (time_after(start_time, wait_until))
                        return -ETIMEDOUT;
@@ -228,7 +227,7 @@ nfp_nsp_wait_reg(struct nfp_cpp *cpp, u64 *reg,
  *
  * Return: 0 for success with no result
  *
- *      1..255 for NSP completion with a result code
+ *      positive value for NSP completion with a result code
  *
  *     -EAGAIN if the NSP is not yet present
  *     -ENODEV if the NSP is not a supported model
@@ -380,9 +379,10 @@ int nfp_nsp_wait(struct nfp_nsp *state)
                if (err != -EAGAIN)
                        break;
 
-               err = msleep_interruptible(100);
-               if (err)
+               if (msleep_interruptible(25)) {
+                       err = -ERESTARTSYS;
                        break;
+               }
 
                if (time_after(start_time, wait_until)) {
                        err = -ETIMEDOUT;