tracex6_user.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. #include <stdio.h>
  2. #include <unistd.h>
  3. #include <stdlib.h>
  4. #include <stdbool.h>
  5. #include <string.h>
  6. #include <fcntl.h>
  7. #include <poll.h>
  8. #include <sys/ioctl.h>
  9. #include <linux/perf_event.h>
  10. #include <linux/bpf.h>
  11. #include "libbpf.h"
  12. #include "bpf_load.h"
  13. #include "perf-sys.h"
  14. #define SAMPLE_PERIOD 0x7fffffffffffffffULL
  15. static void test_bpf_perf_event(void)
  16. {
  17. int nr_cpus = sysconf(_SC_NPROCESSORS_CONF);
  18. int *pmu_fd = malloc(nr_cpus * sizeof(int));
  19. int status, i;
  20. struct perf_event_attr attr_insn_pmu = {
  21. .freq = 0,
  22. .sample_period = SAMPLE_PERIOD,
  23. .inherit = 0,
  24. .type = PERF_TYPE_HARDWARE,
  25. .read_format = 0,
  26. .sample_type = 0,
  27. .config = 0,/* PMU: cycles */
  28. };
  29. for (i = 0; i < nr_cpus; i++) {
  30. pmu_fd[i] = sys_perf_event_open(&attr_insn_pmu, -1/*pid*/, i/*cpu*/, -1/*group_fd*/, 0);
  31. if (pmu_fd[i] < 0) {
  32. printf("event syscall failed\n");
  33. goto exit;
  34. }
  35. bpf_map_update_elem(map_fd[0], &i, &pmu_fd[i], BPF_ANY);
  36. ioctl(pmu_fd[i], PERF_EVENT_IOC_ENABLE, 0);
  37. }
  38. status = system("ls > /dev/null");
  39. if (status)
  40. goto exit;
  41. status = system("sleep 2");
  42. if (status)
  43. goto exit;
  44. exit:
  45. for (i = 0; i < nr_cpus; i++)
  46. close(pmu_fd[i]);
  47. close(map_fd[0]);
  48. free(pmu_fd);
  49. }
  50. int main(int argc, char **argv)
  51. {
  52. char filename[256];
  53. snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]);
  54. if (load_bpf_file(filename)) {
  55. printf("%s", bpf_log_buf);
  56. return 1;
  57. }
  58. test_bpf_perf_event();
  59. read_trace_pipe();
  60. return 0;
  61. }