From f7e343245eacef390a0d52ba4f7dac361eb11a51 Mon Sep 17 00:00:00 2001 From: Subramanian Ganapathy Date: Wed, 30 May 2012 16:52:38 -0700 Subject: [PATCH] Adding fixes for the fork based implementation, also removed some redundant code pointed to by Prof. Demsky --- main.cc | 1 + mymemory.cc | 35 +++++++++++++++++++++++++++++++++++ mymemory.h | 4 ++++ snapshot-interface.h | 1 + snapshot.cc | 16 ++++------------ 5 files changed, 45 insertions(+), 12 deletions(-) diff --git a/main.cc b/main.cc index e8a2b33..be4c58d 100644 --- a/main.cc +++ b/main.cc @@ -65,6 +65,7 @@ void real_main() { delete model; DEBUG("Exiting\n"); + finalize(); } int main_numargs; diff --git a/mymemory.cc b/mymemory.cc index 80c1b95..0bbb749 100644 --- a/mymemory.cc +++ b/mymemory.cc @@ -33,6 +33,37 @@ void *MYMALLOC(size_t size) { #endif } +void *system_malloc( size_t size ){ + static void *(*mallocp)(size_t size); + char *error; + void *ptr; + + /* get address of libc malloc */ + if (!mallocp) { + mallocp = ( void * ( * )( size_t ) )dlsym(RTLD_NEXT, "malloc"); + if ((error = dlerror()) != NULL) { + fputs(error, stderr); + exit(1); + } + } + ptr = mallocp(size); + return ptr; +} + +void system_free( void * ptr ){ + static void (*freep)(void *); + char *error; + + /* get address of libc free */ + if (!freep) { + freep = ( void ( * )( void * ) )dlsym(RTLD_NEXT, "free"); + if ((error = dlerror()) != NULL) { + fputs(error, stderr); + exit(1); + } + } + freep(ptr); +} void MYFREE(void *ptr) { #if USE_MPROTECT_SNAPSHOT static void (*freep)(void *); @@ -62,6 +93,10 @@ void free( void * ptr ){ mspace_free( mySpace, ptr ); } +void *realloc( void *ptr, size_t size ){ + return mspace_realloc( mySpace, ptr, size ); +} + void * operator new(size_t size) throw(std::bad_alloc) { return malloc(size); } diff --git a/mymemory.h b/mymemory.h index 90b2784..f928797 100644 --- a/mymemory.h +++ b/mymemory.h @@ -23,6 +23,8 @@ void *MYMALLOC(size_t size); void MYFREE(void *ptr); +void system_free( void * ptr ); +void *system_malloc( size_t size ); /* The following code example is taken from the book The C++ Standard Library - A Tutorial and Reference @@ -119,6 +121,8 @@ extern "C" { typedef void * mspace; extern void* mspace_malloc(mspace msp, size_t bytes); extern void mspace_free(mspace msp, void* mem); +extern void* mspace_realloc(mspace msp, void* mem, size_t newsize); +extern void* mspace_calloc(mspace msp, size_t n_elements, size_t elem_size); extern mspace create_mspace_with_base(void* base, size_t capacity, int locked); extern mspace create_mspace(size_t capacity, int locked); extern mspace mySpace; diff --git a/snapshot-interface.h b/snapshot-interface.h index e9746e1..7e501fe 100644 --- a/snapshot-interface.h +++ b/snapshot-interface.h @@ -8,6 +8,7 @@ typedef void (*VoidFuncPtr)(); void initSnapShotLibrary(unsigned int numbackingpages, unsigned int numsnapshots, unsigned int nummemoryregions, unsigned int numheappages, VoidFuncPtr entryPoint); +void finalize(); void SnapshotGlobalSegments(); diff --git a/snapshot.cc b/snapshot.cc index 4d71bab..3c5e515 100644 --- a/snapshot.cc +++ b/snapshot.cc @@ -115,6 +115,7 @@ extern "C" { sTheRecord->mStackSize = STACK_SIZE_DEFAULT; sTheRecord->mIDToRollback = -1; sTheRecord->currSnapShotID = 0; + sTheRecord->mbFinalize = false; #endif } #ifdef __cplusplus @@ -156,19 +157,10 @@ void initSnapShotLibrary(unsigned int numbackingpages, addMemoryRegionToSnapShot(pagealignedbase, numheappages); entryPoint(); #else - //SUBRAMANIAN: WHY IS THIS SIGNAL HANDLER HERE FOR THE FORK BASED APPROACH???? - //IT LOOKS LIKE SOME CODE WAS REMOVED FROM SIGNAL HANDLER... - //IN ANY CASE, DO NOT REUSE THE HANDLEPF CALL!!!! - //add a signal to indicate that the process is going to terminate. - struct sigaction sa; - sa.sa_flags = SA_SIGINFO | SA_NODEFER | SA_RESTART; - sigemptyset( &sa.sa_mask ); - sa.sa_sigaction = HandlePF; - if( sigaction( SIGUSR1, &sa, NULL ) == -1 ){ - printf("SIGACTION CANNOT BE INSTALLED\n"); - exit(-1); - } + basemySpace=system_malloc((numheappages+1)*PAGESIZE); + void * pagealignedbase=PageAlignAddressUpward(basemySpace); + mySpace = create_mspace_with_base(pagealignedbase, numheappages*PAGESIZE, 1 ); createSharedLibrary(); //step 2 setup the stack context. -- 2.34.1