Skip to content

Commit

Permalink
fs/9p/v9fs.c (v9fs_parse_options): Handle kstrdup and match_strdup fa…
Browse files Browse the repository at this point in the history
…ilure. Now that this function can fail, return an int, diagnose other option-parsing failures, and adjust the sole caller: (v9fs_session_init): Handle kstrdup failure. Propagate any new v9fs_parse_options failure "up".

Signed-off-by: Jim Meyering <[email protected]>
Cc: Ron Minnich <[email protected]>
Cc: Latchesar Ionkov <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Acked-by: Eric Van Hensbergen <[email protected]>
  • Loading branch information
meyering authored and Eric Van Hensbergen committed May 15, 2008
1 parent ee44399 commit ab31267
Showing 1 changed file with 34 additions and 6 deletions.
40 changes: 34 additions & 6 deletions fs/9p/v9fs.c
Original file line number Diff line number Diff line change
Expand Up @@ -73,36 +73,44 @@ static match_table_t tokens = {
* v9fs_parse_options - parse mount options into session structure
* @v9ses: existing v9fs session information
*
* Return 0 upon success, -ERRNO upon failure.
*/

static void v9fs_parse_options(struct v9fs_session_info *v9ses)
static int v9fs_parse_options(struct v9fs_session_info *v9ses)
{
char *options;
substring_t args[MAX_OPT_ARGS];
char *p;
int option = 0;
char *s, *e;
int ret;
int ret = 0;

/* setup defaults */
v9ses->afid = ~0;
v9ses->debug = 0;
v9ses->cache = 0;

if (!v9ses->options)
return;
return 0;

options = kstrdup(v9ses->options, GFP_KERNEL);
if (!options) {
P9_DPRINTK(P9_DEBUG_ERROR,
"failed to allocate copy of option string\n");
return -ENOMEM;
}

while ((p = strsep(&options, ",")) != NULL) {
int token;
if (!*p)
continue;
token = match_token(p, tokens, args);
if (token < Opt_uname) {
ret = match_int(&args[0], &option);
if (ret < 0) {
int r = match_int(&args[0], &option);
if (r < 0) {
P9_DPRINTK(P9_DEBUG_ERROR,
"integer field, but no integer?\n");
ret = r;
continue;
}
}
Expand Down Expand Up @@ -138,6 +146,13 @@ static void v9fs_parse_options(struct v9fs_session_info *v9ses)

case Opt_access:
s = match_strdup(&args[0]);
if (!s) {
P9_DPRINTK(P9_DEBUG_ERROR,
"failed to allocate copy"
" of option argument\n");
ret = -ENOMEM;
break;
}
v9ses->flags &= ~V9FS_ACCESS_MASK;
if (strcmp(s, "user") == 0)
v9ses->flags |= V9FS_ACCESS_USER;
Expand All @@ -157,6 +172,7 @@ static void v9fs_parse_options(struct v9fs_session_info *v9ses)
}
}
kfree(options);
return ret;
}

/**
Expand All @@ -172,6 +188,7 @@ struct p9_fid *v9fs_session_init(struct v9fs_session_info *v9ses,
{
int retval = -EINVAL;
struct p9_fid *fid;
int rc;

v9ses->uname = __getname();
if (!v9ses->uname)
Expand All @@ -190,7 +207,18 @@ struct p9_fid *v9fs_session_init(struct v9fs_session_info *v9ses,
v9ses->dfltuid = V9FS_DEFUID;
v9ses->dfltgid = V9FS_DEFGID;
v9ses->options = kstrdup(data, GFP_KERNEL);
v9fs_parse_options(v9ses);
if (!v9ses->options) {
P9_DPRINTK(P9_DEBUG_ERROR,
"failed to allocate copy of option string\n");
retval = -ENOMEM;
goto error;
}

rc = v9fs_parse_options(v9ses);
if (rc < 0) {
retval = rc;
goto error;
}

v9ses->clnt = p9_client_create(dev_name, v9ses->options);

Expand Down

0 comments on commit ab31267

Please sign in to comment.