diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2014-08-29 12:37:29 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2014-10-09 02:39:10 -0400 |
commit | 8ba7f6c2faada3ad553518b9febbdce7a988359b (patch) | |
tree | 5e821d13563bb2059a1393655c02ce14a80c1542 /tools/perf/util/string.c | |
parent | 849f3127bb46ef75a66dffc1b9b0d3f5f43fa395 (diff) |
saner perf_atoll()
That loop in there is both anti-idiomatic *and* completely pointless.
strtoll() is there for purpose; use it and compare what's left with
acceptable suffices.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'tools/perf/util/string.c')
-rw-r--r-- | tools/perf/util/string.c | 90 |
1 files changed, 30 insertions, 60 deletions
diff --git a/tools/perf/util/string.c b/tools/perf/util/string.c index 2553e5b55b89..d87767f76903 100644 --- a/tools/perf/util/string.c +++ b/tools/perf/util/string.c | |||
@@ -9,78 +9,48 @@ | |||
9 | */ | 9 | */ |
10 | s64 perf_atoll(const char *str) | 10 | s64 perf_atoll(const char *str) |
11 | { | 11 | { |
12 | unsigned int i; | 12 | s64 length; |
13 | s64 length = -1, unit = 1; | 13 | char *p; |
14 | char c; | ||
14 | 15 | ||
15 | if (!isdigit(str[0])) | 16 | if (!isdigit(str[0])) |
16 | goto out_err; | 17 | goto out_err; |
17 | 18 | ||
18 | for (i = 1; i < strlen(str); i++) { | 19 | length = strtoll(str, &p, 10); |
19 | switch (str[i]) { | 20 | switch (c = *p++) { |
20 | case 'B': | 21 | case 'b': case 'B': |
21 | case 'b': | 22 | if (*p) |
22 | break; | ||
23 | case 'K': | ||
24 | if (str[i + 1] != 'B') | ||
25 | goto out_err; | ||
26 | else | ||
27 | goto kilo; | ||
28 | case 'k': | ||
29 | if (str[i + 1] != 'b') | ||
30 | goto out_err; | ||
31 | kilo: | ||
32 | unit = K; | ||
33 | break; | ||
34 | case 'M': | ||
35 | if (str[i + 1] != 'B') | ||
36 | goto out_err; | ||
37 | else | ||
38 | goto mega; | ||
39 | case 'm': | ||
40 | if (str[i + 1] != 'b') | ||
41 | goto out_err; | 23 | goto out_err; |
42 | mega: | 24 | case '\0': |
43 | unit = K * K; | 25 | return length; |
26 | default: | ||
27 | goto out_err; | ||
28 | /* two-letter suffices */ | ||
29 | case 'k': case 'K': | ||
30 | length <<= 10; | ||
44 | break; | 31 | break; |
45 | case 'G': | 32 | case 'm': case 'M': |
46 | if (str[i + 1] != 'B') | 33 | length <<= 20; |
47 | goto out_err; | ||
48 | else | ||
49 | goto giga; | ||
50 | case 'g': | ||
51 | if (str[i + 1] != 'b') | ||
52 | goto out_err; | ||
53 | giga: | ||
54 | unit = K * K * K; | ||
55 | break; | 34 | break; |
56 | case 'T': | 35 | case 'g': case 'G': |
57 | if (str[i + 1] != 'B') | 36 | length <<= 30; |
58 | goto out_err; | ||
59 | else | ||
60 | goto tera; | ||
61 | case 't': | ||
62 | if (str[i + 1] != 'b') | ||
63 | goto out_err; | ||
64 | tera: | ||
65 | unit = K * K * K * K; | ||
66 | break; | 37 | break; |
67 | case '\0': /* only specified figures */ | 38 | case 't': case 'T': |
68 | unit = 1; | 39 | length <<= 40; |
69 | break; | 40 | break; |
70 | default: | ||
71 | if (!isdigit(str[i])) | ||
72 | goto out_err; | ||
73 | break; | ||
74 | } | ||
75 | } | 41 | } |
76 | 42 | /* we want the cases to match */ | |
77 | length = atoll(str) * unit; | 43 | if (islower(c)) { |
78 | goto out; | 44 | if (strcmp(p, "b") != 0) |
45 | goto out_err; | ||
46 | } else { | ||
47 | if (strcmp(p, "B") != 0) | ||
48 | goto out_err; | ||
49 | } | ||
50 | return length; | ||
79 | 51 | ||
80 | out_err: | 52 | out_err: |
81 | length = -1; | 53 | return -1; |
82 | out: | ||
83 | return length; | ||
84 | } | 54 | } |
85 | 55 | ||
86 | /* | 56 | /* |