bpf-script-example.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. * bpf-script-example.c
  3. * Test basic LLVM building
  4. */
  5. #ifndef LINUX_VERSION_CODE
  6. # error Need LINUX_VERSION_CODE
  7. # error Example: for 4.2 kernel, put 'clang-opt="-DLINUX_VERSION_CODE=0x40200" into llvm section of ~/.perfconfig'
  8. #endif
  9. #define BPF_ANY 0
  10. #define BPF_MAP_TYPE_ARRAY 2
  11. #define BPF_FUNC_map_lookup_elem 1
  12. #define BPF_FUNC_map_update_elem 2
  13. static void *(*bpf_map_lookup_elem)(void *map, void *key) =
  14. (void *) BPF_FUNC_map_lookup_elem;
  15. static void *(*bpf_map_update_elem)(void *map, void *key, void *value, int flags) =
  16. (void *) BPF_FUNC_map_update_elem;
  17. struct bpf_map_def {
  18. unsigned int type;
  19. unsigned int key_size;
  20. unsigned int value_size;
  21. unsigned int max_entries;
  22. };
  23. #define SEC(NAME) __attribute__((section(NAME), used))
  24. struct bpf_map_def SEC("maps") flip_table = {
  25. .type = BPF_MAP_TYPE_ARRAY,
  26. .key_size = sizeof(int),
  27. .value_size = sizeof(int),
  28. .max_entries = 1,
  29. };
  30. SEC("func=sys_epoll_pwait")
  31. int bpf_func__sys_epoll_pwait(void *ctx)
  32. {
  33. int ind =0;
  34. int *flag = bpf_map_lookup_elem(&flip_table, &ind);
  35. int new_flag;
  36. if (!flag)
  37. return 0;
  38. /* flip flag and store back */
  39. new_flag = !*flag;
  40. bpf_map_update_elem(&flip_table, &ind, &new_flag, BPF_ANY);
  41. return new_flag;
  42. }
  43. char _license[] SEC("license") = "GPL";
  44. int _version SEC("version") = LINUX_VERSION_CODE;