kmod-path.c 6.6 KB

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