blob: 3630e80ce252eb67b35556f24456a7ad43f486c6 [file] [log] [blame]
Jason Evans86abd0d2013-11-30 15:25:42 -08001#include "test/jemalloc_test.h"
Jason Evans93443682010-10-20 17:39:18 -07002
Jason Evans2a83ed02013-12-08 20:52:21 -08003static const bool config_stats =
4#ifdef JEMALLOC_STATS
5 true
6#else
7 false
8#endif
9 ;
10
Jason Evans93443682010-10-20 17:39:18 -070011void *
Jason Evans0f4f1ef2013-12-12 14:41:02 -080012thd_start(void *arg)
Jason Evans93443682010-10-20 17:39:18 -070013{
14 int err;
15 void *p;
16 uint64_t a0, a1, d0, d1;
Jason Evans9dcad2d2011-02-13 18:11:54 -080017 uint64_t *ap0, *ap1, *dp0, *dp1;
Jason Evans93443682010-10-20 17:39:18 -070018 size_t sz, usize;
19
20 sz = sizeof(a0);
Jason Evans0a5489e2012-03-01 17:19:20 -080021 if ((err = mallctl("thread.allocated", &a0, &sz, NULL, 0))) {
Jason Evans2a83ed02013-12-08 20:52:21 -080022 if (err == ENOENT)
23 goto label_ENOENT;
24 test_fail("%s(): Error in mallctl(): %s", __func__,
Jason Evans93443682010-10-20 17:39:18 -070025 strerror(err));
Jason Evans93443682010-10-20 17:39:18 -070026 }
Jason Evans9dcad2d2011-02-13 18:11:54 -080027 sz = sizeof(ap0);
Jason Evans0a5489e2012-03-01 17:19:20 -080028 if ((err = mallctl("thread.allocatedp", &ap0, &sz, NULL, 0))) {
Jason Evans2a83ed02013-12-08 20:52:21 -080029 if (err == ENOENT)
30 goto label_ENOENT;
31 test_fail("%s(): Error in mallctl(): %s", __func__,
Jason Evans9dcad2d2011-02-13 18:11:54 -080032 strerror(err));
Jason Evans9dcad2d2011-02-13 18:11:54 -080033 }
Jason Evans2a83ed02013-12-08 20:52:21 -080034 assert_u64_eq(*ap0, a0,
35 "\"thread.allocatedp\" should provide a pointer to internal "
36 "storage");
Jason Evans93443682010-10-20 17:39:18 -070037
38 sz = sizeof(d0);
Jason Evans0a5489e2012-03-01 17:19:20 -080039 if ((err = mallctl("thread.deallocated", &d0, &sz, NULL, 0))) {
Jason Evans2a83ed02013-12-08 20:52:21 -080040 if (err == ENOENT)
41 goto label_ENOENT;
42 test_fail("%s(): Error in mallctl(): %s", __func__,
Jason Evans93443682010-10-20 17:39:18 -070043 strerror(err));
Jason Evans93443682010-10-20 17:39:18 -070044 }
Jason Evans9dcad2d2011-02-13 18:11:54 -080045 sz = sizeof(dp0);
Jason Evans0a5489e2012-03-01 17:19:20 -080046 if ((err = mallctl("thread.deallocatedp", &dp0, &sz, NULL, 0))) {
Jason Evans2a83ed02013-12-08 20:52:21 -080047 if (err == ENOENT)
48 goto label_ENOENT;
49 test_fail("%s(): Error in mallctl(): %s", __func__,
Jason Evans9dcad2d2011-02-13 18:11:54 -080050 strerror(err));
Jason Evans9dcad2d2011-02-13 18:11:54 -080051 }
Jason Evans2a83ed02013-12-08 20:52:21 -080052 assert_u64_eq(*dp0, d0,
53 "\"thread.deallocatedp\" should provide a pointer to internal "
54 "storage");
Jason Evans93443682010-10-20 17:39:18 -070055
Jason Evans0a5489e2012-03-01 17:19:20 -080056 p = malloc(1);
Jason Evans2a83ed02013-12-08 20:52:21 -080057 assert_ptr_not_null(p, "Unexpected malloc() error");
Jason Evans93443682010-10-20 17:39:18 -070058
59 sz = sizeof(a1);
Jason Evans0a5489e2012-03-01 17:19:20 -080060 mallctl("thread.allocated", &a1, &sz, NULL, 0);
Jason Evans9dcad2d2011-02-13 18:11:54 -080061 sz = sizeof(ap1);
Jason Evans0a5489e2012-03-01 17:19:20 -080062 mallctl("thread.allocatedp", &ap1, &sz, NULL, 0);
Jason Evans2a83ed02013-12-08 20:52:21 -080063 assert_u64_eq(*ap1, a1,
64 "Dereferenced \"thread.allocatedp\" value should equal "
65 "\"thread.allocated\" value");
66 assert_ptr_eq(ap0, ap1,
67 "Pointer returned by \"thread.allocatedp\" should not change");
Jason Evans93443682010-10-20 17:39:18 -070068
Jason Evans0a5489e2012-03-01 17:19:20 -080069 usize = malloc_usable_size(p);
Jason Evans2a83ed02013-12-08 20:52:21 -080070 assert_u64_le(a0 + usize, a1,
71 "Allocated memory counter should increase by at least the amount "
72 "explicitly allocated");
Jason Evans93443682010-10-20 17:39:18 -070073
Jason Evans0a5489e2012-03-01 17:19:20 -080074 free(p);
Jason Evans93443682010-10-20 17:39:18 -070075
76 sz = sizeof(d1);
Jason Evans0a5489e2012-03-01 17:19:20 -080077 mallctl("thread.deallocated", &d1, &sz, NULL, 0);
Jason Evans9dcad2d2011-02-13 18:11:54 -080078 sz = sizeof(dp1);
Jason Evans0a5489e2012-03-01 17:19:20 -080079 mallctl("thread.deallocatedp", &dp1, &sz, NULL, 0);
Jason Evans2a83ed02013-12-08 20:52:21 -080080 assert_u64_eq(*dp1, d1,
81 "Dereferenced \"thread.deallocatedp\" value should equal "
82 "\"thread.deallocated\" value");
83 assert_ptr_eq(dp0, dp1,
84 "Pointer returned by \"thread.deallocatedp\" should not change");
Jason Evans93443682010-10-20 17:39:18 -070085
Jason Evans2a83ed02013-12-08 20:52:21 -080086 assert_u64_le(d0 + usize, d1,
87 "Deallocated memory counter should increase by at least the amount "
88 "explicitly deallocated");
Jason Evans93443682010-10-20 17:39:18 -070089
Jason Evans2a83ed02013-12-08 20:52:21 -080090 return (NULL);
91label_ENOENT:
92 assert_false(config_stats,
93 "ENOENT should only be returned if stats are disabled");
94 test_skip("\"thread.allocated\" mallctl not available");
Jason Evans93443682010-10-20 17:39:18 -070095 return (NULL);
96}
97
Jason Evans2a83ed02013-12-08 20:52:21 -080098TEST_BEGIN(test_main_thread)
99{
100
Jason Evans0f4f1ef2013-12-12 14:41:02 -0800101 thd_start(NULL);
Jason Evans2a83ed02013-12-08 20:52:21 -0800102}
103TEST_END
104
105TEST_BEGIN(test_subthread)
106{
Jason Evans0f4f1ef2013-12-12 14:41:02 -0800107 thd_t thd;
Jason Evans2a83ed02013-12-08 20:52:21 -0800108
Jason Evans0f4f1ef2013-12-12 14:41:02 -0800109 thd_create(&thd, thd_start, NULL);
110 thd_join(thd, NULL);
Jason Evans2a83ed02013-12-08 20:52:21 -0800111}
112TEST_END
113
Jason Evans93443682010-10-20 17:39:18 -0700114int
115main(void)
116{
Jason Evans93443682010-10-20 17:39:18 -0700117
Jason Evans2a83ed02013-12-08 20:52:21 -0800118 /* Run tests multiple times to check for bad interactions. */
119 return (test(
120 test_main_thread,
121 test_subthread,
122 test_main_thread,
123 test_subthread,
124 test_main_thread));
Jason Evans93443682010-10-20 17:39:18 -0700125}