Path: blob/master/tools/lib/perf/Documentation/examples/counting.c
26302 views
#include <linux/perf_event.h>1#include <perf/evlist.h>2#include <perf/evsel.h>3#include <perf/cpumap.h>4#include <perf/threadmap.h>5#include <perf/mmap.h>6#include <perf/core.h>7#include <perf/event.h>8#include <stdio.h>9#include <unistd.h>1011static int libperf_print(enum libperf_print_level level,12const char *fmt, va_list ap)13{14return vfprintf(stderr, fmt, ap);15}1617int main(int argc, char **argv)18{19int count = 100000, err = 0;20struct perf_evlist *evlist;21struct perf_evsel *evsel;22struct perf_thread_map *threads;23struct perf_counts_values counts;2425struct perf_event_attr attr1 = {26.type = PERF_TYPE_SOFTWARE,27.config = PERF_COUNT_SW_CPU_CLOCK,28.read_format = PERF_FORMAT_TOTAL_TIME_ENABLED|PERF_FORMAT_TOTAL_TIME_RUNNING,29.disabled = 1,30};31struct perf_event_attr attr2 = {32.type = PERF_TYPE_SOFTWARE,33.config = PERF_COUNT_SW_TASK_CLOCK,34.read_format = PERF_FORMAT_TOTAL_TIME_ENABLED|PERF_FORMAT_TOTAL_TIME_RUNNING,35.disabled = 1,36};3738libperf_init(libperf_print);39threads = perf_thread_map__new_dummy();40if (!threads) {41fprintf(stderr, "failed to create threads\n");42return -1;43}44perf_thread_map__set_pid(threads, 0, 0);45evlist = perf_evlist__new();46if (!evlist) {47fprintf(stderr, "failed to create evlist\n");48goto out_threads;49}50evsel = perf_evsel__new(&attr1);51if (!evsel) {52fprintf(stderr, "failed to create evsel1\n");53goto out_evlist;54}55perf_evlist__add(evlist, evsel);56evsel = perf_evsel__new(&attr2);57if (!evsel) {58fprintf(stderr, "failed to create evsel2\n");59goto out_evlist;60}61perf_evlist__add(evlist, evsel);62perf_evlist__set_maps(evlist, NULL, threads);63err = perf_evlist__open(evlist);64if (err) {65fprintf(stderr, "failed to open evsel\n");66goto out_evlist;67}68perf_evlist__enable(evlist);69while (count--);70perf_evlist__disable(evlist);71perf_evlist__for_each_evsel(evlist, evsel) {72perf_evsel__read(evsel, 0, 0, &counts);73fprintf(stdout, "count %llu, enabled %llu, run %llu\n",74counts.val, counts.ena, counts.run);75}76perf_evlist__close(evlist);77out_evlist:78perf_evlist__delete(evlist);79out_threads:80perf_thread_map__put(threads);81return err;82}838485