aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/super.c
diff options
context:
space:
mode:
authorTero Roponen <tero.roponen@gmail.com>2010-12-27 03:43:13 -0500
committerLi Zefan <lizf@cn.fujitsu.com>2011-01-26 12:05:11 -0500
commit3f3d0bc0df041236fad4ffa82188a6e4ef9af75e (patch)
treeb27b210a3c48e08e63d1ee69c9b4b7e86709e360 /fs/btrfs/super.c
parentbdc924bb4cdac92b945945c3149ab8191c92d75d (diff)
Btrfs: Free correct pointer after using strsep
We must save and free the original kstrdup()'ed pointer because strsep() modifies its first argument. Signed-off-by: Tero Roponen <tero.roponen@gmail.com> Signed-off-by: Li Zefan <lizf@cn.fujitsu.com>
Diffstat (limited to 'fs/btrfs/super.c')
-rw-r--r--fs/btrfs/super.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c
index f50253c2279d..78ee681465af 100644
--- a/fs/btrfs/super.c
+++ b/fs/btrfs/super.c
@@ -277,7 +277,7 @@ static int btrfs_parse_early_options(const char *options, fmode_t flags,
277 struct btrfs_fs_devices **fs_devices) 277 struct btrfs_fs_devices **fs_devices)
278{ 278{
279 substring_t args[MAX_OPT_ARGS]; 279 substring_t args[MAX_OPT_ARGS];
280 char *opts, *p; 280 char *opts, *orig, *p;
281 int error = 0; 281 int error = 0;
282 int intarg; 282 int intarg;
283 283
@@ -291,6 +291,7 @@ static int btrfs_parse_early_options(const char *options, fmode_t flags,
291 opts = kstrdup(options, GFP_KERNEL); 291 opts = kstrdup(options, GFP_KERNEL);
292 if (!opts) 292 if (!opts)
293 return -ENOMEM; 293 return -ENOMEM;
294 orig = opts;
294 295
295 while ((p = strsep(&opts, ",")) != NULL) { 296 while ((p = strsep(&opts, ",")) != NULL) {
296 int token; 297 int token;
@@ -326,7 +327,7 @@ static int btrfs_parse_early_options(const char *options, fmode_t flags,
326 } 327 }
327 328
328 out_free_opts: 329 out_free_opts:
329 kfree(opts); 330 kfree(orig);
330 out: 331 out:
331 /* 332 /*
332 * If no subvolume name is specified we use the default one. Allocate 333 * If no subvolume name is specified we use the default one. Allocate