|
@@ -2882,12 +2882,11 @@ static void nfs4_close_prepare(struct rpc_task *task, void *data)
|
|
call_close |= is_wronly;
|
|
call_close |= is_wronly;
|
|
else if (is_wronly)
|
|
else if (is_wronly)
|
|
calldata->arg.fmode |= FMODE_WRITE;
|
|
calldata->arg.fmode |= FMODE_WRITE;
|
|
|
|
+ if (calldata->arg.fmode != (FMODE_READ|FMODE_WRITE))
|
|
|
|
+ call_close |= is_rdwr;
|
|
} else if (is_rdwr)
|
|
} else if (is_rdwr)
|
|
calldata->arg.fmode |= FMODE_READ|FMODE_WRITE;
|
|
calldata->arg.fmode |= FMODE_READ|FMODE_WRITE;
|
|
|
|
|
|
- if (calldata->arg.fmode == 0)
|
|
|
|
- call_close |= is_rdwr;
|
|
|
|
-
|
|
|
|
if (!nfs4_valid_open_stateid(state))
|
|
if (!nfs4_valid_open_stateid(state))
|
|
call_close = 0;
|
|
call_close = 0;
|
|
spin_unlock(&state->owner->so_lock);
|
|
spin_unlock(&state->owner->so_lock);
|