1 2 #include <stdio.h> 3 #include <stdlib.h> 4 5 /* The original test driver machinery. */ 6 #define N_TEST_TRANSACTIONS 500 7 #define N_TEST_ARR 2000 8 9 #define M_TEST_MALLOC 1000 10 11 void* test_arr[N_TEST_ARR]; 12 13 unsigned myrandom(void) 14 { 15 /* Simple multiply-with-carry random generator. */ 16 static unsigned m_w = 11; 17 static unsigned m_z = 13; 18 19 m_z = 36969 * (m_z & 65535) + (m_z >> 16); 20 m_w = 18000 * (m_w & 65535) + (m_w >> 16); 21 return (m_z << 16) + m_w; 22 } 23 24 int main ( int argc, char** argv ) 25 { 26 int i, j, k, nbytes; 27 unsigned char* chp; 28 29 for (i = 0; i < N_TEST_ARR; i++) 30 test_arr[i] = NULL; 31 32 for (i = 0; i < N_TEST_TRANSACTIONS; i++) { 33 j = myrandom() % N_TEST_ARR; 34 if (test_arr[j]) { 35 free(test_arr[j]); 36 test_arr[j] = NULL; 37 } else { 38 nbytes = 1 + myrandom() % M_TEST_MALLOC; 39 if (myrandom()%64 == 32) 40 nbytes *= 17; 41 test_arr[j] = malloc( nbytes ); 42 chp = test_arr[j]; 43 for (k = 1; k < nbytes; k++) 44 chp[k] = (unsigned char)(k + 99); 45 } 46 } 47 48 for (i = 0; test_arr[i] == NULL; i++) ; 49 free(test_arr[i]); 50 ((char*)test_arr[i])[0] = 0; 51 52 for (i = 0; i < N_TEST_ARR; i++) { 53 if (test_arr[i]) { 54 free(test_arr[i]); 55 test_arr[i] = NULL; 56 } 57 } 58 59 return 0; 60 } 61