dso-data.c 3.0 KB

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