diff options
author | Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp> | 2010-09-15 11:36:24 -0400 |
---|---|---|
committer | Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp> | 2010-10-22 20:24:39 -0400 |
commit | c05dbfc2609993ccc067879579e2a7726e12b3f1 (patch) | |
tree | d5b20ce06901a05b8649d31eb8694fef8f2dddb7 | |
parent | 2879ed66e4c6da1dfc6bb0bd04566b61824f9256 (diff) |
nilfs2: accept 64-bit checkpoint numbers in cp mount option
The current implementation doesn't mount snapshots with checkpoint
numbers larger than INT_MAX since it uses match_int() for parsing
"cp=" mount option.
This uses simple_strtoull() for the conversion to resolve the issue.
Signed-off-by: Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
-rw-r--r-- | fs/nilfs2/super.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/fs/nilfs2/super.c b/fs/nilfs2/super.c index d92ebd5d60d9..a1cd444103ff 100644 --- a/fs/nilfs2/super.c +++ b/fs/nilfs2/super.c | |||
@@ -556,7 +556,6 @@ static int parse_options(char *options, struct super_block *sb, int is_remount) | |||
556 | struct nilfs_sb_info *sbi = NILFS_SB(sb); | 556 | struct nilfs_sb_info *sbi = NILFS_SB(sb); |
557 | char *p; | 557 | char *p; |
558 | substring_t args[MAX_OPT_ARGS]; | 558 | substring_t args[MAX_OPT_ARGS]; |
559 | int option; | ||
560 | 559 | ||
561 | if (!options) | 560 | if (!options) |
562 | return 1; | 561 | return 1; |
@@ -594,8 +593,6 @@ static int parse_options(char *options, struct super_block *sb, int is_remount) | |||
594 | nilfs_write_opt(sbi, ERROR_MODE, ERRORS_CONT); | 593 | nilfs_write_opt(sbi, ERROR_MODE, ERRORS_CONT); |
595 | break; | 594 | break; |
596 | case Opt_snapshot: | 595 | case Opt_snapshot: |
597 | if (match_int(&args[0], &option) || option <= 0) | ||
598 | return 0; | ||
599 | if (is_remount) { | 596 | if (is_remount) { |
600 | printk(KERN_ERR | 597 | printk(KERN_ERR |
601 | "NILFS: \"%s\" option is invalid " | 598 | "NILFS: \"%s\" option is invalid " |
@@ -1065,7 +1062,7 @@ static int nilfs_identify(char *data, struct nilfs_super_data *sd) | |||
1065 | { | 1062 | { |
1066 | char *p, *options = data; | 1063 | char *p, *options = data; |
1067 | substring_t args[MAX_OPT_ARGS]; | 1064 | substring_t args[MAX_OPT_ARGS]; |
1068 | int option, token; | 1065 | int token; |
1069 | int ret = 0; | 1066 | int ret = 0; |
1070 | 1067 | ||
1071 | do { | 1068 | do { |
@@ -1073,16 +1070,18 @@ static int nilfs_identify(char *data, struct nilfs_super_data *sd) | |||
1073 | if (p != NULL && *p) { | 1070 | if (p != NULL && *p) { |
1074 | token = match_token(p, tokens, args); | 1071 | token = match_token(p, tokens, args); |
1075 | if (token == Opt_snapshot) { | 1072 | if (token == Opt_snapshot) { |
1076 | if (!(sd->flags & MS_RDONLY)) | 1073 | if (!(sd->flags & MS_RDONLY)) { |
1077 | ret++; | 1074 | ret++; |
1078 | else { | 1075 | } else { |
1079 | ret = match_int(&args[0], &option); | 1076 | sd->cno = simple_strtoull(args[0].from, |
1080 | if (!ret) { | 1077 | NULL, 0); |
1081 | if (option > 0) | 1078 | /* |
1082 | sd->cno = option; | 1079 | * No need to see the end pointer; |
1083 | else | 1080 | * match_token() has done syntax |
1084 | ret++; | 1081 | * checking. |
1085 | } | 1082 | */ |
1083 | if (sd->cno == 0) | ||
1084 | ret++; | ||
1086 | } | 1085 | } |
1087 | } | 1086 | } |
1088 | if (ret) | 1087 | if (ret) |