kmod-path.c 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <stdbool.h>
  3. #include <stdlib.h>
  4. #include "tests.h"
  5. #include "dso.h"
  6. #include "debug.h"
  7. static int test(const char *path, bool alloc_name, bool alloc_ext,
  8. bool kmod, bool comp, const char *name, const char *ext)
  9. {
  10. struct kmod_path m;
  11. memset(&m, 0x0, sizeof(m));
  12. TEST_ASSERT_VAL("kmod_path__parse",
  13. !__kmod_path__parse(&m, path, alloc_name, alloc_ext));
  14. pr_debug("%s - alloc name %d, alloc ext %d, kmod %d, comp %d, name '%s', ext '%s'\n",
  15. path, alloc_name, alloc_ext, m.kmod, m.comp, m.name, m.ext);
  16. TEST_ASSERT_VAL("wrong kmod", m.kmod == kmod);
  17. TEST_ASSERT_VAL("wrong comp", m.comp == comp);
  18. if (ext)
  19. TEST_ASSERT_VAL("wrong ext", m.ext && !strcmp(ext, m.ext));
  20. else
  21. TEST_ASSERT_VAL("wrong ext", !m.ext);
  22. if (name)
  23. TEST_ASSERT_VAL("wrong name", m.name && !strcmp(name, m.name));
  24. else
  25. TEST_ASSERT_VAL("wrong name", !m.name);
  26. free(m.name);
  27. free(m.ext);
  28. return 0;
  29. }
  30. static int test_is_kernel_module(const char *path, int cpumode, bool expect)
  31. {
  32. TEST_ASSERT_VAL("is_kernel_module",
  33. (!!is_kernel_module(path, cpumode)) == (!!expect));
  34. pr_debug("%s (cpumode: %d) - is_kernel_module: %s\n",
  35. path, cpumode, expect ? "true" : "false");
  36. return 0;
  37. }
  38. #define T(path, an, ae, k, c, n, e) \
  39. TEST_ASSERT_VAL("failed", !test(path, an, ae, k, c, n, e))
  40. #define M(path, c, e) \
  41. TEST_ASSERT_VAL("failed", !test_is_kernel_module(path, c, e))
  42. int test__kmod_path__parse(struct test *t __maybe_unused, int subtest __maybe_unused)
  43. {
  44. /* path alloc_name alloc_ext kmod comp name ext */
  45. T("/xxxx/xxxx/x-x.ko", true , true , true, false, "[x_x]", NULL);
  46. T("/xxxx/xxxx/x-x.ko", false , true , true, false, NULL , NULL);
  47. T("/xxxx/xxxx/x-x.ko", true , false , true, false, "[x_x]", NULL);
  48. T("/xxxx/xxxx/x-x.ko", false , false , true, false, NULL , NULL);
  49. M("/xxxx/xxxx/x-x.ko", PERF_RECORD_MISC_CPUMODE_UNKNOWN, true);
  50. M("/xxxx/xxxx/x-x.ko", PERF_RECORD_MISC_KERNEL, true);
  51. M("/xxxx/xxxx/x-x.ko", PERF_RECORD_MISC_USER, false);
  52. #ifdef HAVE_ZLIB_SUPPORT
  53. /* path alloc_name alloc_ext kmod comp name ext */
  54. T("/xxxx/xxxx/x.ko.gz", true , true , true, true, "[x]", "gz");
  55. T("/xxxx/xxxx/x.ko.gz", false , true , true, true, NULL , "gz");
  56. T("/xxxx/xxxx/x.ko.gz", true , false , true, true, "[x]", NULL);
  57. T("/xxxx/xxxx/x.ko.gz", false , false , true, true, NULL , NULL);
  58. M("/xxxx/xxxx/x.ko.gz", PERF_RECORD_MISC_CPUMODE_UNKNOWN, true);
  59. M("/xxxx/xxxx/x.ko.gz", PERF_RECORD_MISC_KERNEL, true);
  60. M("/xxxx/xxxx/x.ko.gz", PERF_RECORD_MISC_USER, false);
  61. /* path alloc_name alloc_ext kmod comp name ext */
  62. T("/xxxx/xxxx/x.gz", true , true , false, true, "x.gz" ,"gz");
  63. T("/xxxx/xxxx/x.gz", false , true , false, true, NULL ,"gz");
  64. T("/xxxx/xxxx/x.gz", true , false , false, true, "x.gz" , NULL);
  65. T("/xxxx/xxxx/x.gz", false , false , false, true, NULL , NULL);
  66. M("/xxxx/xxxx/x.gz", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  67. M("/xxxx/xxxx/x.gz", PERF_RECORD_MISC_KERNEL, false);
  68. M("/xxxx/xxxx/x.gz", PERF_RECORD_MISC_USER, false);
  69. /* path alloc_name alloc_ext kmod comp name ext */
  70. T("x.gz", true , true , false, true, "x.gz", "gz");
  71. T("x.gz", false , true , false, true, NULL , "gz");
  72. T("x.gz", true , false , false, true, "x.gz", NULL);
  73. T("x.gz", false , false , false, true, NULL , NULL);
  74. M("x.gz", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  75. M("x.gz", PERF_RECORD_MISC_KERNEL, false);
  76. M("x.gz", PERF_RECORD_MISC_USER, false);
  77. /* path alloc_name alloc_ext kmod comp name ext */
  78. T("x.ko.gz", true , true , true, true, "[x]", "gz");
  79. T("x.ko.gz", false , true , true, true, NULL , "gz");
  80. T("x.ko.gz", true , false , true, true, "[x]", NULL);
  81. T("x.ko.gz", false , false , true, true, NULL , NULL);
  82. M("x.ko.gz", PERF_RECORD_MISC_CPUMODE_UNKNOWN, true);
  83. M("x.ko.gz", PERF_RECORD_MISC_KERNEL, true);
  84. M("x.ko.gz", PERF_RECORD_MISC_USER, false);
  85. #endif
  86. /* path alloc_name alloc_ext kmod comp name ext */
  87. T("[test_module]", true , true , true, false, "[test_module]", NULL);
  88. T("[test_module]", false , true , true, false, NULL , NULL);
  89. T("[test_module]", true , false , true, false, "[test_module]", NULL);
  90. T("[test_module]", false , false , true, false, NULL , NULL);
  91. M("[test_module]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, true);
  92. M("[test_module]", PERF_RECORD_MISC_KERNEL, true);
  93. M("[test_module]", PERF_RECORD_MISC_USER, false);
  94. /* path alloc_name alloc_ext kmod comp name ext */
  95. T("[test.module]", true , true , true, false, "[test.module]", NULL);
  96. T("[test.module]", false , true , true, false, NULL , NULL);
  97. T("[test.module]", true , false , true, false, "[test.module]", NULL);
  98. T("[test.module]", false , false , true, false, NULL , NULL);
  99. M("[test.module]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, true);
  100. M("[test.module]", PERF_RECORD_MISC_KERNEL, true);
  101. M("[test.module]", PERF_RECORD_MISC_USER, false);
  102. /* path alloc_name alloc_ext kmod comp name ext */
  103. T("[vdso]", true , true , false, false, "[vdso]", NULL);
  104. T("[vdso]", false , true , false, false, NULL , NULL);
  105. T("[vdso]", true , false , false, false, "[vdso]", NULL);
  106. T("[vdso]", false , false , false, false, NULL , NULL);
  107. M("[vdso]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  108. M("[vdso]", PERF_RECORD_MISC_KERNEL, false);
  109. M("[vdso]", PERF_RECORD_MISC_USER, false);
  110. T("[vdso32]", true , true , false, false, "[vdso32]", NULL);
  111. T("[vdso32]", false , true , false, false, NULL , NULL);
  112. T("[vdso32]", true , false , false, false, "[vdso32]", NULL);
  113. T("[vdso32]", false , false , false, false, NULL , NULL);
  114. M("[vdso32]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  115. M("[vdso32]", PERF_RECORD_MISC_KERNEL, false);
  116. M("[vdso32]", PERF_RECORD_MISC_USER, false);
  117. T("[vdsox32]", true , true , false, false, "[vdsox32]", NULL);
  118. T("[vdsox32]", false , true , false, false, NULL , NULL);
  119. T("[vdsox32]", true , false , false, false, "[vdsox32]", NULL);
  120. T("[vdsox32]", false , false , false, false, NULL , NULL);
  121. M("[vdsox32]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  122. M("[vdsox32]", PERF_RECORD_MISC_KERNEL, false);
  123. M("[vdsox32]", PERF_RECORD_MISC_USER, false);
  124. /* path alloc_name alloc_ext kmod comp name ext */
  125. T("[vsyscall]", true , true , false, false, "[vsyscall]", NULL);
  126. T("[vsyscall]", false , true , false, false, NULL , NULL);
  127. T("[vsyscall]", true , false , false, false, "[vsyscall]", NULL);
  128. T("[vsyscall]", false , false , false, false, NULL , NULL);
  129. M("[vsyscall]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  130. M("[vsyscall]", PERF_RECORD_MISC_KERNEL, false);
  131. M("[vsyscall]", PERF_RECORD_MISC_USER, false);
  132. /* path alloc_name alloc_ext kmod comp name ext */
  133. T("[kernel.kallsyms]", true , true , false, false, "[kernel.kallsyms]", NULL);
  134. T("[kernel.kallsyms]", false , true , false, false, NULL , NULL);
  135. T("[kernel.kallsyms]", true , false , false, false, "[kernel.kallsyms]", NULL);
  136. T("[kernel.kallsyms]", false , false , false, false, NULL , NULL);
  137. M("[kernel.kallsyms]", PERF_RECORD_MISC_CPUMODE_UNKNOWN, false);
  138. M("[kernel.kallsyms]", PERF_RECORD_MISC_KERNEL, false);
  139. M("[kernel.kallsyms]", PERF_RECORD_MISC_USER, false);
  140. return 0;
  141. }