sTheRecord->mStackSize = STACK_SIZE_DEFAULT;
sTheRecord->mIDToRollback = -1;
sTheRecord->currSnapShotID = 0;
- sTheRecord->mbFinalize = false;
#endif
}
createSharedLibrary();
//step 2 setup the stack context.
-
- int alreadySwapped = 0;
- getcontext( &savedSnapshotContext );
- if( !alreadySwapped ){
- alreadySwapped = 1;
- ucontext_t currentContext, swappedContext, newContext;
- getcontext( &newContext );
- newContext.uc_stack.ss_sp = sTheRecord->mStackBase;
- newContext.uc_stack.ss_size = STACK_SIZE_DEFAULT;
- newContext.uc_link = ¤tContext;
- makecontext( &newContext, entryPoint, 0 );
- swapcontext( &swappedContext, &newContext );
- }
+ ucontext_t newContext;
+ getcontext( &newContext );
+ newContext.uc_stack.ss_sp = sTheRecord->mStackBase;
+ newContext.uc_stack.ss_size = STACK_SIZE_DEFAULT;
+ makecontext( &newContext, entryPoint, 0 );
+ /* switch to a new entryPoint context, on a new stack */
+ swapcontext(&savedSnapshotContext, &newContext);
//add the code to take a snapshot here...
//to return to user process, do a second swapcontext...
pid_t forkedID = 0;
snapshotid = sTheRecord->currSnapShotID;
bool swapContext = false;
- while( !sTheRecord->mbFinalize ){
+ while( true ){
sTheRecord->currSnapShotID=snapshotid+1;
forkedID = fork();
if( 0 == forkedID ){
SSDEBUG("Invoked rollback");
exit(EXIT_SUCCESS);
}
+ sTheRecord->mIDToRollback = -1;
#endif
}
- /** The finalize method shuts down the snapshotting system. */
- //Subramanian -- remove this function from the external interface and
- //have us call it internally
- void finalize(){
- #if !USE_MPROTECT_SNAPSHOT
- sTheRecord->mbFinalize = true;
- #endif
- }