kmod-path.c 6.4 KB

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