diff options
28 files changed, 164 insertions, 121 deletions
diff --git a/arch/powerpc/kernel/perf_event_fsl_emb.c b/arch/powerpc/kernel/perf_event_fsl_emb.c index 4dcf5f831e9d..b0dc8f7069cd 100644 --- a/arch/powerpc/kernel/perf_event_fsl_emb.c +++ b/arch/powerpc/kernel/perf_event_fsl_emb.c | |||
| @@ -596,6 +596,7 @@ static void record_and_restart(struct perf_event *event, unsigned long val, | |||
| 596 | if (left <= 0) | 596 | if (left <= 0) |
| 597 | left = period; | 597 | left = period; |
| 598 | record = 1; | 598 | record = 1; |
| 599 | event->hw.last_period = event->hw.sample_period; | ||
| 599 | } | 600 | } |
| 600 | if (left < 0x80000000LL) | 601 | if (left < 0x80000000LL) |
| 601 | val = 0x80000000LL - left; | 602 | val = 0x80000000LL - left; |
diff --git a/kernel/perf_event.c b/kernel/perf_event.c index 84522c796987..126a302c481c 100644 --- a/kernel/perf_event.c +++ b/kernel/perf_event.c | |||
| @@ -2201,13 +2201,6 @@ find_lively_task_by_vpid(pid_t vpid) | |||
| 2201 | if (!task) | 2201 | if (!task) |
| 2202 | return ERR_PTR(-ESRCH); | 2202 | return ERR_PTR(-ESRCH); |
| 2203 | 2203 | ||
| 2204 | /* | ||
| 2205 | * Can't attach events to a dying task. | ||
| 2206 | */ | ||
| 2207 | err = -ESRCH; | ||
| 2208 | if (task->flags & PF_EXITING) | ||
| 2209 | goto errout; | ||
| 2210 | |||
| 2211 | /* Reuse ptrace permission checks for now. */ | 2204 | /* Reuse ptrace permission checks for now. */ |
| 2212 | err = -EACCES; | 2205 | err = -EACCES; |
| 2213 | if (!ptrace_may_access(task, PTRACE_MODE_READ)) | 2206 | if (!ptrace_may_access(task, PTRACE_MODE_READ)) |
| @@ -2268,14 +2261,27 @@ retry: | |||
| 2268 | 2261 | ||
| 2269 | get_ctx(ctx); | 2262 | get_ctx(ctx); |
| 2270 | 2263 | ||
| 2271 | if (cmpxchg(&task->perf_event_ctxp[ctxn], NULL, ctx)) { | 2264 | err = 0; |
| 2272 | /* | 2265 | mutex_lock(&task->perf_event_mutex); |
| 2273 | * We raced with some other task; use | 2266 | /* |
| 2274 | * the context they set. | 2267 | * If it has already passed perf_event_exit_task(). |
| 2275 | */ | 2268 | * we must see PF_EXITING, it takes this mutex too. |
| 2269 | */ | ||
| 2270 | if (task->flags & PF_EXITING) | ||
| 2271 | err = -ESRCH; | ||
| 2272 | else if (task->perf_event_ctxp[ctxn]) | ||
| 2273 | err = -EAGAIN; | ||
| 2274 | else | ||
| 2275 | rcu_assign_pointer(task->perf_event_ctxp[ctxn], ctx); | ||
| 2276 | mutex_unlock(&task->perf_event_mutex); | ||
| 2277 | |||
| 2278 | if (unlikely(err)) { | ||
| 2276 | put_task_struct(task); | 2279 | put_task_struct(task); |
| 2277 | kfree(ctx); | 2280 | kfree(ctx); |
| 2278 | goto retry; | 2281 | |
| 2282 | if (err == -EAGAIN) | ||
| 2283 | goto retry; | ||
| 2284 | goto errout; | ||
| 2279 | } | 2285 | } |
| 2280 | } | 2286 | } |
| 2281 | 2287 | ||
| @@ -5374,6 +5380,8 @@ free_dev: | |||
| 5374 | goto out; | 5380 | goto out; |
| 5375 | } | 5381 | } |
| 5376 | 5382 | ||
| 5383 | static struct lock_class_key cpuctx_mutex; | ||
| 5384 | |||
| 5377 | int perf_pmu_register(struct pmu *pmu, char *name, int type) | 5385 | int perf_pmu_register(struct pmu *pmu, char *name, int type) |
| 5378 | { | 5386 | { |
| 5379 | int cpu, ret; | 5387 | int cpu, ret; |
| @@ -5422,6 +5430,7 @@ skip_type: | |||
| 5422 | 5430 | ||
| 5423 | cpuctx = per_cpu_ptr(pmu->pmu_cpu_context, cpu); | 5431 | cpuctx = per_cpu_ptr(pmu->pmu_cpu_context, cpu); |
| 5424 | __perf_event_init_context(&cpuctx->ctx); | 5432 | __perf_event_init_context(&cpuctx->ctx); |
| 5433 | lockdep_set_class(&cpuctx->ctx.mutex, &cpuctx_mutex); | ||
| 5425 | cpuctx->ctx.type = cpu_context; | 5434 | cpuctx->ctx.type = cpu_context; |
| 5426 | cpuctx->ctx.pmu = pmu; | 5435 | cpuctx->ctx.pmu = pmu; |
| 5427 | cpuctx->jiffies_interval = 1; | 5436 | cpuctx->jiffies_interval = 1; |
| @@ -6127,7 +6136,7 @@ static void perf_event_exit_task_context(struct task_struct *child, int ctxn) | |||
| 6127 | * scheduled, so we are now safe from rescheduling changing | 6136 | * scheduled, so we are now safe from rescheduling changing |
| 6128 | * our context. | 6137 | * our context. |
| 6129 | */ | 6138 | */ |
| 6130 | child_ctx = child->perf_event_ctxp[ctxn]; | 6139 | child_ctx = rcu_dereference_raw(child->perf_event_ctxp[ctxn]); |
| 6131 | task_ctx_sched_out(child_ctx, EVENT_ALL); | 6140 | task_ctx_sched_out(child_ctx, EVENT_ALL); |
| 6132 | 6141 | ||
| 6133 | /* | 6142 | /* |
| @@ -6440,11 +6449,6 @@ int perf_event_init_context(struct task_struct *child, int ctxn) | |||
| 6440 | unsigned long flags; | 6449 | unsigned long flags; |
| 6441 | int ret = 0; | 6450 | int ret = 0; |
| 6442 | 6451 | ||
| 6443 | child->perf_event_ctxp[ctxn] = NULL; | ||
| 6444 | |||
| 6445 | mutex_init(&child->perf_event_mutex); | ||
| 6446 | INIT_LIST_HEAD(&child->perf_event_list); | ||
| 6447 | |||
| 6448 | if (likely(!parent->perf_event_ctxp[ctxn])) | 6452 | if (likely(!parent->perf_event_ctxp[ctxn])) |
| 6449 | return 0; | 6453 | return 0; |
| 6450 | 6454 | ||
| @@ -6533,6 +6537,10 @@ int perf_event_init_task(struct task_struct *child) | |||
| 6533 | { | 6537 | { |
| 6534 | int ctxn, ret; | 6538 | int ctxn, ret; |
| 6535 | 6539 | ||
| 6540 | memset(child->perf_event_ctxp, 0, sizeof(child->perf_event_ctxp)); | ||
| 6541 | mutex_init(&child->perf_event_mutex); | ||
| 6542 | INIT_LIST_HEAD(&child->perf_event_list); | ||
| 6543 | |||
| 6536 | for_each_task_context_nr(ctxn) { | 6544 | for_each_task_context_nr(ctxn) { |
| 6537 | ret = perf_event_init_context(child, ctxn); | 6545 | ret = perf_event_init_context(child, ctxn); |
| 6538 | if (ret) | 6546 | if (ret) |
diff --git a/tools/perf/Makefile b/tools/perf/Makefile index 2b5387d53ba5..7141c42e1469 100644 --- a/tools/perf/Makefile +++ b/tools/perf/Makefile | |||
| @@ -204,13 +204,11 @@ EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wshadow | |||
| 204 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Winit-self | 204 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Winit-self |
| 205 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wpacked | 205 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wpacked |
| 206 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wredundant-decls | 206 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wredundant-decls |
| 207 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wstack-protector | ||
| 208 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wstrict-aliasing=3 | 207 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wstrict-aliasing=3 |
| 209 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wswitch-default | 208 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wswitch-default |
| 210 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wswitch-enum | 209 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wswitch-enum |
| 211 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wno-system-headers | 210 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wno-system-headers |
| 212 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wundef | 211 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wundef |
| 213 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wvolatile-register-var | ||
| 214 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wwrite-strings | 212 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wwrite-strings |
| 215 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wbad-function-cast | 213 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wbad-function-cast |
| 216 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wmissing-declarations | 214 | EXTRA_WARNINGS := $(EXTRA_WARNINGS) -Wmissing-declarations |
| @@ -294,6 +292,13 @@ ifeq ($(call try-cc,$(SOURCE_HELLO),-Werror -fstack-protector-all),y) | |||
| 294 | CFLAGS := $(CFLAGS) -fstack-protector-all | 292 | CFLAGS := $(CFLAGS) -fstack-protector-all |
| 295 | endif | 293 | endif |
| 296 | 294 | ||
| 295 | ifeq ($(call try-cc,$(SOURCE_HELLO),-Werror -Wstack-protector),y) | ||
| 296 | CFLAGS := $(CFLAGS) -Wstack-protector | ||
| 297 | endif | ||
| 298 | |||
| 299 | ifeq ($(call try-cc,$(SOURCE_HELLO),-Werror -Wvolatile-register-var),y) | ||
| 300 | CFLAGS := $(CFLAGS) -Wvolatile-register-var | ||
| 301 | endif | ||
| 297 | 302 | ||
| 298 | ### --- END CONFIGURATION SECTION --- | 303 | ### --- END CONFIGURATION SECTION --- |
| 299 | 304 | ||
diff --git a/tools/perf/builtin-annotate.c b/tools/perf/builtin-annotate.c index c056cdc06912..8879463807e4 100644 --- a/tools/perf/builtin-annotate.c +++ b/tools/perf/builtin-annotate.c | |||
| @@ -212,7 +212,7 @@ get_source_line(struct hist_entry *he, int len, const char *filename) | |||
| 212 | continue; | 212 | continue; |
| 213 | 213 | ||
| 214 | offset = start + i; | 214 | offset = start + i; |
| 215 | sprintf(cmd, "addr2line -e %s %016llx", filename, offset); | 215 | sprintf(cmd, "addr2line -e %s %016" PRIx64, filename, offset); |
| 216 | fp = popen(cmd, "r"); | 216 | fp = popen(cmd, "r"); |
| 217 | if (!fp) | 217 | if (!fp) |
| 218 | continue; | 218 | continue; |
| @@ -270,9 +270,9 @@ static void hist_entry__print_hits(struct hist_entry *self) | |||
| 270 | 270 | ||
| 271 | for (offset = 0; offset < len; ++offset) | 271 | for (offset = 0; offset < len; ++offset) |
| 272 | if (h->ip[offset] != 0) | 272 | if (h->ip[offset] != 0) |
| 273 | printf("%*Lx: %Lu\n", BITS_PER_LONG / 2, | 273 | printf("%*" PRIx64 ": %" PRIu64 "\n", BITS_PER_LONG / 2, |
| 274 | sym->start + offset, h->ip[offset]); | 274 | sym->start + offset, h->ip[offset]); |
| 275 | printf("%*s: %Lu\n", BITS_PER_LONG / 2, "h->sum", h->sum); | 275 | printf("%*s: %" PRIu64 "\n", BITS_PER_LONG / 2, "h->sum", h->sum); |
| 276 | } | 276 | } |
| 277 | 277 | ||
| 278 | static int hist_entry__tty_annotate(struct hist_entry *he) | 278 | static int hist_entry__tty_annotate(struct hist_entry *he) |
diff --git a/tools/perf/builtin-kmem.c b/tools/perf/builtin-kmem.c index def7ddc2fd4f..d97256d65980 100644 --- a/tools/perf/builtin-kmem.c +++ b/tools/perf/builtin-kmem.c | |||
| @@ -371,10 +371,10 @@ static void __print_result(struct rb_root *root, struct perf_session *session, | |||
| 371 | addr = data->ptr; | 371 | addr = data->ptr; |
| 372 | 372 | ||
| 373 | if (sym != NULL) | 373 | if (sym != NULL) |
| 374 | snprintf(buf, sizeof(buf), "%s+%Lx", sym->name, | 374 | snprintf(buf, sizeof(buf), "%s+%" PRIx64 "", sym->name, |
| 375 | addr - map->unmap_ip(map, sym->start)); | 375 | addr - map->unmap_ip(map, sym->start)); |
| 376 | else | 376 | else |
| 377 | snprintf(buf, sizeof(buf), "%#Lx", addr); | 377 | snprintf(buf, sizeof(buf), "%#" PRIx64 "", addr); |
| 378 | printf(" %-34s |", buf); | 378 | printf(" %-34s |", buf); |
| 379 | 379 | ||
| 380 | printf(" %9llu/%-5lu | %9llu/%-5lu | %8lu | %8lu | %6.3f%%\n", | 380 | printf(" %9llu/%-5lu | %9llu/%-5lu | %8lu | %8lu | %6.3f%%\n", |
diff --git a/tools/perf/builtin-lock.c b/tools/perf/builtin-lock.c index b9c6e5432971..2b36defc5d73 100644 --- a/tools/perf/builtin-lock.c +++ b/tools/perf/builtin-lock.c | |||
| @@ -782,9 +782,9 @@ static void print_result(void) | |||
| 782 | pr_info("%10u ", st->nr_acquired); | 782 | pr_info("%10u ", st->nr_acquired); |
| 783 | pr_info("%10u ", st->nr_contended); | 783 | pr_info("%10u ", st->nr_contended); |
| 784 | 784 | ||
| 785 | pr_info("%15llu ", st->wait_time_total); | 785 | pr_info("%15" PRIu64 " ", st->wait_time_total); |
| 786 | pr_info("%15llu ", st->wait_time_max); | 786 | pr_info("%15" PRIu64 " ", st->wait_time_max); |
| 787 | pr_info("%15llu ", st->wait_time_min == ULLONG_MAX ? | 787 | pr_info("%15" PRIu64 " ", st->wait_time_min == ULLONG_MAX ? |
| 788 | 0 : st->wait_time_min); | 788 | 0 : st->wait_time_min); |
| 789 | pr_info("\n"); | 789 | pr_info("\n"); |
| 790 | } | 790 | } |
diff --git a/tools/perf/builtin-record.c b/tools/perf/builtin-record.c index fcd29e8af29f..b2f729fdb317 100644 --- a/tools/perf/builtin-record.c +++ b/tools/perf/builtin-record.c | |||
| @@ -817,7 +817,7 @@ static int __cmd_record(int argc, const char **argv) | |||
| 817 | * Approximate RIP event size: 24 bytes. | 817 | * Approximate RIP event size: 24 bytes. |
| 818 | */ | 818 | */ |
| 819 | fprintf(stderr, | 819 | fprintf(stderr, |
| 820 | "[ perf record: Captured and wrote %.3f MB %s (~%lld samples) ]\n", | 820 | "[ perf record: Captured and wrote %.3f MB %s (~%" PRIu64 " samples) ]\n", |
| 821 | (double)bytes_written / 1024.0 / 1024.0, | 821 | (double)bytes_written / 1024.0 / 1024.0, |
| 822 | output_name, | 822 | output_name, |
| 823 | bytes_written / 24); | 823 | bytes_written / 24); |
diff --git a/tools/perf/builtin-report.c b/tools/perf/builtin-report.c index 75183a4518e6..c27e31f289e6 100644 --- a/tools/perf/builtin-report.c +++ b/tools/perf/builtin-report.c | |||
| @@ -197,7 +197,7 @@ static int process_read_event(event_t *event, struct sample_data *sample __used, | |||
| 197 | event->read.value); | 197 | event->read.value); |
| 198 | } | 198 | } |
| 199 | 199 | ||
| 200 | dump_printf(": %d %d %s %Lu\n", event->read.pid, event->read.tid, | 200 | dump_printf(": %d %d %s %" PRIu64 "\n", event->read.pid, event->read.tid, |
| 201 | attr ? __event_name(attr->type, attr->config) : "FAIL", | 201 | attr ? __event_name(attr->type, attr->config) : "FAIL", |
| 202 | event->read.value); | 202 | event->read.value); |
| 203 | 203 | ||
diff --git a/tools/perf/builtin-sched.c b/tools/perf/builtin-sched.c index 29e7ffd85690..29acb894e035 100644 --- a/tools/perf/builtin-sched.c +++ b/tools/perf/builtin-sched.c | |||
| @@ -193,7 +193,7 @@ static void calibrate_run_measurement_overhead(void) | |||
| 193 | } | 193 | } |
| 194 | run_measurement_overhead = min_delta; | 194 | run_measurement_overhead = min_delta; |
| 195 | 195 | ||
| 196 | printf("run measurement overhead: %Ld nsecs\n", min_delta); | 196 | printf("run measurement overhead: %" PRIu64 " nsecs\n", min_delta); |
| 197 | } | 197 | } |
| 198 | 198 | ||
| 199 | static void calibrate_sleep_measurement_overhead(void) | 199 | static void calibrate_sleep_measurement_overhead(void) |
| @@ -211,7 +211,7 @@ static void calibrate_sleep_measurement_overhead(void) | |||
| 211 | min_delta -= 10000; | 211 | min_delta -= 10000; |
| 212 | sleep_measurement_overhead = min_delta; | 212 | sleep_measurement_overhead = min_delta; |
| 213 | 213 | ||
| 214 | printf("sleep measurement overhead: %Ld nsecs\n", min_delta); | 214 | printf("sleep measurement overhead: %" PRIu64 " nsecs\n", min_delta); |
| 215 | } | 215 | } |
| 216 | 216 | ||
| 217 | static struct sched_atom * | 217 | static struct sched_atom * |
| @@ -617,13 +617,13 @@ static void test_calibrations(void) | |||
| 617 | burn_nsecs(1e6); | 617 | burn_nsecs(1e6); |
| 618 | T1 = get_nsecs(); | 618 | T1 = get_nsecs(); |
| 619 | 619 | ||
| 620 | printf("the run test took %Ld nsecs\n", T1-T0); | 620 | printf("the run test took %" PRIu64 " nsecs\n", T1 - T0); |
| 621 | 621 | ||
| 622 | T0 = get_nsecs(); | 622 | T0 = get_nsecs(); |
| 623 | sleep_nsecs(1e6); | 623 | sleep_nsecs(1e6); |
| 624 | T1 = get_nsecs(); | 624 | T1 = get_nsecs(); |
| 625 | 625 | ||
| 626 | printf("the sleep test took %Ld nsecs\n", T1-T0); | 626 | printf("the sleep test took %" PRIu64 " nsecs\n", T1 - T0); |
| 627 | } | 627 | } |
| 628 | 628 | ||
| 629 | #define FILL_FIELD(ptr, field, event, data) \ | 629 | #define FILL_FIELD(ptr, field, event, data) \ |
| @@ -816,10 +816,10 @@ replay_switch_event(struct trace_switch_event *switch_event, | |||
| 816 | delta = 0; | 816 | delta = 0; |
| 817 | 817 | ||
| 818 | if (delta < 0) | 818 | if (delta < 0) |
| 819 | die("hm, delta: %Ld < 0 ?\n", delta); | 819 | die("hm, delta: %" PRIu64 " < 0 ?\n", delta); |
| 820 | 820 | ||
| 821 | if (verbose) { | 821 | if (verbose) { |
| 822 | printf(" ... switch from %s/%d to %s/%d [ran %Ld nsecs]\n", | 822 | printf(" ... switch from %s/%d to %s/%d [ran %" PRIu64 " nsecs]\n", |
| 823 | switch_event->prev_comm, switch_event->prev_pid, | 823 | switch_event->prev_comm, switch_event->prev_pid, |
| 824 | switch_event->next_comm, switch_event->next_pid, | 824 | switch_event->next_comm, switch_event->next_pid, |
| 825 | delta); | 825 | delta); |
| @@ -1048,7 +1048,7 @@ latency_switch_event(struct trace_switch_event *switch_event, | |||
| 1048 | delta = 0; | 1048 | delta = 0; |
| 1049 | 1049 | ||
| 1050 | if (delta < 0) | 1050 | if (delta < 0) |
| 1051 | die("hm, delta: %Ld < 0 ?\n", delta); | 1051 | die("hm, delta: %" PRIu64 " < 0 ?\n", delta); |
| 1052 | 1052 | ||
| 1053 | 1053 | ||
| 1054 | sched_out = perf_session__findnew(session, switch_event->prev_pid); | 1054 | sched_out = perf_session__findnew(session, switch_event->prev_pid); |
| @@ -1221,7 +1221,7 @@ static void output_lat_thread(struct work_atoms *work_list) | |||
| 1221 | 1221 | ||
| 1222 | avg = work_list->total_lat / work_list->nb_atoms; | 1222 | avg = work_list->total_lat / work_list->nb_atoms; |
| 1223 | 1223 | ||
| 1224 | printf("|%11.3f ms |%9llu | avg:%9.3f ms | max:%9.3f ms | max at: %9.6f s\n", | 1224 | printf("|%11.3f ms |%9" PRIu64 " | avg:%9.3f ms | max:%9.3f ms | max at: %9.6f s\n", |
| 1225 | (double)work_list->total_runtime / 1e6, | 1225 | (double)work_list->total_runtime / 1e6, |
| 1226 | work_list->nb_atoms, (double)avg / 1e6, | 1226 | work_list->nb_atoms, (double)avg / 1e6, |
| 1227 | (double)work_list->max_lat / 1e6, | 1227 | (double)work_list->max_lat / 1e6, |
| @@ -1423,7 +1423,7 @@ map_switch_event(struct trace_switch_event *switch_event, | |||
| 1423 | delta = 0; | 1423 | delta = 0; |
| 1424 | 1424 | ||
| 1425 | if (delta < 0) | 1425 | if (delta < 0) |
| 1426 | die("hm, delta: %Ld < 0 ?\n", delta); | 1426 | die("hm, delta: %" PRIu64 " < 0 ?\n", delta); |
| 1427 | 1427 | ||
| 1428 | 1428 | ||
| 1429 | sched_out = perf_session__findnew(session, switch_event->prev_pid); | 1429 | sched_out = perf_session__findnew(session, switch_event->prev_pid); |
| @@ -1713,7 +1713,7 @@ static void __cmd_lat(void) | |||
| 1713 | } | 1713 | } |
| 1714 | 1714 | ||
| 1715 | printf(" -----------------------------------------------------------------------------------------\n"); | 1715 | printf(" -----------------------------------------------------------------------------------------\n"); |
| 1716 | printf(" TOTAL: |%11.3f ms |%9Ld |\n", | 1716 | printf(" TOTAL: |%11.3f ms |%9" PRIu64 " |\n", |
| 1717 | (double)all_runtime/1e6, all_count); | 1717 | (double)all_runtime/1e6, all_count); |
| 1718 | 1718 | ||
| 1719 | printf(" ---------------------------------------------------\n"); | 1719 | printf(" ---------------------------------------------------\n"); |
diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c index 150a606002eb..b766c2a9ac97 100644 --- a/tools/perf/builtin-script.c +++ b/tools/perf/builtin-script.c | |||
| @@ -77,8 +77,8 @@ static int process_sample_event(event_t *event, struct sample_data *sample, | |||
| 77 | if (session->sample_type & PERF_SAMPLE_RAW) { | 77 | if (session->sample_type & PERF_SAMPLE_RAW) { |
| 78 | if (debug_mode) { | 78 | if (debug_mode) { |
| 79 | if (sample->time < last_timestamp) { | 79 | if (sample->time < last_timestamp) { |
| 80 | pr_err("Samples misordered, previous: %llu " | 80 | pr_err("Samples misordered, previous: %" PRIu64 |
| 81 | "this: %llu\n", last_timestamp, | 81 | " this: %" PRIu64 "\n", last_timestamp, |
| 82 | sample->time); | 82 | sample->time); |
| 83 | nr_unordered++; | 83 | nr_unordered++; |
| 84 | } | 84 | } |
| @@ -126,7 +126,7 @@ static int __cmd_script(struct perf_session *session) | |||
| 126 | ret = perf_session__process_events(session, &event_ops); | 126 | ret = perf_session__process_events(session, &event_ops); |
| 127 | 127 | ||
| 128 | if (debug_mode) | 128 | if (debug_mode) |
| 129 | pr_err("Misordered timestamps: %llu\n", nr_unordered); | 129 | pr_err("Misordered timestamps: %" PRIu64 "\n", nr_unordered); |
| 130 | 130 | ||
| 131 | return ret; | 131 | return ret; |
| 132 | } | 132 | } |
diff --git a/tools/perf/builtin-stat.c b/tools/perf/builtin-stat.c index 0ff11d9b13be..a482a191a0ca 100644 --- a/tools/perf/builtin-stat.c +++ b/tools/perf/builtin-stat.c | |||
| @@ -206,8 +206,8 @@ static int read_counter_aggr(struct perf_evsel *counter) | |||
| 206 | update_stats(&ps->res_stats[i], count[i]); | 206 | update_stats(&ps->res_stats[i], count[i]); |
| 207 | 207 | ||
| 208 | if (verbose) { | 208 | if (verbose) { |
| 209 | fprintf(stderr, "%s: %Ld %Ld %Ld\n", event_name(counter), | 209 | fprintf(stderr, "%s: %" PRIu64 " %" PRIu64 " %" PRIu64 "\n", |
| 210 | count[0], count[1], count[2]); | 210 | event_name(counter), count[0], count[1], count[2]); |
| 211 | } | 211 | } |
| 212 | 212 | ||
| 213 | /* | 213 | /* |
diff --git a/tools/perf/builtin-test.c b/tools/perf/builtin-test.c index ed5696198d3d..5dcdba653d70 100644 --- a/tools/perf/builtin-test.c +++ b/tools/perf/builtin-test.c | |||
| @@ -146,7 +146,7 @@ next_pair: | |||
| 146 | if (llabs(skew) < page_size) | 146 | if (llabs(skew) < page_size) |
| 147 | continue; | 147 | continue; |
| 148 | 148 | ||
| 149 | pr_debug("%#Lx: diff end addr for %s v: %#Lx k: %#Lx\n", | 149 | pr_debug("%#" PRIx64 ": diff end addr for %s v: %#" PRIx64 " k: %#" PRIx64 "\n", |
| 150 | sym->start, sym->name, sym->end, pair->end); | 150 | sym->start, sym->name, sym->end, pair->end); |
| 151 | } else { | 151 | } else { |
| 152 | struct rb_node *nnd; | 152 | struct rb_node *nnd; |
| @@ -168,11 +168,11 @@ detour: | |||
| 168 | goto detour; | 168 | goto detour; |
| 169 | } | 169 | } |
| 170 | 170 | ||
| 171 | pr_debug("%#Lx: diff name v: %s k: %s\n", | 171 | pr_debug("%#" PRIx64 ": diff name v: %s k: %s\n", |
| 172 | sym->start, sym->name, pair->name); | 172 | sym->start, sym->name, pair->name); |
| 173 | } | 173 | } |
| 174 | } else | 174 | } else |
| 175 | pr_debug("%#Lx: %s not on kallsyms\n", sym->start, sym->name); | 175 | pr_debug("%#" PRIx64 ": %s not on kallsyms\n", sym->start, sym->name); |
| 176 | 176 | ||
| 177 | err = -1; | 177 | err = -1; |
| 178 | } | 178 | } |
| @@ -211,10 +211,10 @@ detour: | |||
| 211 | 211 | ||
| 212 | if (pair->start == pos->start) { | 212 | if (pair->start == pos->start) { |
| 213 | pair->priv = 1; | 213 | pair->priv = 1; |
| 214 | pr_info(" %Lx-%Lx %Lx %s in kallsyms as", | 214 | pr_info(" %" PRIx64 "-%" PRIx64 " %" PRIx64 " %s in kallsyms as", |
| 215 | pos->start, pos->end, pos->pgoff, pos->dso->name); | 215 | pos->start, pos->end, pos->pgoff, pos->dso->name); |
| 216 | if (pos->pgoff != pair->pgoff || pos->end != pair->end) | 216 | if (pos->pgoff != pair->pgoff || pos->end != pair->end) |
| 217 | pr_info(": \n*%Lx-%Lx %Lx", | 217 | pr_info(": \n*%" PRIx64 "-%" PRIx64 " %" PRIx64 "", |
| 218 | pair->start, pair->end, pair->pgoff); | 218 | pair->start, pair->end, pair->pgoff); |
| 219 | pr_info(" %s\n", pair->dso->name); | 219 | pr_info(" %s\n", pair->dso->name); |
| 220 | pair->priv = 1; | 220 | pair->priv = 1; |
| @@ -307,7 +307,7 @@ static int test__open_syscall_event(void) | |||
| 307 | } | 307 | } |
| 308 | 308 | ||
| 309 | if (evsel->counts->cpu[0].val != nr_open_calls) { | 309 | if (evsel->counts->cpu[0].val != nr_open_calls) { |
| 310 | pr_debug("perf_evsel__read_on_cpu: expected to intercept %d calls, got %Ld\n", | 310 | pr_debug("perf_evsel__read_on_cpu: expected to intercept %d calls, got %" PRIu64 "\n", |
| 311 | nr_open_calls, evsel->counts->cpu[0].val); | 311 | nr_open_calls, evsel->counts->cpu[0].val); |
| 312 | goto out_close_fd; | 312 | goto out_close_fd; |
| 313 | } | 313 | } |
| @@ -332,8 +332,7 @@ static int test__open_syscall_event_on_all_cpus(void) | |||
| 332 | struct perf_evsel *evsel; | 332 | struct perf_evsel *evsel; |
| 333 | struct perf_event_attr attr; | 333 | struct perf_event_attr attr; |
| 334 | unsigned int nr_open_calls = 111, i; | 334 | unsigned int nr_open_calls = 111, i; |
| 335 | cpu_set_t *cpu_set; | 335 | cpu_set_t cpu_set; |
| 336 | size_t cpu_set_size; | ||
| 337 | int id = trace_event__id("sys_enter_open"); | 336 | int id = trace_event__id("sys_enter_open"); |
| 338 | 337 | ||
| 339 | if (id < 0) { | 338 | if (id < 0) { |
| @@ -353,13 +352,8 @@ static int test__open_syscall_event_on_all_cpus(void) | |||
| 353 | return -1; | 352 | return -1; |
| 354 | } | 353 | } |
| 355 | 354 | ||
| 356 | cpu_set = CPU_ALLOC(cpus->nr); | ||
| 357 | 355 | ||
| 358 | if (cpu_set == NULL) | 356 | CPU_ZERO(&cpu_set); |
| 359 | goto out_thread_map_delete; | ||
| 360 | |||
| 361 | cpu_set_size = CPU_ALLOC_SIZE(cpus->nr); | ||
| 362 | CPU_ZERO_S(cpu_set_size, cpu_set); | ||
| 363 | 357 | ||
| 364 | memset(&attr, 0, sizeof(attr)); | 358 | memset(&attr, 0, sizeof(attr)); |
| 365 | attr.type = PERF_TYPE_TRACEPOINT; | 359 | attr.type = PERF_TYPE_TRACEPOINT; |
| @@ -367,7 +361,7 @@ static int test__open_syscall_event_on_all_cpus(void) | |||
| 367 | evsel = perf_evsel__new(&attr, 0); | 361 | evsel = perf_evsel__new(&attr, 0); |
| 368 | if (evsel == NULL) { | 362 | if (evsel == NULL) { |
| 369 | pr_debug("perf_evsel__new\n"); | 363 | pr_debug("perf_evsel__new\n"); |
| 370 | goto out_cpu_free; | 364 | goto out_thread_map_delete; |
| 371 | } | 365 | } |
| 372 | 366 | ||
| 373 | if (perf_evsel__open(evsel, cpus, threads) < 0) { | 367 | if (perf_evsel__open(evsel, cpus, threads) < 0) { |
| @@ -379,14 +373,29 @@ static int test__open_syscall_event_on_all_cpus(void) | |||
| 379 | 373 | ||
| 380 | for (cpu = 0; cpu < cpus->nr; ++cpu) { | 374 | for (cpu = 0; cpu < cpus->nr; ++cpu) { |
| 381 | unsigned int ncalls = nr_open_calls + cpu; | 375 | unsigned int ncalls = nr_open_calls + cpu; |
| 376 | /* | ||
| 377 | * XXX eventually lift this restriction in a way that | ||
| 378 | * keeps perf building on older glibc installations | ||
| 379 | * without CPU_ALLOC. 1024 cpus in 2010 still seems | ||
| 380 | * a reasonable upper limit tho :-) | ||
| 381 | */ | ||
| 382 | if (cpus->map[cpu] >= CPU_SETSIZE) { | ||
| 383 | pr_debug("Ignoring CPU %d\n", cpus->map[cpu]); | ||
| 384 | continue; | ||
| 385 | } | ||
| 382 | 386 | ||
| 383 | CPU_SET(cpu, cpu_set); | 387 | CPU_SET(cpus->map[cpu], &cpu_set); |
| 384 | sched_setaffinity(0, cpu_set_size, cpu_set); | 388 | if (sched_setaffinity(0, sizeof(cpu_set), &cpu_set) < 0) { |
| 389 | pr_debug("sched_setaffinity() failed on CPU %d: %s ", | ||
| 390 | cpus->map[cpu], | ||
| 391 | strerror(errno)); | ||
| 392 | goto out_close_fd; | ||
| 393 | } | ||
| 385 | for (i = 0; i < ncalls; ++i) { | 394 | for (i = 0; i < ncalls; ++i) { |
| 386 | fd = open("/etc/passwd", O_RDONLY); | 395 | fd = open("/etc/passwd", O_RDONLY); |
| 387 | close(fd); | 396 | close(fd); |
| 388 | } | 397 | } |
| 389 | CPU_CLR(cpu, cpu_set); | 398 | CPU_CLR(cpus->map[cpu], &cpu_set); |
| 390 | } | 399 | } |
| 391 | 400 | ||
| 392 | /* | 401 | /* |
| @@ -402,6 +411,9 @@ static int test__open_syscall_event_on_all_cpus(void) | |||
| 402 | for (cpu = 0; cpu < cpus->nr; ++cpu) { | 411 | for (cpu = 0; cpu < cpus->nr; ++cpu) { |
| 403 | unsigned int expected; | 412 | unsigned int expected; |
| 404 | 413 | ||
| 414 | if (cpus->map[cpu] >= CPU_SETSIZE) | ||
| 415 | continue; | ||
| 416 | |||
| 405 | if (perf_evsel__read_on_cpu(evsel, cpu, 0) < 0) { | 417 | if (perf_evsel__read_on_cpu(evsel, cpu, 0) < 0) { |
| 406 | pr_debug("perf_evsel__open_read_on_cpu\n"); | 418 | pr_debug("perf_evsel__open_read_on_cpu\n"); |
| 407 | goto out_close_fd; | 419 | goto out_close_fd; |
| @@ -409,8 +421,8 @@ static int test__open_syscall_event_on_all_cpus(void) | |||
| 409 | 421 | ||
| 410 | expected = nr_open_calls + cpu; | 422 | expected = nr_open_calls + cpu; |
| 411 | if (evsel->counts->cpu[cpu].val != expected) { | 423 | if (evsel->counts->cpu[cpu].val != expected) { |
| 412 | pr_debug("perf_evsel__read_on_cpu: expected to intercept %d calls on cpu %d, got %Ld\n", | 424 | pr_debug("perf_evsel__read_on_cpu: expected to intercept %d calls on cpu %d, got %" PRIu64 "\n", |
| 413 | expected, cpu, evsel->counts->cpu[cpu].val); | 425 | expected, cpus->map[cpu], evsel->counts->cpu[cpu].val); |
| 414 | goto out_close_fd; | 426 | goto out_close_fd; |
| 415 | } | 427 | } |
| 416 | } | 428 | } |
| @@ -420,8 +432,6 @@ out_close_fd: | |||
| 420 | perf_evsel__close_fd(evsel, 1, threads->nr); | 432 | perf_evsel__close_fd(evsel, 1, threads->nr); |
| 421 | out_evsel_delete: | 433 | out_evsel_delete: |
| 422 | perf_evsel__delete(evsel); | 434 | perf_evsel__delete(evsel); |
| 423 | out_cpu_free: | ||
| 424 | CPU_FREE(cpu_set); | ||
| 425 | out_thread_map_delete: | 435 | out_thread_map_delete: |
| 426 | thread_map__delete(threads); | 436 | thread_map__delete(threads); |
| 427 | return err; | 437 | return err; |
diff --git a/tools/perf/builtin-top.c b/tools/perf/builtin-top.c index 05344c6210ac..b6998e055767 100644 --- a/tools/perf/builtin-top.c +++ b/tools/perf/builtin-top.c | |||
| @@ -40,6 +40,7 @@ | |||
| 40 | #include <stdio.h> | 40 | #include <stdio.h> |
| 41 | #include <termios.h> | 41 | #include <termios.h> |
| 42 | #include <unistd.h> | 42 | #include <unistd.h> |
| 43 | #include <inttypes.h> | ||
| 43 | 44 | ||
| 44 | #include <errno.h> | 45 | #include <errno.h> |
| 45 | #include <time.h> | 46 | #include <time.h> |
| @@ -214,7 +215,7 @@ static int parse_source(struct sym_entry *syme) | |||
| 214 | len = sym->end - sym->start; | 215 | len = sym->end - sym->start; |
| 215 | 216 | ||
| 216 | sprintf(command, | 217 | sprintf(command, |
| 217 | "objdump --start-address=%#0*Lx --stop-address=%#0*Lx -dS %s", | 218 | "objdump --start-address=%#0*" PRIx64 " --stop-address=%#0*" PRIx64 " -dS %s", |
| 218 | BITS_PER_LONG / 4, map__rip_2objdump(map, sym->start), | 219 | BITS_PER_LONG / 4, map__rip_2objdump(map, sym->start), |
| 219 | BITS_PER_LONG / 4, map__rip_2objdump(map, sym->end), path); | 220 | BITS_PER_LONG / 4, map__rip_2objdump(map, sym->end), path); |
| 220 | 221 | ||
| @@ -308,7 +309,7 @@ static void lookup_sym_source(struct sym_entry *syme) | |||
| 308 | struct source_line *line; | 309 | struct source_line *line; |
| 309 | char pattern[PATTERN_LEN + 1]; | 310 | char pattern[PATTERN_LEN + 1]; |
| 310 | 311 | ||
| 311 | sprintf(pattern, "%0*Lx <", BITS_PER_LONG / 4, | 312 | sprintf(pattern, "%0*" PRIx64 " <", BITS_PER_LONG / 4, |
| 312 | map__rip_2objdump(syme->map, symbol->start)); | 313 | map__rip_2objdump(syme->map, symbol->start)); |
| 313 | 314 | ||
| 314 | pthread_mutex_lock(&syme->src->lock); | 315 | pthread_mutex_lock(&syme->src->lock); |
| @@ -537,7 +538,7 @@ static void print_sym_table(void) | |||
| 537 | if (nr_counters == 1 || !display_weighted) { | 538 | if (nr_counters == 1 || !display_weighted) { |
| 538 | struct perf_evsel *first; | 539 | struct perf_evsel *first; |
| 539 | first = list_entry(evsel_list.next, struct perf_evsel, node); | 540 | first = list_entry(evsel_list.next, struct perf_evsel, node); |
| 540 | printf("%Ld", first->attr.sample_period); | 541 | printf("%" PRIu64, (uint64_t)first->attr.sample_period); |
| 541 | if (freq) | 542 | if (freq) |
| 542 | printf("Hz "); | 543 | printf("Hz "); |
| 543 | else | 544 | else |
| @@ -640,7 +641,7 @@ static void print_sym_table(void) | |||
| 640 | 641 | ||
| 641 | percent_color_fprintf(stdout, "%4.1f%%", pcnt); | 642 | percent_color_fprintf(stdout, "%4.1f%%", pcnt); |
| 642 | if (verbose) | 643 | if (verbose) |
| 643 | printf(" %016llx", sym->start); | 644 | printf(" %016" PRIx64, sym->start); |
| 644 | printf(" %-*.*s", sym_width, sym_width, sym->name); | 645 | printf(" %-*.*s", sym_width, sym_width, sym->name); |
| 645 | printf(" %-*.*s\n", dso_width, dso_width, | 646 | printf(" %-*.*s\n", dso_width, dso_width, |
| 646 | dso_width >= syme->map->dso->long_name_len ? | 647 | dso_width >= syme->map->dso->long_name_len ? |
diff --git a/tools/perf/util/event.c b/tools/perf/util/event.c index 2302ec051bb4..1478ab4ee222 100644 --- a/tools/perf/util/event.c +++ b/tools/perf/util/event.c | |||
| @@ -459,7 +459,8 @@ int event__process_comm(event_t *self, struct sample_data *sample __used, | |||
| 459 | int event__process_lost(event_t *self, struct sample_data *sample __used, | 459 | int event__process_lost(event_t *self, struct sample_data *sample __used, |
| 460 | struct perf_session *session) | 460 | struct perf_session *session) |
| 461 | { | 461 | { |
| 462 | dump_printf(": id:%Ld: lost:%Ld\n", self->lost.id, self->lost.lost); | 462 | dump_printf(": id:%" PRIu64 ": lost:%" PRIu64 "\n", |
| 463 | self->lost.id, self->lost.lost); | ||
| 463 | session->hists.stats.total_lost += self->lost.lost; | 464 | session->hists.stats.total_lost += self->lost.lost; |
| 464 | return 0; | 465 | return 0; |
| 465 | } | 466 | } |
| @@ -575,7 +576,7 @@ int event__process_mmap(event_t *self, struct sample_data *sample __used, | |||
| 575 | u8 cpumode = self->header.misc & PERF_RECORD_MISC_CPUMODE_MASK; | 576 | u8 cpumode = self->header.misc & PERF_RECORD_MISC_CPUMODE_MASK; |
| 576 | int ret = 0; | 577 | int ret = 0; |
| 577 | 578 | ||
| 578 | dump_printf(" %d/%d: [%#Lx(%#Lx) @ %#Lx]: %s\n", | 579 | dump_printf(" %d/%d: [%#" PRIx64 "(%#" PRIx64 ") @ %#" PRIx64 "]: %s\n", |
| 579 | self->mmap.pid, self->mmap.tid, self->mmap.start, | 580 | self->mmap.pid, self->mmap.tid, self->mmap.start, |
| 580 | self->mmap.len, self->mmap.pgoff, self->mmap.filename); | 581 | self->mmap.len, self->mmap.pgoff, self->mmap.filename); |
| 581 | 582 | ||
diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c index 989fa2dee2fd..f6a929e74981 100644 --- a/tools/perf/util/header.c +++ b/tools/perf/util/header.c | |||
| @@ -798,8 +798,8 @@ static int perf_file_section__process(struct perf_file_section *self, | |||
| 798 | int feat, int fd) | 798 | int feat, int fd) |
| 799 | { | 799 | { |
| 800 | if (lseek(fd, self->offset, SEEK_SET) == (off_t)-1) { | 800 | if (lseek(fd, self->offset, SEEK_SET) == (off_t)-1) { |
| 801 | pr_debug("Failed to lseek to %Ld offset for feature %d, " | 801 | pr_debug("Failed to lseek to %" PRIu64 " offset for feature " |
| 802 | "continuing...\n", self->offset, feat); | 802 | "%d, continuing...\n", self->offset, feat); |
| 803 | return 0; | 803 | return 0; |
| 804 | } | 804 | } |
| 805 | 805 | ||
diff --git a/tools/perf/util/hist.c b/tools/perf/util/hist.c index c749ba6136a0..32f4f1f2f6e4 100644 --- a/tools/perf/util/hist.c +++ b/tools/perf/util/hist.c | |||
| @@ -636,13 +636,13 @@ int hist_entry__snprintf(struct hist_entry *self, char *s, size_t size, | |||
| 636 | } | 636 | } |
| 637 | } | 637 | } |
| 638 | } else | 638 | } else |
| 639 | ret = snprintf(s, size, sep ? "%lld" : "%12lld ", period); | 639 | ret = snprintf(s, size, sep ? "%" PRIu64 : "%12" PRIu64 " ", period); |
| 640 | 640 | ||
| 641 | if (symbol_conf.show_nr_samples) { | 641 | if (symbol_conf.show_nr_samples) { |
| 642 | if (sep) | 642 | if (sep) |
| 643 | ret += snprintf(s + ret, size - ret, "%c%lld", *sep, period); | 643 | ret += snprintf(s + ret, size - ret, "%c%" PRIu64, *sep, period); |
| 644 | else | 644 | else |
| 645 | ret += snprintf(s + ret, size - ret, "%11lld", period); | 645 | ret += snprintf(s + ret, size - ret, "%11" PRIu64, period); |
| 646 | } | 646 | } |
| 647 | 647 | ||
| 648 | if (pair_hists) { | 648 | if (pair_hists) { |
| @@ -971,7 +971,7 @@ int hist_entry__inc_addr_samples(struct hist_entry *self, u64 ip) | |||
| 971 | sym_size = sym->end - sym->start; | 971 | sym_size = sym->end - sym->start; |
| 972 | offset = ip - sym->start; | 972 | offset = ip - sym->start; |
| 973 | 973 | ||
| 974 | pr_debug3("%s: ip=%#Lx\n", __func__, self->ms.map->unmap_ip(self->ms.map, ip)); | 974 | pr_debug3("%s: ip=%#" PRIx64 "\n", __func__, self->ms.map->unmap_ip(self->ms.map, ip)); |
| 975 | 975 | ||
| 976 | if (offset >= sym_size) | 976 | if (offset >= sym_size) |
| 977 | return 0; | 977 | return 0; |
| @@ -980,8 +980,9 @@ int hist_entry__inc_addr_samples(struct hist_entry *self, u64 ip) | |||
| 980 | h->sum++; | 980 | h->sum++; |
| 981 | h->ip[offset]++; | 981 | h->ip[offset]++; |
| 982 | 982 | ||
| 983 | pr_debug3("%#Lx %s: period++ [ip: %#Lx, %#Lx] => %Ld\n", self->ms.sym->start, | 983 | pr_debug3("%#" PRIx64 " %s: period++ [ip: %#" PRIx64 ", %#" PRIx64 |
| 984 | self->ms.sym->name, ip, ip - self->ms.sym->start, h->ip[offset]); | 984 | "] => %" PRIu64 "\n", self->ms.sym->start, self->ms.sym->name, |
| 985 | ip, ip - self->ms.sym->start, h->ip[offset]); | ||
| 985 | return 0; | 986 | return 0; |
| 986 | } | 987 | } |
| 987 | 988 | ||
| @@ -1132,7 +1133,7 @@ fallback: | |||
| 1132 | goto out_free_filename; | 1133 | goto out_free_filename; |
| 1133 | } | 1134 | } |
| 1134 | 1135 | ||
| 1135 | pr_debug("%s: filename=%s, sym=%s, start=%#Lx, end=%#Lx\n", __func__, | 1136 | pr_debug("%s: filename=%s, sym=%s, start=%#" PRIx64 ", end=%#" PRIx64 "\n", __func__, |
| 1136 | filename, sym->name, map->unmap_ip(map, sym->start), | 1137 | filename, sym->name, map->unmap_ip(map, sym->start), |
| 1137 | map->unmap_ip(map, sym->end)); | 1138 | map->unmap_ip(map, sym->end)); |
| 1138 | 1139 | ||
| @@ -1142,7 +1143,7 @@ fallback: | |||
| 1142 | dso, dso->long_name, sym, sym->name); | 1143 | dso, dso->long_name, sym, sym->name); |
| 1143 | 1144 | ||
| 1144 | snprintf(command, sizeof(command), | 1145 | snprintf(command, sizeof(command), |
| 1145 | "objdump --start-address=0x%016Lx --stop-address=0x%016Lx -dS -C %s|grep -v %s|expand", | 1146 | "objdump --start-address=0x%016" PRIx64 " --stop-address=0x%016" PRIx64 " -dS -C %s|grep -v %s|expand", |
| 1146 | map__rip_2objdump(map, sym->start), | 1147 | map__rip_2objdump(map, sym->start), |
| 1147 | map__rip_2objdump(map, sym->end), | 1148 | map__rip_2objdump(map, sym->end), |
| 1148 | symfs_filename, filename); | 1149 | symfs_filename, filename); |
diff --git a/tools/perf/util/include/linux/bitops.h b/tools/perf/util/include/linux/bitops.h index 8be0b968ca0b..305c8484f200 100644 --- a/tools/perf/util/include/linux/bitops.h +++ b/tools/perf/util/include/linux/bitops.h | |||
| @@ -2,6 +2,7 @@ | |||
| 2 | #define _PERF_LINUX_BITOPS_H_ | 2 | #define _PERF_LINUX_BITOPS_H_ |
| 3 | 3 | ||
| 4 | #include <linux/kernel.h> | 4 | #include <linux/kernel.h> |
| 5 | #include <linux/compiler.h> | ||
| 5 | #include <asm/hweight.h> | 6 | #include <asm/hweight.h> |
| 6 | 7 | ||
| 7 | #define BITS_PER_LONG __WORDSIZE | 8 | #define BITS_PER_LONG __WORDSIZE |
diff --git a/tools/perf/util/map.c b/tools/perf/util/map.c index 3a7eb6ec0eec..a16ecab5229d 100644 --- a/tools/perf/util/map.c +++ b/tools/perf/util/map.c | |||
| @@ -1,5 +1,6 @@ | |||
| 1 | #include "symbol.h" | 1 | #include "symbol.h" |
| 2 | #include <errno.h> | 2 | #include <errno.h> |
| 3 | #include <inttypes.h> | ||
| 3 | #include <limits.h> | 4 | #include <limits.h> |
| 4 | #include <stdlib.h> | 5 | #include <stdlib.h> |
| 5 | #include <string.h> | 6 | #include <string.h> |
| @@ -195,7 +196,7 @@ int map__overlap(struct map *l, struct map *r) | |||
| 195 | 196 | ||
| 196 | size_t map__fprintf(struct map *self, FILE *fp) | 197 | size_t map__fprintf(struct map *self, FILE *fp) |
| 197 | { | 198 | { |
| 198 | return fprintf(fp, " %Lx-%Lx %Lx %s\n", | 199 | return fprintf(fp, " %" PRIx64 "-%" PRIx64 " %" PRIx64 " %s\n", |
| 199 | self->start, self->end, self->pgoff, self->dso->name); | 200 | self->start, self->end, self->pgoff, self->dso->name); |
| 200 | } | 201 | } |
| 201 | 202 | ||
diff --git a/tools/perf/util/parse-events.c b/tools/perf/util/parse-events.c index bc2732ee23eb..135f69baf966 100644 --- a/tools/perf/util/parse-events.c +++ b/tools/perf/util/parse-events.c | |||
| @@ -279,7 +279,7 @@ const char *__event_name(int type, u64 config) | |||
| 279 | static char buf[32]; | 279 | static char buf[32]; |
| 280 | 280 | ||
| 281 | if (type == PERF_TYPE_RAW) { | 281 | if (type == PERF_TYPE_RAW) { |
| 282 | sprintf(buf, "raw 0x%llx", config); | 282 | sprintf(buf, "raw 0x%" PRIx64, config); |
| 283 | return buf; | 283 | return buf; |
| 284 | } | 284 | } |
| 285 | 285 | ||
diff --git a/tools/perf/util/parse-events.h b/tools/perf/util/parse-events.h index b82cafb83772..458e3ecf17af 100644 --- a/tools/perf/util/parse-events.h +++ b/tools/perf/util/parse-events.h | |||
| @@ -23,7 +23,7 @@ struct tracepoint_path { | |||
| 23 | }; | 23 | }; |
| 24 | 24 | ||
| 25 | extern struct tracepoint_path *tracepoint_id_to_path(u64 config); | 25 | extern struct tracepoint_path *tracepoint_id_to_path(u64 config); |
| 26 | extern bool have_tracepoints(struct list_head *evsel_list); | 26 | extern bool have_tracepoints(struct list_head *evlist); |
| 27 | 27 | ||
| 28 | extern int nr_counters; | 28 | extern int nr_counters; |
| 29 | 29 | ||
diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c index 128aaab0aeda..6e29d9c9dccc 100644 --- a/tools/perf/util/probe-event.c +++ b/tools/perf/util/probe-event.c | |||
| @@ -172,7 +172,7 @@ static int kprobe_convert_to_perf_probe(struct probe_trace_point *tp, | |||
| 172 | sym = __find_kernel_function_by_name(tp->symbol, &map); | 172 | sym = __find_kernel_function_by_name(tp->symbol, &map); |
| 173 | if (sym) { | 173 | if (sym) { |
| 174 | addr = map->unmap_ip(map, sym->start + tp->offset); | 174 | addr = map->unmap_ip(map, sym->start + tp->offset); |
| 175 | pr_debug("try to find %s+%ld@%llx\n", tp->symbol, | 175 | pr_debug("try to find %s+%ld@%" PRIx64 "\n", tp->symbol, |
| 176 | tp->offset, addr); | 176 | tp->offset, addr); |
| 177 | ret = find_perf_probe_point((unsigned long)addr, pp); | 177 | ret = find_perf_probe_point((unsigned long)addr, pp); |
| 178 | } | 178 | } |
diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 313dac2d94ce..105f00bfd555 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c | |||
| @@ -652,10 +652,11 @@ static void callchain__printf(struct sample_data *sample) | |||
| 652 | { | 652 | { |
| 653 | unsigned int i; | 653 | unsigned int i; |
| 654 | 654 | ||
| 655 | printf("... chain: nr:%Lu\n", sample->callchain->nr); | 655 | printf("... chain: nr:%" PRIu64 "\n", sample->callchain->nr); |
| 656 | 656 | ||
| 657 | for (i = 0; i < sample->callchain->nr; i++) | 657 | for (i = 0; i < sample->callchain->nr; i++) |
| 658 | printf("..... %2d: %016Lx\n", i, sample->callchain->ips[i]); | 658 | printf("..... %2d: %016" PRIx64 "\n", |
| 659 | i, sample->callchain->ips[i]); | ||
| 659 | } | 660 | } |
| 660 | 661 | ||
| 661 | static void perf_session__print_tstamp(struct perf_session *session, | 662 | static void perf_session__print_tstamp(struct perf_session *session, |
| @@ -672,7 +673,7 @@ static void perf_session__print_tstamp(struct perf_session *session, | |||
| 672 | printf("%u ", sample->cpu); | 673 | printf("%u ", sample->cpu); |
| 673 | 674 | ||
| 674 | if (session->sample_type & PERF_SAMPLE_TIME) | 675 | if (session->sample_type & PERF_SAMPLE_TIME) |
| 675 | printf("%Lu ", sample->time); | 676 | printf("%" PRIu64 " ", sample->time); |
| 676 | } | 677 | } |
| 677 | 678 | ||
| 678 | static void dump_event(struct perf_session *session, event_t *event, | 679 | static void dump_event(struct perf_session *session, event_t *event, |
| @@ -681,16 +682,16 @@ static void dump_event(struct perf_session *session, event_t *event, | |||
| 681 | if (!dump_trace) | 682 | if (!dump_trace) |
| 682 | return; | 683 | return; |
| 683 | 684 | ||
| 684 | printf("\n%#Lx [%#x]: event: %d\n", file_offset, event->header.size, | 685 | printf("\n%#" PRIx64 " [%#x]: event: %d\n", |
| 685 | event->header.type); | 686 | file_offset, event->header.size, event->header.type); |
| 686 | 687 | ||
| 687 | trace_event(event); | 688 | trace_event(event); |
| 688 | 689 | ||
| 689 | if (sample) | 690 | if (sample) |
| 690 | perf_session__print_tstamp(session, event, sample); | 691 | perf_session__print_tstamp(session, event, sample); |
| 691 | 692 | ||
| 692 | printf("%#Lx [%#x]: PERF_RECORD_%s", file_offset, event->header.size, | 693 | printf("%#" PRIx64 " [%#x]: PERF_RECORD_%s", file_offset, |
| 693 | event__get_event_name(event->header.type)); | 694 | event->header.size, event__get_event_name(event->header.type)); |
| 694 | } | 695 | } |
| 695 | 696 | ||
| 696 | static void dump_sample(struct perf_session *session, event_t *event, | 697 | static void dump_sample(struct perf_session *session, event_t *event, |
| @@ -699,8 +700,9 @@ static void dump_sample(struct perf_session *session, event_t *event, | |||
| 699 | if (!dump_trace) | 700 | if (!dump_trace) |
| 700 | return; | 701 | return; |
| 701 | 702 | ||
| 702 | printf("(IP, %d): %d/%d: %#Lx period: %Ld\n", event->header.misc, | 703 | printf("(IP, %d): %d/%d: %#" PRIx64 " period: %" PRIu64 "\n", |
| 703 | sample->pid, sample->tid, sample->ip, sample->period); | 704 | event->header.misc, sample->pid, sample->tid, sample->ip, |
| 705 | sample->period); | ||
| 704 | 706 | ||
| 705 | if (session->sample_type & PERF_SAMPLE_CALLCHAIN) | 707 | if (session->sample_type & PERF_SAMPLE_CALLCHAIN) |
| 706 | callchain__printf(sample); | 708 | callchain__printf(sample); |
| @@ -843,8 +845,8 @@ static void perf_session__warn_about_errors(const struct perf_session *session, | |||
| 843 | { | 845 | { |
| 844 | if (ops->lost == event__process_lost && | 846 | if (ops->lost == event__process_lost && |
| 845 | session->hists.stats.total_lost != 0) { | 847 | session->hists.stats.total_lost != 0) { |
| 846 | ui__warning("Processed %Lu events and LOST %Lu!\n\n" | 848 | ui__warning("Processed %" PRIu64 " events and LOST %" PRIu64 |
| 847 | "Check IO/CPU overload!\n\n", | 849 | "!\n\nCheck IO/CPU overload!\n\n", |
| 848 | session->hists.stats.total_period, | 850 | session->hists.stats.total_period, |
| 849 | session->hists.stats.total_lost); | 851 | session->hists.stats.total_lost); |
| 850 | } | 852 | } |
| @@ -918,7 +920,7 @@ more: | |||
| 918 | 920 | ||
| 919 | if (size == 0 || | 921 | if (size == 0 || |
| 920 | (skip = perf_session__process_event(self, &event, ops, head)) < 0) { | 922 | (skip = perf_session__process_event(self, &event, ops, head)) < 0) { |
| 921 | dump_printf("%#Lx [%#x]: skipping unknown header type: %d\n", | 923 | dump_printf("%#" PRIx64 " [%#x]: skipping unknown header type: %d\n", |
| 922 | head, event.header.size, event.header.type); | 924 | head, event.header.size, event.header.type); |
| 923 | /* | 925 | /* |
| 924 | * assume we lost track of the stream, check alignment, and | 926 | * assume we lost track of the stream, check alignment, and |
| @@ -1023,7 +1025,7 @@ more: | |||
| 1023 | 1025 | ||
| 1024 | if (size == 0 || | 1026 | if (size == 0 || |
| 1025 | perf_session__process_event(session, event, ops, file_pos) < 0) { | 1027 | perf_session__process_event(session, event, ops, file_pos) < 0) { |
| 1026 | dump_printf("%#Lx [%#x]: skipping unknown header type: %d\n", | 1028 | dump_printf("%#" PRIx64 " [%#x]: skipping unknown header type: %d\n", |
| 1027 | file_offset + head, event->header.size, | 1029 | file_offset + head, event->header.size, |
| 1028 | event->header.type); | 1030 | event->header.type); |
| 1029 | /* | 1031 | /* |
diff --git a/tools/perf/util/svghelper.c b/tools/perf/util/svghelper.c index b3637db025a2..fb737fe9be91 100644 --- a/tools/perf/util/svghelper.c +++ b/tools/perf/util/svghelper.c | |||
| @@ -12,6 +12,7 @@ | |||
| 12 | * of the License. | 12 | * of the License. |
| 13 | */ | 13 | */ |
| 14 | 14 | ||
| 15 | #include <inttypes.h> | ||
| 15 | #include <stdio.h> | 16 | #include <stdio.h> |
| 16 | #include <stdlib.h> | 17 | #include <stdlib.h> |
| 17 | #include <unistd.h> | 18 | #include <unistd.h> |
| @@ -43,11 +44,11 @@ static double cpu2y(int cpu) | |||
| 43 | return cpu2slot(cpu) * SLOT_MULT; | 44 | return cpu2slot(cpu) * SLOT_MULT; |
| 44 | } | 45 | } |
| 45 | 46 | ||
| 46 | static double time2pixels(u64 time) | 47 | static double time2pixels(u64 __time) |
| 47 | { | 48 | { |
| 48 | double X; | 49 | double X; |
| 49 | 50 | ||
| 50 | X = 1.0 * svg_page_width * (time - first_time) / (last_time - first_time); | 51 | X = 1.0 * svg_page_width * (__time - first_time) / (last_time - first_time); |
| 51 | return X; | 52 | return X; |
| 52 | } | 53 | } |
| 53 | 54 | ||
| @@ -94,7 +95,7 @@ void open_svg(const char *filename, int cpus, int rows, u64 start, u64 end) | |||
| 94 | 95 | ||
| 95 | total_height = (1 + rows + cpu2slot(cpus)) * SLOT_MULT; | 96 | total_height = (1 + rows + cpu2slot(cpus)) * SLOT_MULT; |
| 96 | fprintf(svgfile, "<?xml version=\"1.0\" standalone=\"no\"?> \n"); | 97 | fprintf(svgfile, "<?xml version=\"1.0\" standalone=\"no\"?> \n"); |
| 97 | fprintf(svgfile, "<svg width=\"%i\" height=\"%llu\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\">\n", svg_page_width, total_height); | 98 | fprintf(svgfile, "<svg width=\"%i\" height=\"%" PRIu64 "\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\">\n", svg_page_width, total_height); |
| 98 | 99 | ||
| 99 | fprintf(svgfile, "<defs>\n <style type=\"text/css\">\n <![CDATA[\n"); | 100 | fprintf(svgfile, "<defs>\n <style type=\"text/css\">\n <![CDATA[\n"); |
| 100 | 101 | ||
| @@ -483,7 +484,7 @@ void svg_time_grid(void) | |||
| 483 | color = 128; | 484 | color = 128; |
| 484 | } | 485 | } |
| 485 | 486 | ||
| 486 | fprintf(svgfile, "<line x1=\"%4.8f\" y1=\"%4.2f\" x2=\"%4.8f\" y2=\"%llu\" style=\"stroke:rgb(%i,%i,%i);stroke-width:%1.3f\"/>\n", | 487 | fprintf(svgfile, "<line x1=\"%4.8f\" y1=\"%4.2f\" x2=\"%4.8f\" y2=\"%" PRIu64 "\" style=\"stroke:rgb(%i,%i,%i);stroke-width:%1.3f\"/>\n", |
| 487 | time2pixels(i), SLOT_MULT/2, time2pixels(i), total_height, color, color, color, thickness); | 488 | time2pixels(i), SLOT_MULT/2, time2pixels(i), total_height, color, color, color, thickness); |
| 488 | 489 | ||
| 489 | i += 10000000; | 490 | i += 10000000; |
diff --git a/tools/perf/util/symbol.c b/tools/perf/util/symbol.c index 15ccfba8cdf8..7821d0e6866f 100644 --- a/tools/perf/util/symbol.c +++ b/tools/perf/util/symbol.c | |||
| @@ -11,6 +11,7 @@ | |||
| 11 | #include <sys/param.h> | 11 | #include <sys/param.h> |
| 12 | #include <fcntl.h> | 12 | #include <fcntl.h> |
| 13 | #include <unistd.h> | 13 | #include <unistd.h> |
| 14 | #include <inttypes.h> | ||
| 14 | #include "build-id.h" | 15 | #include "build-id.h" |
| 15 | #include "debug.h" | 16 | #include "debug.h" |
| 16 | #include "symbol.h" | 17 | #include "symbol.h" |
| @@ -153,7 +154,7 @@ static struct symbol *symbol__new(u64 start, u64 len, u8 binding, | |||
| 153 | self->binding = binding; | 154 | self->binding = binding; |
| 154 | self->namelen = namelen - 1; | 155 | self->namelen = namelen - 1; |
| 155 | 156 | ||
| 156 | pr_debug4("%s: %s %#Lx-%#Lx\n", __func__, name, start, self->end); | 157 | pr_debug4("%s: %s %#" PRIx64 "-%#" PRIx64 "\n", __func__, name, start, self->end); |
| 157 | 158 | ||
| 158 | memcpy(self->name, name, namelen); | 159 | memcpy(self->name, name, namelen); |
| 159 | 160 | ||
| @@ -167,7 +168,7 @@ void symbol__delete(struct symbol *self) | |||
| 167 | 168 | ||
| 168 | static size_t symbol__fprintf(struct symbol *self, FILE *fp) | 169 | static size_t symbol__fprintf(struct symbol *self, FILE *fp) |
| 169 | { | 170 | { |
| 170 | return fprintf(fp, " %llx-%llx %c %s\n", | 171 | return fprintf(fp, " %" PRIx64 "-%" PRIx64 " %c %s\n", |
| 171 | self->start, self->end, | 172 | self->start, self->end, |
| 172 | self->binding == STB_GLOBAL ? 'g' : | 173 | self->binding == STB_GLOBAL ? 'g' : |
| 173 | self->binding == STB_LOCAL ? 'l' : 'w', | 174 | self->binding == STB_LOCAL ? 'l' : 'w', |
| @@ -1161,6 +1162,13 @@ static int dso__load_sym(struct dso *self, struct map *map, const char *name, | |||
| 1161 | 1162 | ||
| 1162 | section_name = elf_sec__name(&shdr, secstrs); | 1163 | section_name = elf_sec__name(&shdr, secstrs); |
| 1163 | 1164 | ||
| 1165 | /* On ARM, symbols for thumb functions have 1 added to | ||
| 1166 | * the symbol address as a flag - remove it */ | ||
| 1167 | if ((ehdr.e_machine == EM_ARM) && | ||
| 1168 | (map->type == MAP__FUNCTION) && | ||
| 1169 | (sym.st_value & 1)) | ||
| 1170 | --sym.st_value; | ||
| 1171 | |||
| 1164 | if (self->kernel != DSO_TYPE_USER || kmodule) { | 1172 | if (self->kernel != DSO_TYPE_USER || kmodule) { |
| 1165 | char dso_name[PATH_MAX]; | 1173 | char dso_name[PATH_MAX]; |
| 1166 | 1174 | ||
| @@ -1208,8 +1216,8 @@ static int dso__load_sym(struct dso *self, struct map *map, const char *name, | |||
| 1208 | } | 1216 | } |
| 1209 | 1217 | ||
| 1210 | if (curr_dso->adjust_symbols) { | 1218 | if (curr_dso->adjust_symbols) { |
| 1211 | pr_debug4("%s: adjusting symbol: st_value: %#Lx " | 1219 | pr_debug4("%s: adjusting symbol: st_value: %#" PRIx64 " " |
| 1212 | "sh_addr: %#Lx sh_offset: %#Lx\n", __func__, | 1220 | "sh_addr: %#" PRIx64 " sh_offset: %#" PRIx64 "\n", __func__, |
| 1213 | (u64)sym.st_value, (u64)shdr.sh_addr, | 1221 | (u64)sym.st_value, (u64)shdr.sh_addr, |
| 1214 | (u64)shdr.sh_offset); | 1222 | (u64)shdr.sh_offset); |
| 1215 | sym.st_value -= shdr.sh_addr - shdr.sh_offset; | 1223 | sym.st_value -= shdr.sh_addr - shdr.sh_offset; |
diff --git a/tools/perf/util/types.h b/tools/perf/util/types.h index 7d6b8331f898..5f3689a3d085 100644 --- a/tools/perf/util/types.h +++ b/tools/perf/util/types.h | |||
| @@ -1,12 +1,14 @@ | |||
| 1 | #ifndef __PERF_TYPES_H | 1 | #ifndef __PERF_TYPES_H |
| 2 | #define __PERF_TYPES_H | 2 | #define __PERF_TYPES_H |
| 3 | 3 | ||
| 4 | #include <stdint.h> | ||
| 5 | |||
| 4 | /* | 6 | /* |
| 5 | * We define u64 as unsigned long long for every architecture | 7 | * We define u64 as uint64_t for every architecture |
| 6 | * so that we can print it with %Lx without getting warnings. | 8 | * so that we can print it with "%"PRIx64 without getting warnings. |
| 7 | */ | 9 | */ |
| 8 | typedef unsigned long long u64; | 10 | typedef uint64_t u64; |
| 9 | typedef signed long long s64; | 11 | typedef int64_t s64; |
| 10 | typedef unsigned int u32; | 12 | typedef unsigned int u32; |
| 11 | typedef signed int s32; | 13 | typedef signed int s32; |
| 12 | typedef unsigned short u16; | 14 | typedef unsigned short u16; |
diff --git a/tools/perf/util/ui/browsers/hists.c b/tools/perf/util/ui/browsers/hists.c index ebda8c3fde9e..60c463c16028 100644 --- a/tools/perf/util/ui/browsers/hists.c +++ b/tools/perf/util/ui/browsers/hists.c | |||
| @@ -350,7 +350,7 @@ static char *callchain_list__sym_name(struct callchain_list *self, | |||
| 350 | if (self->ms.sym) | 350 | if (self->ms.sym) |
| 351 | return self->ms.sym->name; | 351 | return self->ms.sym->name; |
| 352 | 352 | ||
| 353 | snprintf(bf, bfsize, "%#Lx", self->ip); | 353 | snprintf(bf, bfsize, "%#" PRIx64, self->ip); |
| 354 | return bf; | 354 | return bf; |
| 355 | } | 355 | } |
| 356 | 356 | ||
diff --git a/tools/perf/util/ui/browsers/map.c b/tools/perf/util/ui/browsers/map.c index e35437dfa5b4..e5158369106e 100644 --- a/tools/perf/util/ui/browsers/map.c +++ b/tools/perf/util/ui/browsers/map.c | |||
| @@ -1,5 +1,6 @@ | |||
| 1 | #include "../libslang.h" | 1 | #include "../libslang.h" |
| 2 | #include <elf.h> | 2 | #include <elf.h> |
| 3 | #include <inttypes.h> | ||
| 3 | #include <sys/ttydefaults.h> | 4 | #include <sys/ttydefaults.h> |
| 4 | #include <ctype.h> | 5 | #include <ctype.h> |
| 5 | #include <string.h> | 6 | #include <string.h> |
| @@ -57,7 +58,7 @@ static void map_browser__write(struct ui_browser *self, void *nd, int row) | |||
| 57 | int width; | 58 | int width; |
| 58 | 59 | ||
| 59 | ui_browser__set_percent_color(self, 0, current_entry); | 60 | ui_browser__set_percent_color(self, 0, current_entry); |
| 60 | slsmg_printf("%*llx %*llx %c ", | 61 | slsmg_printf("%*" PRIx64 " %*" PRIx64 " %c ", |
| 61 | mb->addrlen, sym->start, mb->addrlen, sym->end, | 62 | mb->addrlen, sym->start, mb->addrlen, sym->end, |
| 62 | sym->binding == STB_GLOBAL ? 'g' : | 63 | sym->binding == STB_GLOBAL ? 'g' : |
| 63 | sym->binding == STB_LOCAL ? 'l' : 'w'); | 64 | sym->binding == STB_LOCAL ? 'l' : 'w'); |
| @@ -150,6 +151,6 @@ int map__browse(struct map *self) | |||
| 150 | ++mb.b.nr_entries; | 151 | ++mb.b.nr_entries; |
| 151 | } | 152 | } |
| 152 | 153 | ||
| 153 | mb.addrlen = snprintf(tmp, sizeof(tmp), "%llx", maxaddr); | 154 | mb.addrlen = snprintf(tmp, sizeof(tmp), "%" PRIx64, maxaddr); |
| 154 | return map_browser__run(&mb); | 155 | return map_browser__run(&mb); |
| 155 | } | 156 | } |
diff --git a/tools/perf/util/values.c b/tools/perf/util/values.c index cfa55d686e3b..bdd33470b235 100644 --- a/tools/perf/util/values.c +++ b/tools/perf/util/values.c | |||
| @@ -150,7 +150,7 @@ static void perf_read_values__display_pretty(FILE *fp, | |||
| 150 | if (width > tidwidth) | 150 | if (width > tidwidth) |
| 151 | tidwidth = width; | 151 | tidwidth = width; |
| 152 | for (j = 0; j < values->counters; j++) { | 152 | for (j = 0; j < values->counters; j++) { |
| 153 | width = snprintf(NULL, 0, "%Lu", values->value[i][j]); | 153 | width = snprintf(NULL, 0, "%" PRIu64, values->value[i][j]); |
| 154 | if (width > counterwidth[j]) | 154 | if (width > counterwidth[j]) |
| 155 | counterwidth[j] = width; | 155 | counterwidth[j] = width; |
| 156 | } | 156 | } |
| @@ -165,7 +165,7 @@ static void perf_read_values__display_pretty(FILE *fp, | |||
| 165 | fprintf(fp, " %*d %*d", pidwidth, values->pid[i], | 165 | fprintf(fp, " %*d %*d", pidwidth, values->pid[i], |
| 166 | tidwidth, values->tid[i]); | 166 | tidwidth, values->tid[i]); |
| 167 | for (j = 0; j < values->counters; j++) | 167 | for (j = 0; j < values->counters; j++) |
| 168 | fprintf(fp, " %*Lu", | 168 | fprintf(fp, " %*" PRIu64, |
| 169 | counterwidth[j], values->value[i][j]); | 169 | counterwidth[j], values->value[i][j]); |
| 170 | fprintf(fp, "\n"); | 170 | fprintf(fp, "\n"); |
| 171 | } | 171 | } |
| @@ -196,13 +196,13 @@ static void perf_read_values__display_raw(FILE *fp, | |||
| 196 | width = strlen(values->countername[j]); | 196 | width = strlen(values->countername[j]); |
| 197 | if (width > namewidth) | 197 | if (width > namewidth) |
| 198 | namewidth = width; | 198 | namewidth = width; |
| 199 | width = snprintf(NULL, 0, "%llx", values->counterrawid[j]); | 199 | width = snprintf(NULL, 0, "%" PRIx64, values->counterrawid[j]); |
| 200 | if (width > rawwidth) | 200 | if (width > rawwidth) |
| 201 | rawwidth = width; | 201 | rawwidth = width; |
| 202 | } | 202 | } |
| 203 | for (i = 0; i < values->threads; i++) { | 203 | for (i = 0; i < values->threads; i++) { |
| 204 | for (j = 0; j < values->counters; j++) { | 204 | for (j = 0; j < values->counters; j++) { |
| 205 | width = snprintf(NULL, 0, "%Lu", values->value[i][j]); | 205 | width = snprintf(NULL, 0, "%" PRIu64, values->value[i][j]); |
| 206 | if (width > countwidth) | 206 | if (width > countwidth) |
| 207 | countwidth = width; | 207 | countwidth = width; |
| 208 | } | 208 | } |
| @@ -214,7 +214,7 @@ static void perf_read_values__display_raw(FILE *fp, | |||
| 214 | countwidth, "Count"); | 214 | countwidth, "Count"); |
| 215 | for (i = 0; i < values->threads; i++) | 215 | for (i = 0; i < values->threads; i++) |
| 216 | for (j = 0; j < values->counters; j++) | 216 | for (j = 0; j < values->counters; j++) |
| 217 | fprintf(fp, " %*d %*d %*s %*llx %*Lu\n", | 217 | fprintf(fp, " %*d %*d %*s %*" PRIx64 " %*" PRIu64, |
| 218 | pidwidth, values->pid[i], | 218 | pidwidth, values->pid[i], |
| 219 | tidwidth, values->tid[i], | 219 | tidwidth, values->tid[i], |
| 220 | namewidth, values->countername[j], | 220 | namewidth, values->countername[j], |
