xfs: don't retry repairs harder when EAGAIN is returned
Repair functions will not return EAGAIN -- if they were not able to obtain resources, they should return EDEADLOCK (like the rest of online fsck) to signal that we need to grab all the resources and try again. Hence we don't need to deal with this case except as a debugging assertion. Signed-off-by: Darrick J. Wong <djwong@kernel.org> Reviewed-by: Dave Chinner <dchinner@redhat.com>
This commit is contained in:
parent
0a713bd41e
commit
6bf2f87915
@ -61,7 +61,6 @@ xrep_attempt(
|
||||
sc->flags |= XREP_ALREADY_FIXED;
|
||||
return -EAGAIN;
|
||||
case -EDEADLOCK:
|
||||
case -EAGAIN:
|
||||
/* Tell the caller to try again having grabbed all the locks. */
|
||||
if (!(sc->flags & XCHK_TRY_HARDER)) {
|
||||
sc->flags |= XCHK_TRY_HARDER;
|
||||
@ -74,6 +73,11 @@ xrep_attempt(
|
||||
*/
|
||||
return -EFSCORRUPTED;
|
||||
default:
|
||||
/*
|
||||
* EAGAIN tells the caller to re-scrub, so we cannot return
|
||||
* that here.
|
||||
*/
|
||||
ASSERT(error != -EAGAIN);
|
||||
return error;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user