evsel-tp-sched.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. // SPDX-License-Identifier: GPL-2.0
  2. #include <linux/err.h>
  3. #include <event-parse.h>
  4. #include "evsel.h"
  5. #include "tests.h"
  6. #include "debug.h"
  7. static int evsel__test_field(struct evsel *evsel, const char *name, int size, bool should_be_signed)
  8. {
  9. struct tep_format_field *field = evsel__field(evsel, name);
  10. int is_signed;
  11. int ret = 0;
  12. if (field == NULL) {
  13. pr_debug("%s: \"%s\" field not found!\n", evsel->name, name);
  14. return -1;
  15. }
  16. is_signed = !!(field->flags & TEP_FIELD_IS_SIGNED);
  17. if (should_be_signed && !is_signed) {
  18. pr_debug("%s: \"%s\" signedness(%d) is wrong, should be %d\n",
  19. evsel->name, name, is_signed, should_be_signed);
  20. ret = -1;
  21. }
  22. if (field->size != size) {
  23. pr_debug("%s: \"%s\" size (%d) should be %d!\n",
  24. evsel->name, name, field->size, size);
  25. ret = -1;
  26. }
  27. return ret;
  28. }
  29. static int test__perf_evsel__tp_sched_test(struct test_suite *test __maybe_unused,
  30. int subtest __maybe_unused)
  31. {
  32. struct evsel *evsel = evsel__newtp("sched", "sched_switch");
  33. int ret = TEST_OK;
  34. if (IS_ERR(evsel)) {
  35. pr_debug("evsel__newtp failed with %ld\n", PTR_ERR(evsel));
  36. return PTR_ERR(evsel) == -EACCES ? TEST_SKIP : TEST_FAIL;
  37. }
  38. if (evsel__test_field(evsel, "prev_comm", 16, false))
  39. ret = TEST_FAIL;
  40. if (evsel__test_field(evsel, "prev_pid", 4, true))
  41. ret = TEST_FAIL;
  42. if (evsel__test_field(evsel, "prev_prio", 4, true))
  43. ret = TEST_FAIL;
  44. if (evsel__test_field(evsel, "prev_state", sizeof(long), true))
  45. ret = TEST_FAIL;
  46. if (evsel__test_field(evsel, "next_comm", 16, false))
  47. ret = TEST_FAIL;
  48. if (evsel__test_field(evsel, "next_pid", 4, true))
  49. ret = TEST_FAIL;
  50. if (evsel__test_field(evsel, "next_prio", 4, true))
  51. ret = TEST_FAIL;
  52. evsel__delete(evsel);
  53. evsel = evsel__newtp("sched", "sched_wakeup");
  54. if (IS_ERR(evsel)) {
  55. pr_debug("evsel__newtp failed with %ld\n", PTR_ERR(evsel));
  56. return TEST_FAIL;
  57. }
  58. if (evsel__test_field(evsel, "comm", 16, false))
  59. ret = TEST_FAIL;
  60. if (evsel__test_field(evsel, "pid", 4, true))
  61. ret = TEST_FAIL;
  62. if (evsel__test_field(evsel, "prio", 4, true))
  63. ret = TEST_FAIL;
  64. if (evsel__test_field(evsel, "target_cpu", 4, true))
  65. ret = TEST_FAIL;
  66. evsel__delete(evsel);
  67. return ret;
  68. }
  69. static struct test_case tests__perf_evsel__tp_sched_test[] = {
  70. TEST_CASE_REASON("Parse sched tracepoints fields",
  71. perf_evsel__tp_sched_test,
  72. "permissions"),
  73. { .name = NULL, }
  74. };
  75. struct test_suite suite__perf_evsel__tp_sched_test = {
  76. .desc = "Parse sched tracepoints fields",
  77. .test_cases = tests__perf_evsel__tp_sched_test,
  78. };