From: Brian Norris Date: Thu, 14 Jun 2012 06:28:10 +0000 (-0700) Subject: snapshot: remove 'extern "C"' block X-Git-Tag: pldi2013~391^2~32 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=f5fbcb47d918e04f14e0d79d64538bf72afb6be4;p=model-checker.git snapshot: remove 'extern "C"' block We do not need to wrap this function in 'extern "C"' for two reasons: 1) It's not actually exported and used in C code 2) You only need this sort of declaration in the header file that may be included in both C++ and C compilation. But snapshot.cc should only be compiled by the C++ compiler, and snapshot.h is not included in any C compilation. --- diff --git a/snapshot.cc b/snapshot.cc index 51d2a3a..65a7e21 100644 --- a/snapshot.cc +++ b/snapshot.cc @@ -106,30 +106,24 @@ void * ReturnPageAlignedAddress(void * addr) { void * PageAlignAddressUpward(void * addr) { return (void *)((((uintptr_t)addr)+PAGESIZE-1)&~(PAGESIZE-1)); } -#ifdef __cplusplus -extern "C" { -#endif - void createSharedLibrary(){ +void createSharedLibrary(){ #if !USE_MPROTECT_SNAPSHOT - //step 1. create shared memory. - if( sTheRecord ) return; - int fd = shm_open( "/ModelChecker-Snapshotter", O_RDWR | O_CREAT, 0777 ); //universal permissions. - if( -1 == fd ) FAILURE("shm_open"); - if( -1 == ftruncate( fd, ( size_t )SHARED_MEMORY_DEFAULT + ( size_t )STACK_SIZE_DEFAULT ) ) FAILURE( "ftruncate" ); - char * memMapBase = ( char * ) mmap( 0, ( size_t )SHARED_MEMORY_DEFAULT + ( size_t )STACK_SIZE_DEFAULT, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0 ); - if( MAP_FAILED == memMapBase ) FAILURE("mmap"); - sTheRecord = ( struct Snapshot_t * )memMapBase; - sTheRecord->mSharedMemoryBase = memMapBase + sizeof( struct Snapshot_t ); - sTheRecord->mStackBase = ( char * )memMapBase + ( size_t )SHARED_MEMORY_DEFAULT; - sTheRecord->mStackSize = STACK_SIZE_DEFAULT; - sTheRecord->mIDToRollback = -1; - sTheRecord->currSnapShotID = 0; - sTheRecord->mbFinalize = false; + //step 1. create shared memory. + if( sTheRecord ) return; + int fd = shm_open( "/ModelChecker-Snapshotter", O_RDWR | O_CREAT, 0777 ); //universal permissions. + if( -1 == fd ) FAILURE("shm_open"); + if( -1 == ftruncate( fd, ( size_t )SHARED_MEMORY_DEFAULT + ( size_t )STACK_SIZE_DEFAULT ) ) FAILURE( "ftruncate" ); + char * memMapBase = ( char * ) mmap( 0, ( size_t )SHARED_MEMORY_DEFAULT + ( size_t )STACK_SIZE_DEFAULT, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0 ); + if( MAP_FAILED == memMapBase ) FAILURE("mmap"); + sTheRecord = ( struct Snapshot_t * )memMapBase; + sTheRecord->mSharedMemoryBase = memMapBase + sizeof( struct Snapshot_t ); + sTheRecord->mStackBase = ( char * )memMapBase + ( size_t )SHARED_MEMORY_DEFAULT; + sTheRecord->mStackSize = STACK_SIZE_DEFAULT; + sTheRecord->mIDToRollback = -1; + sTheRecord->currSnapShotID = 0; + sTheRecord->mbFinalize = false; #endif - } -#ifdef __cplusplus } -#endif /** The initSnapShotLibrary function initializes the Snapshot library. * @param entryPoint the function that should run the program. diff --git a/snapshot.h b/snapshot.h index 03e020e..cbbe007 100644 --- a/snapshot.h +++ b/snapshot.h @@ -22,11 +22,6 @@ snapshot_id takeSnapshot( ); void rollBack( snapshot_id theSnapShot ); -#ifdef __cplusplus -extern "C" { -#endif void createSharedLibrary(); -#ifdef __cplusplus -}; /* end of extern "C" */ -#endif + #endif