Fix dividing 0 error in stress/cpp/microbench
Summary: Per issue #2356, some CXX compilers may optimize away the new/delete operation in stress/cpp/microbench.cpp. Thus, this commit (1) bumps the time interval to 1 if it is 0, and (2) modifies the pointers in the microbench to volatile.
This commit is contained in:
parent
e8f9f13811
commit
a74acb57e8
@ -28,6 +28,17 @@ timer_ratio(timedelta_t *a, timedelta_t *b, char *buf, size_t buflen) {
|
|||||||
size_t i = 0;
|
size_t i = 0;
|
||||||
size_t j, n;
|
size_t j, n;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The time difference could be 0 if the two clock readings are
|
||||||
|
* identical, either due to the operations being measured in the middle
|
||||||
|
* took very little time (or even got optimized away), or the clock
|
||||||
|
* readings are bad / very coarse grained clock.
|
||||||
|
* Thus, bump t1 if it is 0 to avoid dividing 0.
|
||||||
|
*/
|
||||||
|
if (t1 == 0) {
|
||||||
|
t1 = 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* Whole. */
|
/* Whole. */
|
||||||
n = malloc_snprintf(&buf[i], buflen-i, "%"FMTu64, t0 / t1);
|
n = malloc_snprintf(&buf[i], buflen-i, "%"FMTu64, t0 / t1);
|
||||||
i += n;
|
i += n;
|
||||||
|
@ -3,45 +3,45 @@
|
|||||||
|
|
||||||
static void
|
static void
|
||||||
malloc_free(void) {
|
malloc_free(void) {
|
||||||
void *p = malloc(1);
|
void* volatile p = malloc(1);
|
||||||
expect_ptr_not_null(p, "Unexpected malloc failure");
|
expect_ptr_not_null((void *)p, "Unexpected malloc failure");
|
||||||
free(p);
|
free((void *)p);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
new_delete(void) {
|
new_delete(void) {
|
||||||
auto p = ::operator new(1);
|
void* volatile p = ::operator new(1);
|
||||||
expect_ptr_not_null(p, "Unexpected new failure");
|
expect_ptr_not_null((void *)p, "Unexpected new failure");
|
||||||
::operator delete(p);
|
::operator delete((void *)p);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
malloc_free_array(void) {
|
malloc_free_array(void) {
|
||||||
void *p = malloc(sizeof(int)*8);
|
void* volatile p = malloc(sizeof(int)*8);
|
||||||
expect_ptr_not_null(p, "Unexpected malloc failure");
|
expect_ptr_not_null((void *)p, "Unexpected malloc failure");
|
||||||
free(p);
|
free((void *)p);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
new_delete_array(void) {
|
new_delete_array(void) {
|
||||||
auto p = new int[8];
|
int* volatile p = new int[8];
|
||||||
expect_ptr_not_null(p, "Unexpected new[] failure");
|
expect_ptr_not_null((int *)p, "Unexpected new[] failure");
|
||||||
delete[] p;
|
delete[] (int *)p;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if __cpp_sized_deallocation >= 201309
|
#if __cpp_sized_deallocation >= 201309
|
||||||
static void
|
static void
|
||||||
new_sized_delete(void) {
|
new_sized_delete(void) {
|
||||||
auto p = ::operator new(1);
|
void* volatile p = ::operator new(1);
|
||||||
expect_ptr_not_null(p, "Unexpected new failure");
|
expect_ptr_not_null((void *)p, "Unexpected new failure");
|
||||||
::operator delete(p, 1);
|
::operator delete((void *)p, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
malloc_sdallocx(void) {
|
malloc_sdallocx(void) {
|
||||||
void *p = malloc(1);
|
void* volatile p = malloc(1);
|
||||||
expect_ptr_not_null(p, "Unexpected malloc failure");
|
expect_ptr_not_null((void *)p, "Unexpected malloc failure");
|
||||||
sdallocx(p, 1, 0);
|
sdallocx((void *)p, 1, 0);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user