blob: c84f6cbfc3efceff77a19fefebcceeb2b030cd7b (
plain)
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
|
#include <stdio.h>
#include <stdlib.h>
#define NLIVE 1000000
#define NITERS (3*1000*1000)
char* arr[NLIVE];
int main ( void )
{
int i, j, nbytes = 0;
printf("initialising\n");
for (i = 0; i < NLIVE; i++)
arr[i] = NULL;
printf("running\n");
j = -1;
for (i = 0; i < NITERS; i++) {
j++;
if (j == NLIVE) j = 0;
if (arr[j])
free(arr[j]);
arr[j] = malloc(nbytes);
// Cycle through the sizes 0,8,16,24,32. Zero will get rounded up to
// 8, so the 8B bucket will get twice as much traffic.
nbytes += 8;
if (nbytes > 32)
nbytes = 0;
}
for (i = 0; i < NLIVE; i++)
if (arr[i])
free(arr[i]);
printf("done\n");
return 0;
}
|