dso-data.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. #include "util.h"
  2. #include <stdlib.h>
  3. #include <sys/types.h>
  4. #include <sys/stat.h>
  5. #include <fcntl.h>
  6. #include <string.h>
  7. #include "machine.h"
  8. #include "symbol.h"
  9. #include "tests.h"
  10. #define TEST_ASSERT_VAL(text, cond) \
  11. do { \
  12. if (!(cond)) { \
  13. pr_debug("FAILED %s:%d %s\n", __FILE__, __LINE__, text); \
  14. return -1; \
  15. } \
  16. } while (0)
  17. static char *test_file(int size)
  18. {
  19. static char buf_templ[] = "/tmp/test-XXXXXX";
  20. char *templ = buf_templ;
  21. int fd, i;
  22. unsigned char *buf;
  23. fd = mkstemp(templ);
  24. if (fd < 0) {
  25. perror("mkstemp failed");
  26. return NULL;
  27. }
  28. buf = malloc(size);
  29. if (!buf) {
  30. close(fd);
  31. return NULL;
  32. }
  33. for (i = 0; i < size; i++)
  34. buf[i] = (unsigned char) ((int) i % 10);
  35. if (size != write(fd, buf, size))
  36. templ = NULL;
  37. close(fd);
  38. return templ;
  39. }
  40. #define TEST_FILE_SIZE (DSO__DATA_CACHE_SIZE * 20)
  41. struct test_data_offset {
  42. off_t offset;
  43. u8 data[10];
  44. int size;
  45. };
  46. struct test_data_offset offsets[] = {
  47. /* Fill first cache page. */
  48. {
  49. .offset = 10,
  50. .data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 },
  51. .size = 10,
  52. },
  53. /* Read first cache page. */
  54. {
  55. .offset = 10,
  56. .data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 },
  57. .size = 10,
  58. },
  59. /* Fill cache boundary pages. */
  60. {
  61. .offset = DSO__DATA_CACHE_SIZE - DSO__DATA_CACHE_SIZE % 10,
  62. .data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 },
  63. .size = 10,
  64. },
  65. /* Read cache boundary pages. */
  66. {
  67. .offset = DSO__DATA_CACHE_SIZE - DSO__DATA_CACHE_SIZE % 10,
  68. .data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 },
  69. .size = 10,
  70. },
  71. /* Fill final cache page. */
  72. {
  73. .offset = TEST_FILE_SIZE - 10,
  74. .data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 },
  75. .size = 10,
  76. },
  77. /* Read final cache page. */
  78. {
  79. .offset = TEST_FILE_SIZE - 10,
  80. .data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 },
  81. .size = 10,
  82. },
  83. /* Read final cache page. */
  84. {
  85. .offset = TEST_FILE_SIZE - 3,
  86. .data = { 7, 8, 9, 0, 0, 0, 0, 0, 0, 0 },
  87. .size = 3,
  88. },
  89. };
  90. int test__dso_data(void)
  91. {
  92. struct machine machine;
  93. struct dso *dso;
  94. char *file = test_file(TEST_FILE_SIZE);
  95. size_t i;
  96. TEST_ASSERT_VAL("No test file", file);
  97. memset(&machine, 0, sizeof(machine));
  98. dso = dso__new((const char *)file);
  99. /* Basic 10 bytes tests. */
  100. for (i = 0; i < ARRAY_SIZE(offsets); i++) {
  101. struct test_data_offset *data = &offsets[i];
  102. ssize_t size;
  103. u8 buf[10];
  104. memset(buf, 0, 10);
  105. size = dso__data_read_offset(dso, &machine, data->offset,
  106. buf, 10);
  107. TEST_ASSERT_VAL("Wrong size", size == data->size);
  108. TEST_ASSERT_VAL("Wrong data", !memcmp(buf, data->data, 10));
  109. }
  110. /* Read cross multiple cache pages. */
  111. {
  112. ssize_t size;
  113. int c;
  114. u8 *buf;
  115. buf = malloc(TEST_FILE_SIZE);
  116. TEST_ASSERT_VAL("ENOMEM\n", buf);
  117. /* First iteration to fill caches, second one to read them. */
  118. for (c = 0; c < 2; c++) {
  119. memset(buf, 0, TEST_FILE_SIZE);
  120. size = dso__data_read_offset(dso, &machine, 10,
  121. buf, TEST_FILE_SIZE);
  122. TEST_ASSERT_VAL("Wrong size",
  123. size == (TEST_FILE_SIZE - 10));
  124. for (i = 0; i < (size_t)size; i++)
  125. TEST_ASSERT_VAL("Wrong data",
  126. buf[i] == (i % 10));
  127. }
  128. free(buf);
  129. }
  130. dso__delete(dso);
  131. unlink(file);
  132. return 0;
  133. }