1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
|
/*
* Copyright 2011 The Emscripten Authors. All rights reserved.
* Emscripten is available under two separate licenses, the MIT license and the
* University of Illinois/NCSA Open Source License. Both these licenses can be
* found in the LICENSE file.
*/
// Emscripten tests
#include <assert.h>
#include <emscripten/console.h>
#include <stdlib.h>
int main(int ac, char **av)
{
int NUM = ac > 1 ? atoi(av[1]) : 0;
int REPS = ac > 2 ? atoi(av[2]) : 0;
int c1 = 0, c2 = 0;
for (int x = 0; x < REPS; x++) {
char* allocations[NUM];
for (int i = 0; i < NUM/2; i++) {
allocations[i] = (char*)malloc((11*i)%1024 + x);
assert(allocations[i]);
if (i > 10 && i%4 == 1 && allocations[i-10]) {
free(allocations[i-10]);
allocations[i-10] = NULL;
}
}
for (int i = NUM/2; i < NUM; i++) {
allocations[i] = (char*)malloc(1024*(i+1));
assert(allocations[i]);
if (i > 10 && i%4 != 1 && allocations[i-10]) {
free(allocations[i-10]);
allocations[i-10] = NULL;
}
}
char* first = allocations[0];
for (int i = 0; i < NUM; i++) {
if (allocations[i]) {
free(allocations[i]);
}
}
char *last = (char*)malloc(512); // should be identical, as we free'd it all
char *newer = (char*)malloc(512); // should be different
c1 += first == last;
c2 += first == newer;
}
emscripten_console_logf("*%d,%d*\n", c1, c2);
}
|