From: Subramanian Ganapathy Date: Wed, 13 Jun 2012 19:58:54 +0000 (-0700) Subject: fixing calloc(), fix Makefile X-Git-Tag: pldi2013~391^2~37 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=c22fe323b21a945acb2eb07b01fd31a9402231a5;p=model-checker.git fixing calloc(), fix Makefile Adding sbrk() calls and hooked into free also to avoid freeing sbrked memory... checked both fork and paged implementation. seems to work Also everytime we switch between fork and paged impl, we need to rebuild so adding snapshot.h as dependency to mymemory.cc in makefile --- diff --git a/Makefile b/Makefile index 7e07cc8..fbbc3a1 100644 --- a/Makefile +++ b/Makefile @@ -44,7 +44,7 @@ $(LIB_SO): $(MODEL_O) $(MODEL_H) $(SHMEM_O) $(SHMEM_H) malloc.o: malloc.c $(CC) -fPIC -c malloc.c -DMSPACES -DONLY_MSPACES $(CPPFLAGS) -mymemory.o: mymemory.h snapshotimp.h mymemory.cc +mymemory.o: mymemory.h snapshotimp.h snapshot.h mymemory.cc $(CXX) -fPIC -c mymemory.cc $(CPPFLAGS) snapshot.o: mymemory.h snapshot.h snapshotimp.h snapshot.cc diff --git a/mymemory.cc b/mymemory.cc index 2b9c44d..245b270 100644 --- a/mymemory.cc +++ b/mymemory.cc @@ -3,6 +3,12 @@ #include "snapshotimp.h" #include #include +#include +#include +#define REQUESTS_BEFORE_ALLOC 1024 +size_t allocatedReqs[ REQUESTS_BEFORE_ALLOC ] = { 0 }; +int nextRequest = 0; +int howManyFreed = 0; #if !USE_MPROTECT_SNAPSHOT static mspace sStaticSpace = NULL; #endif @@ -96,15 +102,47 @@ void * basemySpace = NULL; //Subramanian --- please make these work for the fork based approach +/** Adding the fix for not able to allocate through a reimplemented calloc at the beginning before instantiating our allocator +A bit circumspect about adding an sbrk. linux docs say to avoid using it... */ + +void * HandleEarlyAllocationRequest( size_t sz ){ + if( 0 == mySpace ){ + void * returnAddress = sbrk( sz ); + if( nextRequest >= REQUESTS_BEFORE_ALLOC ){ + exit( EXIT_FAILURE ); + } + allocatedReqs[ nextRequest++ ] = ( size_t )returnAddress; + return returnAddress; + } + return NULL; +} + +/** The fact that I am not expecting more than a handful requests is implicit in my not using a binary search here*/ + +bool DontFree( void * ptr ){ + if( howManyFreed == nextRequest ) return false; //a minor optimization to reduce the number of instructions executed on each free call.... + if( NULL == ptr ) return true; + for( int i = nextRequest - 1; i >= 0; --i ){ + if( allocatedReqs[ i ] == ( size_t )ptr ) { + ++howManyFreed; + return true; + } + } + return false; +} + /** Snapshotting malloc implementation for user programs. */ void *malloc( size_t size ) { + void * earlyReq = HandleEarlyAllocationRequest( size ); + if( earlyReq ) return earlyReq; return mspace_malloc( mySpace, size ); } /** Snapshotting free implementation for user programs. */ void free( void * ptr ){ + if( DontFree( ptr ) ) return; mspace_free( mySpace, ptr ); } @@ -114,8 +152,21 @@ void *realloc( void *ptr, size_t size ){ return mspace_realloc( mySpace, ptr, size ); } +/** Snapshotting calloc implementation for user programs. */ + +void * calloc( size_t num, size_t size ){ + void * earlyReq = HandleEarlyAllocationRequest( size * num ); + if( earlyReq ) { + std::memset( earlyReq, 0, size * num ); + return earlyReq; + } + return mspace_calloc( mySpace, num, size ); +} + + /** Snapshotting new operator for user programs. */ + void * operator new(size_t size) throw(std::bad_alloc) { return malloc(size); }