Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 69a4aa89 authored by Jakub Kicinski's avatar Jakub Kicinski Committed by David S. Miller
Browse files

nfp: correct return codes when msleep gets interrupted



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: default avatarJakub Kicinski <jakub.kicinski@netronome.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a831ffb5
Loading
Loading
Loading
Loading
+6 −6
Original line number Diff line number Diff line
@@ -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;