2017-02-09 23:13:56

by Frank Sorenson

[permalink] [raw]
Subject: [nfs-utils PATCH V2 2/2] Duplicate upcall string for use in error messages

Author: Frank Sorenson <[email protected]>
Date: 2017-02-09 16:51:44 -0600

gssd: Duplicate the upcall string for error messages

strsep() modifies the input string, so error messages
may output only part of the upcall string.

Make a copy of the upcall string, and use that in any
error messages.

Signed-off-by: Frank Sorenson <[email protected]>

diff --git a/utils/gssd/gssd_proc.c b/utils/gssd/gssd_proc.c
index 30c6ace..4fc81c3 100644
--- a/utils/gssd/gssd_proc.c
+++ b/utils/gssd/gssd_proc.c
@@ -729,10 +729,17 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
char *target = NULL;
char *service = NULL;
char *enctypes = NULL;
+ char *upcall_str;
char *pbuf = info->lbuf;

printerr(2, "\n%s: '%s' (%s)\n", __func__, info->lbuf, clp->relpath);

+ upcall_str = strdup(info->lbuf);
+ if (upcall_str == NULL) {
+ printerr(0, "ERROR: malloc failure\n");
+ goto out_nomem;
+ }
+
while ((p = strsep(&pbuf, " "))) {
if (!strncmp(p, "mech=", strlen("mech=")))
mech = p + strlen("mech=");
@@ -749,7 +756,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
if (!mech || strlen(mech) < 1) {
printerr(0, "WARNING: handle_gssd_upcall: "
"failed to find gss mechanism name "
- "in upcall string '%s'\n", info->lbuf);
+ "in upcall string '%s'\n", upcall_str);
goto out;
}

@@ -762,7 +769,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
if (!uidstr) {
printerr(0, "WARNING: handle_gssd_upcall: "
"failed to find uid "
- "in upcall string '%s'\n", info->lbuf);
+ "in upcall string '%s'\n", upcall_str);
goto out;
}

@@ -775,7 +782,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
if (target && strlen(target) < 1) {
printerr(0, "WARNING: handle_gssd_upcall: "
"failed to parse target name "
- "in upcall string '%s'\n", info->lbuf);
+ "in upcall string '%s'\n", upcall_str);
goto out;
}

@@ -790,7 +797,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
if (service && strlen(service) < 1) {
printerr(0, "WARNING: handle_gssd_upcall: "
"failed to parse service type "
- "in upcall string '%s'\n", info->lbuf);
+ "in upcall string '%s'\n", upcall_str);
goto out;
}

@@ -803,6 +810,8 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
do_error_downcall(clp->gssd_fd, uid, -EACCES);
}
out:
+ free(upcall_str);
+out_nomem:
free(info);
return;
}


2017-02-16 10:24:02

by Steve Dickson

[permalink] [raw]
Subject: Re: [nfs-utils PATCH V2 2/2] Duplicate upcall string for use in error messages



On 02/09/2017 06:04 PM, Frank Sorenson wrote:
> Author: Frank Sorenson <[email protected]>
> Date: 2017-02-09 16:51:44 -0600
>
> gssd: Duplicate the upcall string for error messages
>
> strsep() modifies the input string, so error messages
> may output only part of the upcall string.
>
> Make a copy of the upcall string, and use that in any
> error messages.
>
> Signed-off-by: Frank Sorenson <[email protected]>
Committed...

steved.
>
> diff --git a/utils/gssd/gssd_proc.c b/utils/gssd/gssd_proc.c
> index 30c6ace..4fc81c3 100644
> --- a/utils/gssd/gssd_proc.c
> +++ b/utils/gssd/gssd_proc.c
> @@ -729,10 +729,17 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
> char *target = NULL;
> char *service = NULL;
> char *enctypes = NULL;
> + char *upcall_str;
> char *pbuf = info->lbuf;
>
> printerr(2, "\n%s: '%s' (%s)\n", __func__, info->lbuf, clp->relpath);
>
> + upcall_str = strdup(info->lbuf);
> + if (upcall_str == NULL) {
> + printerr(0, "ERROR: malloc failure\n");
> + goto out_nomem;
> + }
> +
> while ((p = strsep(&pbuf, " "))) {
> if (!strncmp(p, "mech=", strlen("mech=")))
> mech = p + strlen("mech=");
> @@ -749,7 +756,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
> if (!mech || strlen(mech) < 1) {
> printerr(0, "WARNING: handle_gssd_upcall: "
> "failed to find gss mechanism name "
> - "in upcall string '%s'\n", info->lbuf);
> + "in upcall string '%s'\n", upcall_str);
> goto out;
> }
>
> @@ -762,7 +769,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
> if (!uidstr) {
> printerr(0, "WARNING: handle_gssd_upcall: "
> "failed to find uid "
> - "in upcall string '%s'\n", info->lbuf);
> + "in upcall string '%s'\n", upcall_str);
> goto out;
> }
>
> @@ -775,7 +782,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
> if (target && strlen(target) < 1) {
> printerr(0, "WARNING: handle_gssd_upcall: "
> "failed to parse target name "
> - "in upcall string '%s'\n", info->lbuf);
> + "in upcall string '%s'\n", upcall_str);
> goto out;
> }
>
> @@ -790,7 +797,7 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
> if (service && strlen(service) < 1) {
> printerr(0, "WARNING: handle_gssd_upcall: "
> "failed to parse service type "
> - "in upcall string '%s'\n", info->lbuf);
> + "in upcall string '%s'\n", upcall_str);
> goto out;
> }
>
> @@ -803,6 +810,8 @@ handle_gssd_upcall(struct clnt_upcall_info *info)
> do_error_downcall(clp->gssd_fd, uid, -EACCES);
> }
> out:
> + free(upcall_str);
> +out_nomem:
> free(info);
> return;
> }
> --
> To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
> the body of a message to [email protected]
> More majordomo info at http://vger.kernel.org/majordomo-info.html