longest_symbol_kunit.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Test the longest symbol length. Execute with:
  4. * ./tools/testing/kunit/kunit.py run longest-symbol
  5. * --arch=x86_64 --kconfig_add CONFIG_KPROBES=y --kconfig_add CONFIG_MODULES=y
  6. * --kconfig_add CONFIG_CPU_MITIGATIONS=n --kconfig_add CONFIG_GCOV_KERNEL=n
  7. */
  8. #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  9. #include <kunit/test.h>
  10. #include <linux/stringify.h>
  11. #include <linux/kprobes.h>
  12. #include <linux/kallsyms.h>
  13. #define DI(name) s##name##name
  14. #define DDI(name) DI(n##name##name)
  15. #define DDDI(name) DDI(n##name##name)
  16. #define DDDDI(name) DDDI(n##name##name)
  17. #define DDDDDI(name) DDDDI(n##name##name)
  18. /*Generate a symbol whose name length is 511 */
  19. #define LONGEST_SYM_NAME DDDDDI(g1h2i3j4k5l6m7n)
  20. #define RETURN_LONGEST_SYM 0xAAAAA
  21. noinline int LONGEST_SYM_NAME(void);
  22. noinline int LONGEST_SYM_NAME(void)
  23. {
  24. return RETURN_LONGEST_SYM;
  25. }
  26. _Static_assert(sizeof(__stringify(LONGEST_SYM_NAME)) == KSYM_NAME_LEN,
  27. "Incorrect symbol length found. Expected KSYM_NAME_LEN: "
  28. __stringify(KSYM_NAME_LEN) ", but found: "
  29. __stringify(sizeof(LONGEST_SYM_NAME)));
  30. static void test_longest_symbol(struct kunit *test)
  31. {
  32. KUNIT_EXPECT_EQ(test, RETURN_LONGEST_SYM, LONGEST_SYM_NAME());
  33. };
  34. static void test_longest_symbol_kallsyms(struct kunit *test)
  35. {
  36. unsigned long (*kallsyms_lookup_name)(const char *name);
  37. static int (*longest_sym)(void);
  38. struct kprobe kp = {
  39. .symbol_name = "kallsyms_lookup_name",
  40. };
  41. if (register_kprobe(&kp) < 0) {
  42. pr_info("%s: kprobe not registered", __func__);
  43. KUNIT_FAIL(test, "test_longest_symbol kallsyms: kprobe not registered\n");
  44. return;
  45. }
  46. kunit_warn(test, "test_longest_symbol kallsyms: kprobe registered\n");
  47. kallsyms_lookup_name = (unsigned long (*)(const char *name))kp.addr;
  48. unregister_kprobe(&kp);
  49. longest_sym =
  50. (void *) kallsyms_lookup_name(__stringify(LONGEST_SYM_NAME));
  51. KUNIT_EXPECT_EQ(test, RETURN_LONGEST_SYM, longest_sym());
  52. };
  53. static struct kunit_case longest_symbol_test_cases[] = {
  54. KUNIT_CASE(test_longest_symbol),
  55. KUNIT_CASE(test_longest_symbol_kallsyms),
  56. {}
  57. };
  58. static struct kunit_suite longest_symbol_test_suite = {
  59. .name = "longest-symbol",
  60. .test_cases = longest_symbol_test_cases,
  61. };
  62. kunit_test_suite(longest_symbol_test_suite);
  63. MODULE_LICENSE("GPL");
  64. MODULE_DESCRIPTION("Test the longest symbol length");
  65. MODULE_AUTHOR("Sergio González Collado");