typedef long unsigned int size_t; void * __attribute__((__cdecl__)) malloc (size_t __size) ; void __attribute__((__cdecl__)) free (void *) ; extern int __VERIFIER_nondet_int(void); int* f(int *q, int v); int* g(int *p); /* if v is initially >= 0 , q is not deallocated returns allocated, initialized memory */ int* f( int *q, int v) { if(v < 0) { free(q); return malloc(sizeof(int)); } int *tmp = malloc(sizeof(int)); *tmp = v+1; int *tmp2 = f(g(tmp),v-1); *tmp2 = 0; int *tmp3 = malloc(sizeof(int)); *tmp3 = v+2; int *tmp4 = g(tmp3); *tmp4 = 1; while(*tmp2 != 0) ; //Need disjointness of tmp2 and tmp4 to terminate return tmp4; } /* must pass allocated, initialized pointer returns allocated, unitilized memory */ int* g(int *p) { if(*p < 0) { free(p); return malloc(sizeof(int)); } (*p)--; int *np = g(p); free(np); return malloc(sizeof(int)); } int main() { int *p1 = malloc(sizeof(int)); int *p2 = malloc(sizeof(int)); *p1 = __VERIFIER_nondet_int(); *p2 = __VERIFIER_nondet_int(); if(*p1 < 0 || *p2 < 0) return 0; f(p1,*p2); free(p1); }