X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/298475b7a7f5b043d8d6870ac51626a9d8bd3777..8f8f76af2d03714eaab97e3678acfdfc0e422cc9:/teshsuite/xbt/mmalloc/mmalloc_test.cpp diff --git a/teshsuite/xbt/mmalloc/mmalloc_test.cpp b/teshsuite/xbt/mmalloc/mmalloc_test.cpp index d77e012ef9..6f798f06d8 100644 --- a/teshsuite/xbt/mmalloc/mmalloc_test.cpp +++ b/teshsuite/xbt/mmalloc/mmalloc_test.cpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2012-2020. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2012-2022. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -7,6 +7,7 @@ #include "xbt.h" #include "xbt/mmalloc.h" +#include #include #include #include @@ -14,6 +15,7 @@ #include #include #include +#include XBT_LOG_NEW_DEFAULT_CATEGORY(test,"this test"); @@ -25,21 +27,20 @@ constexpr int TESTSIZE = 100; static void check_block(const unsigned char* p, unsigned char b, int n) { for (int i = 0; i < n; i++) - if (p[i] != b) - xbt_die("value mismatch: %p[%d] = %#hhx, expected %#hhx", p, i, p[i], b); + xbt_assert(p[i] == b, "value mismatch: %p[%d] = %#hhx, expected %#hhx", p, i, p[i], b); } int main(int argc, char**argv) { xbt_mheap_t heapA = nullptr; - void *pointers[TESTSIZE]; + std::array pointers; xbt_init(&argc,argv); XBT_INFO("Allocating a new heap"); unsigned long mask = ~((unsigned long)xbt_pagesize - 1); auto* addr = reinterpret_cast(((unsigned long)sbrk(0) + BUFFSIZE) & mask); - heapA = xbt_mheap_new(-1, addr); - if (heapA == NULL) { + heapA = xbt_mheap_new(addr, 0); + if (heapA == nullptr) { perror("attach 1 failed"); fprintf(stderr, "bye\n"); exit(1); @@ -69,30 +70,9 @@ int main(int argc, char**argv) pointers[i] = mmalloc(heapA, size); } - XBT_INFO("free all blocks (each one twice, to check that double free are correctly caught)"); - for (i = 0; i < TESTSIZE; i++) { - bool gotit = false; + XBT_INFO("free all blocks"); + for (i = 0; i < TESTSIZE; i++) mfree(heapA, pointers[i]); - try { - mfree(heapA, pointers[i]); - } catch (const simgrid::Exception&) { - gotit = true; - } - if (not gotit) - xbt_die("FAIL: A double-free went undetected (for size:%d)",size_of_block(i)); - } - - XBT_INFO("free again all blocks (to really check that double free are correctly caught)"); - for (i = 0; i < TESTSIZE; i++) { - bool gotit = false; - try { - mfree(heapA, pointers[i]); - } catch (const simgrid::Exception&) { - gotit = true; - } - if (not gotit) - xbt_die("FAIL: A double-free went undetected (for size:%d)",size_of_block(i)); - } XBT_INFO("Let's try different codepaths for mrealloc"); for (i = 0; i < TESTSIZE; i++) {