Commit 77d8aa79 authored by Takayuki Nagata's avatar Takayuki Nagata Committed by Steve French

cifs: reinstate original behavior again for forceuid/forcegid

forceuid/forcegid should be enabled by default when uid=/gid= options are
specified, but commit 24e0a1ef ("cifs: switch to new mount api")
changed the behavior. Due to the change, a mounted share does not show
intentional uid/gid for files and directories even though uid=/gid=
options are specified since forceuid/forcegid are not enabled.

This patch reinstates original behavior that overrides uid/gid with
specified uid/gid by the options.

Fixes: 24e0a1ef ("cifs: switch to new mount api")
Signed-off-by: default avatarTakayuki Nagata <tnagata@redhat.com>
Acked-by: default avatarPaulo Alcantara (Red Hat) <pc@manguebit.com>
Acked-by: default avatarRonnie Sahlberg <lsahlber@redhat.com>
Acked-by: default avatarTom Talpey <tom@talpey.com>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 18d86965
...@@ -748,6 +748,16 @@ static int smb3_fs_context_validate(struct fs_context *fc) ...@@ -748,6 +748,16 @@ static int smb3_fs_context_validate(struct fs_context *fc)
/* set the port that we got earlier */ /* set the port that we got earlier */
cifs_set_port((struct sockaddr *)&ctx->dstaddr, ctx->port); cifs_set_port((struct sockaddr *)&ctx->dstaddr, ctx->port);
if (ctx->uid_specified && !ctx->forceuid_specified) {
ctx->override_uid = 1;
pr_notice("enabling forceuid mount option implicitly because uid= option is specified\n");
}
if (ctx->gid_specified && !ctx->forcegid_specified) {
ctx->override_gid = 1;
pr_notice("enabling forcegid mount option implicitly because gid= option is specified\n");
}
if (ctx->override_uid && !ctx->uid_specified) { if (ctx->override_uid && !ctx->uid_specified) {
ctx->override_uid = 0; ctx->override_uid = 0;
pr_notice("ignoring forceuid mount option specified with no uid= option\n"); pr_notice("ignoring forceuid mount option specified with no uid= option\n");
...@@ -1019,12 +1029,14 @@ static int smb3_fs_context_parse_param(struct fs_context *fc, ...@@ -1019,12 +1029,14 @@ static int smb3_fs_context_parse_param(struct fs_context *fc,
ctx->override_uid = 0; ctx->override_uid = 0;
else else
ctx->override_uid = 1; ctx->override_uid = 1;
ctx->forceuid_specified = true;
break; break;
case Opt_forcegid: case Opt_forcegid:
if (result.negated) if (result.negated)
ctx->override_gid = 0; ctx->override_gid = 0;
else else
ctx->override_gid = 1; ctx->override_gid = 1;
ctx->forcegid_specified = true;
break; break;
case Opt_perm: case Opt_perm:
if (result.negated) if (result.negated)
......
...@@ -165,6 +165,8 @@ enum cifs_param { ...@@ -165,6 +165,8 @@ enum cifs_param {
}; };
struct smb3_fs_context { struct smb3_fs_context {
bool forceuid_specified;
bool forcegid_specified;
bool uid_specified; bool uid_specified;
bool cruid_specified; bool cruid_specified;
bool gid_specified; bool gid_specified;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment