682d9da486
There are two notable fixes scheduled for the next release that we should get in the package now. cifs.upcall: fix regression in kerberos mount mount.cifs: fix crash when mount point does not exist
41 lines
866 B
Diff
41 lines
866 B
Diff
diff --git a/mount.cifs.c b/mount.cifs.c
|
|
index 7f898bbd215a..84274c98ddf5 100644
|
|
--- a/mount.cifs.c
|
|
+++ b/mount.cifs.c
|
|
@@ -1996,9 +1996,9 @@ acquire_mountpoint(char **mountpointp)
|
|
*/
|
|
realuid = getuid();
|
|
if (realuid == 0) {
|
|
- dacrc = toggle_dac_capability(0, 1);
|
|
- if (dacrc)
|
|
- return dacrc;
|
|
+ rc = toggle_dac_capability(0, 1);
|
|
+ if (rc)
|
|
+ goto out;
|
|
} else {
|
|
oldfsuid = setfsuid(realuid);
|
|
oldfsgid = setfsgid(getgid());
|
|
@@ -2019,7 +2019,6 @@ acquire_mountpoint(char **mountpointp)
|
|
rc = EX_SYSERR;
|
|
}
|
|
|
|
- *mountpointp = mountpoint;
|
|
restore_privs:
|
|
if (realuid == 0) {
|
|
dacrc = toggle_dac_capability(0, 0);
|
|
@@ -2030,9 +2029,13 @@ restore_privs:
|
|
gid_t __attribute__((unused)) gignore = setfsgid(oldfsgid);
|
|
}
|
|
|
|
- if (rc)
|
|
+out:
|
|
+ if (rc) {
|
|
free(mountpoint);
|
|
+ mountpoint = NULL;
|
|
+ }
|
|
|
|
+ *mountpointp = mountpoint;
|
|
return rc;
|
|
}
|
|
|