Path: blob/master/tools/lib/perf/Documentation/examples/sampling.c
25923 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}1617union u64_swap {18__u64 val64;19__u32 val32[2];20};2122int main(int argc, char **argv)23{24struct perf_evlist *evlist;25struct perf_evsel *evsel;26struct perf_mmap *map;27struct perf_cpu_map *cpus;28struct perf_event_attr attr = {29.type = PERF_TYPE_HARDWARE,30.config = PERF_COUNT_HW_CPU_CYCLES,31.disabled = 1,32.freq = 1,33.sample_freq = 10,34.sample_type = PERF_SAMPLE_IP|PERF_SAMPLE_TID|PERF_SAMPLE_CPU|PERF_SAMPLE_PERIOD,35};36int err = -1;37union perf_event *event;3839libperf_init(libperf_print);4041cpus = perf_cpu_map__new_online_cpus();42if (!cpus) {43fprintf(stderr, "failed to create cpus\n");44return -1;45}4647evlist = perf_evlist__new();48if (!evlist) {49fprintf(stderr, "failed to create evlist\n");50goto out_cpus;51}5253evsel = perf_evsel__new(&attr);54if (!evsel) {55fprintf(stderr, "failed to create cycles\n");56goto out_cpus;57}5859perf_evlist__add(evlist, evsel);6061perf_evlist__set_maps(evlist, cpus, NULL);6263err = perf_evlist__open(evlist);64if (err) {65fprintf(stderr, "failed to open evlist\n");66goto out_evlist;67}6869err = perf_evlist__mmap(evlist, 4);70if (err) {71fprintf(stderr, "failed to mmap evlist\n");72goto out_evlist;73}7475perf_evlist__enable(evlist);76sleep(3);77perf_evlist__disable(evlist);7879perf_evlist__for_each_mmap(evlist, map, false) {80if (perf_mmap__read_init(map) < 0)81continue;8283while ((event = perf_mmap__read_event(map)) != NULL) {84int cpu, pid, tid;85__u64 ip, period, *array;86union u64_swap u;8788array = event->sample.array;8990ip = *array;91array++;9293u.val64 = *array;94pid = u.val32[0];95tid = u.val32[1];96array++;9798u.val64 = *array;99cpu = u.val32[0];100array++;101102period = *array;103104fprintf(stdout, "cpu %3d, pid %6d, tid %6d, ip %20llx, period %20llu\n",105cpu, pid, tid, ip, period);106107perf_mmap__consume(map);108}109110perf_mmap__read_done(map);111}112113out_evlist:114perf_evlist__delete(evlist);115out_cpus:116perf_cpu_map__put(cpus);117return err;118}119120121