bpf-script-test-relocation.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /*
  2. * bpf-script-test-relocation.c
  3. * Test BPF loader checking relocation
  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") my_table = {
  25. .type = BPF_MAP_TYPE_ARRAY,
  26. .key_size = sizeof(int),
  27. .value_size = sizeof(int),
  28. .max_entries = 1,
  29. };
  30. int this_is_a_global_val;
  31. SEC("func=sys_write")
  32. int bpf_func__sys_write(void *ctx)
  33. {
  34. int key = 0;
  35. int value = 0;
  36. /*
  37. * Incorrect relocation. Should not allow this program be
  38. * loaded into kernel.
  39. */
  40. bpf_map_update_elem(&this_is_a_global_val, &key, &value, 0);
  41. return 0;
  42. }
  43. char _license[] SEC("license") = "GPL";
  44. int _version SEC("version") = LINUX_VERSION_CODE;