aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/parse-options.c
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2010-05-17 11:16:48 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2010-05-17 11:16:48 -0400
commit6ba85cea872954a36d79e46bf6a9c6ea92794f01 (patch)
tree0831a7adc633ff0e493b53beb088cf91b827d5c6 /tools/perf/util/parse-options.c
parenta9a4ab747e2d45bf08fddbc1568f080091486af9 (diff)
perf options: Introduce OPT_U64
We have things like user_interval (-c/--count) in 'perf record' that needs this. Cc: Frédéric Weisbecker <fweisbec@gmail.com> Cc: Mike Galbraith <efault@gmx.de> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Stephane Eranian <eranian@google.com> Cc: Tom Zanussi <tzanussi@gmail.com> LKML-Reference: <new-submission> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/parse-options.c')
-rw-r--r--tools/perf/util/parse-options.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/tools/perf/util/parse-options.c b/tools/perf/util/parse-options.c
index ed887642460c..b05d51df2ce7 100644
--- a/tools/perf/util/parse-options.c
+++ b/tools/perf/util/parse-options.c
@@ -60,6 +60,7 @@ static int get_value(struct parse_opt_ctx_t *p,
60 case OPTION_STRING: 60 case OPTION_STRING:
61 case OPTION_INTEGER: 61 case OPTION_INTEGER:
62 case OPTION_LONG: 62 case OPTION_LONG:
63 case OPTION_U64:
63 default: 64 default:
64 break; 65 break;
65 } 66 }
@@ -141,6 +142,22 @@ static int get_value(struct parse_opt_ctx_t *p,
141 return opterror(opt, "expects a numerical value", flags); 142 return opterror(opt, "expects a numerical value", flags);
142 return 0; 143 return 0;
143 144
145 case OPTION_U64:
146 if (unset) {
147 *(u64 *)opt->value = 0;
148 return 0;
149 }
150 if (opt->flags & PARSE_OPT_OPTARG && !p->opt) {
151 *(u64 *)opt->value = opt->defval;
152 return 0;
153 }
154 if (get_arg(p, opt, flags, &arg))
155 return -1;
156 *(u64 *)opt->value = strtoull(arg, (char **)&s, 10);
157 if (*s)
158 return opterror(opt, "expects a numerical value", flags);
159 return 0;
160
144 case OPTION_END: 161 case OPTION_END:
145 case OPTION_ARGUMENT: 162 case OPTION_ARGUMENT:
146 case OPTION_GROUP: 163 case OPTION_GROUP:
@@ -487,6 +504,7 @@ int usage_with_options_internal(const char * const *usagestr,
487 case OPTION_SET_INT: 504 case OPTION_SET_INT:
488 case OPTION_SET_PTR: 505 case OPTION_SET_PTR:
489 case OPTION_LONG: 506 case OPTION_LONG:
507 case OPTION_U64:
490 break; 508 break;
491 } 509 }
492 510