mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-06 13:09:50 +00:00
Remap the error EEXISTS => 0 *before* using error to determine if we should
return a vp.
This commit is contained in:
parent
40e7a3d7fd
commit
679106b15a
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=53776
@ -1812,18 +1812,20 @@ nfs_symlink(ap)
|
||||
nfsm_wcc_data(dvp, wccflag);
|
||||
}
|
||||
nfsm_reqdone;
|
||||
if (newvp && error)
|
||||
vput(newvp);
|
||||
else
|
||||
*ap->a_vpp = newvp;
|
||||
VTONFS(dvp)->n_flag |= NMODIFIED;
|
||||
if (!wccflag)
|
||||
VTONFS(dvp)->n_attrstamp = 0;
|
||||
/*
|
||||
* Kludge: Map EEXIST => 0 assuming that it is a reply to a retry.
|
||||
*/
|
||||
if (error == EEXIST)
|
||||
error = 0;
|
||||
|
||||
if (error) {
|
||||
if (newvp)
|
||||
vput(newvp);
|
||||
} else
|
||||
*ap->a_vpp = newvp;
|
||||
VTONFS(dvp)->n_flag |= NMODIFIED;
|
||||
if (!wccflag)
|
||||
VTONFS(dvp)->n_attrstamp = 0;
|
||||
/*
|
||||
* cnp's buffer expected to be freed if SAVESTART not set or
|
||||
* if an error was returned.
|
||||
|
@ -1812,18 +1812,20 @@ nfs_symlink(ap)
|
||||
nfsm_wcc_data(dvp, wccflag);
|
||||
}
|
||||
nfsm_reqdone;
|
||||
if (newvp && error)
|
||||
vput(newvp);
|
||||
else
|
||||
*ap->a_vpp = newvp;
|
||||
VTONFS(dvp)->n_flag |= NMODIFIED;
|
||||
if (!wccflag)
|
||||
VTONFS(dvp)->n_attrstamp = 0;
|
||||
/*
|
||||
* Kludge: Map EEXIST => 0 assuming that it is a reply to a retry.
|
||||
*/
|
||||
if (error == EEXIST)
|
||||
error = 0;
|
||||
|
||||
if (error) {
|
||||
if (newvp)
|
||||
vput(newvp);
|
||||
} else
|
||||
*ap->a_vpp = newvp;
|
||||
VTONFS(dvp)->n_flag |= NMODIFIED;
|
||||
if (!wccflag)
|
||||
VTONFS(dvp)->n_attrstamp = 0;
|
||||
/*
|
||||
* cnp's buffer expected to be freed if SAVESTART not set or
|
||||
* if an error was returned.
|
||||
|
Loading…
Reference in New Issue
Block a user