diff options
author | Artem Bityutskiy <Artem.Bityutskiy@nokia.com> | 2011-05-06 13:47:14 -0400 |
---|---|---|
committer | Artem Bityutskiy <Artem.Bityutskiy@nokia.com> | 2011-05-16 03:31:38 -0400 |
commit | dcc50c8ee334d570cef84fc956084d567f32a8a3 (patch) | |
tree | 3a8a7709df4084a82348279babd29139cd229873 | |
parent | 8ca5175b02b77178a70cbb9fd7020c4938e3d3a6 (diff) |
UBIFS: simplify error path in lprops debugging check
Simplify error path in 'scan_check_cb()' and stop using the special 'data->err'
field, but instead return the error code directly.
Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
-rw-r--r-- | fs/ubifs/lprops.c | 25 |
1 files changed, 10 insertions, 15 deletions
diff --git a/fs/ubifs/lprops.c b/fs/ubifs/lprops.c index ce9fe3933d16..ac4521ab2798 100644 --- a/fs/ubifs/lprops.c +++ b/fs/ubifs/lprops.c | |||
@@ -1044,7 +1044,7 @@ static int scan_check_cb(struct ubifs_info *c, | |||
1044 | if (cat != (lp->flags & LPROPS_CAT_MASK)) { | 1044 | if (cat != (lp->flags & LPROPS_CAT_MASK)) { |
1045 | ubifs_err("bad LEB category %d expected %d", | 1045 | ubifs_err("bad LEB category %d expected %d", |
1046 | (lp->flags & LPROPS_CAT_MASK), cat); | 1046 | (lp->flags & LPROPS_CAT_MASK), cat); |
1047 | goto out; | 1047 | return -EINVAL; |
1048 | } | 1048 | } |
1049 | } | 1049 | } |
1050 | 1050 | ||
@@ -1078,7 +1078,7 @@ static int scan_check_cb(struct ubifs_info *c, | |||
1078 | } | 1078 | } |
1079 | if (!found) { | 1079 | if (!found) { |
1080 | ubifs_err("bad LPT list (category %d)", cat); | 1080 | ubifs_err("bad LPT list (category %d)", cat); |
1081 | goto out; | 1081 | return -EINVAL; |
1082 | } | 1082 | } |
1083 | } | 1083 | } |
1084 | } | 1084 | } |
@@ -1090,15 +1090,13 @@ static int scan_check_cb(struct ubifs_info *c, | |||
1090 | if ((lp->hpos != -1 && heap->arr[lp->hpos]->lnum != lnum) || | 1090 | if ((lp->hpos != -1 && heap->arr[lp->hpos]->lnum != lnum) || |
1091 | lp != heap->arr[lp->hpos]) { | 1091 | lp != heap->arr[lp->hpos]) { |
1092 | ubifs_err("bad LPT heap (category %d)", cat); | 1092 | ubifs_err("bad LPT heap (category %d)", cat); |
1093 | goto out; | 1093 | return -EINVAL; |
1094 | } | 1094 | } |
1095 | } | 1095 | } |
1096 | 1096 | ||
1097 | buf = __vmalloc(c->leb_size, GFP_NOFS, PAGE_KERNEL); | 1097 | buf = __vmalloc(c->leb_size, GFP_NOFS, PAGE_KERNEL); |
1098 | if (!buf) { | 1098 | if (!buf) |
1099 | ubifs_err("cannot allocate memory to scan LEB %d", lnum); | 1099 | return -ENOMEM; |
1100 | goto out; | ||
1101 | } | ||
1102 | 1100 | ||
1103 | /* | 1101 | /* |
1104 | * After an unclean unmount, empty and freeable LEBs | 1102 | * After an unclean unmount, empty and freeable LEBs |
@@ -1120,9 +1118,8 @@ static int scan_check_cb(struct ubifs_info *c, | |||
1120 | 1118 | ||
1121 | sleb = ubifs_scan(c, lnum, 0, buf, 0); | 1119 | sleb = ubifs_scan(c, lnum, 0, buf, 0); |
1122 | if (IS_ERR(sleb)) { | 1120 | if (IS_ERR(sleb)) { |
1123 | data->err = PTR_ERR(sleb); | 1121 | ret = PTR_ERR(sleb); |
1124 | ret = LPT_SCAN_STOP; | 1122 | goto out; |
1125 | goto exit; | ||
1126 | } | 1123 | } |
1127 | 1124 | ||
1128 | is_idx = -1; | 1125 | is_idx = -1; |
@@ -1240,10 +1237,8 @@ static int scan_check_cb(struct ubifs_info *c, | |||
1240 | } | 1237 | } |
1241 | 1238 | ||
1242 | ubifs_scan_destroy(sleb); | 1239 | ubifs_scan_destroy(sleb); |
1243 | ret = LPT_SCAN_CONTINUE; | ||
1244 | exit: | ||
1245 | vfree(buf); | 1240 | vfree(buf); |
1246 | return ret; | 1241 | return LPT_SCAN_CONTINUE; |
1247 | 1242 | ||
1248 | out_print: | 1243 | out_print: |
1249 | ubifs_err("bad accounting of LEB %d: free %d, dirty %d flags %#x, " | 1244 | ubifs_err("bad accounting of LEB %d: free %d, dirty %d flags %#x, " |
@@ -1252,10 +1247,10 @@ out_print: | |||
1252 | dbg_dump_leb(c, lnum); | 1247 | dbg_dump_leb(c, lnum); |
1253 | out_destroy: | 1248 | out_destroy: |
1254 | ubifs_scan_destroy(sleb); | 1249 | ubifs_scan_destroy(sleb); |
1250 | ret = -EINVAL; | ||
1255 | out: | 1251 | out: |
1256 | vfree(buf); | 1252 | vfree(buf); |
1257 | data->err = -EINVAL; | 1253 | return ret; |
1258 | return LPT_SCAN_STOP; | ||
1259 | } | 1254 | } |
1260 | 1255 | ||
1261 | /** | 1256 | /** |