summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2014-03-14 22:08:33 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2014-03-14 22:08:33 -0700
commit8826ed6d4f2403c2ff71596cb5a16a8be0c60104 (patch)
tree74dbb8a1a4f570fcd1783c4ac3c17aef433c9882 /src
parentc7c3aa3f2db5a7044a73e1af9d9ced2aa827c9e8 (diff)
downloadabc-8826ed6d4f2403c2ff71596cb5a16a8be0c60104.tar.gz
abc-8826ed6d4f2403c2ff71596cb5a16a8be0c60104.tar.bz2
abc-8826ed6d4f2403c2ff71596cb5a16a8be0c60104.zip
Experiments with simulation.
Diffstat (limited to 'src')
-rw-r--r--src/map/if/ifTest.c24
1 files changed, 9 insertions, 15 deletions
diff --git a/src/map/if/ifTest.c b/src/map/if/ifTest.c
index f8ac8423..bbadaca2 100644
--- a/src/map/if/ifTest.c
+++ b/src/map/if/ifTest.c
@@ -206,19 +206,16 @@ typedef struct Par_ThData_t_
int Id;
int Status;
} Par_ThData_t;
-//pthread_mutex_t g_mutex = PTHREAD_MUTEX_INITIALIZER;
void * Gia_ParWorkerThread( void * pArg )
{
Par_ThData_t * pThData = (Par_ThData_t *)pArg;
- unsigned Counter = 0;
+ volatile int * pPlace = &pThData->Status;
while ( 1 )
{
- while ( pThData->Status == 0 )
- printf( "" );
+ while ( *pPlace == 0 );
assert( pThData->Status == 1 );
if ( pThData->Id == -1 )
{
-// printf( "Stopped\n" ); fflush( stdout );
pthread_exit( NULL );
assert( 0 );
return NULL;
@@ -227,7 +224,6 @@ void * Gia_ParWorkerThread( void * pArg )
Gia_ParTestSimulateObj( pThData->p, pThData->Id );
pThData->Status = 0;
}
- assert( Counter != 0 );
assert( 0 );
return NULL;
}
@@ -256,9 +252,8 @@ void Gia_ParTestSimulate2( Gia_Man_t * p, int nWords, int nProcs )
ThData[i].Id = -1;
ThData[i].Status = 0;
status = pthread_create( WorkerThread + i, NULL, Gia_ParWorkerThread, (void *)(ThData + i) ); assert( status == 0 );
-// printf( "Started %d\n", i ); fflush( stdout );
}
- while ( nCountFanins > 0 )
+ while ( nCountFanins > 0 || Vec_IntSize(vStack) > 0 )
{
for ( i = 0; i < nProcs; i++ )
{
@@ -303,7 +298,6 @@ void Gia_ParTestSimulate2( Gia_Man_t * p, int nWords, int nProcs )
for ( i = 0; i < nProcs; i++ )
{
assert( ThData[i].Status == 0 );
-// printf( "Stopping %d\n", i ); fflush( stdout );
ThData[i].Id = -1;
ThData[i].Status = 1;
}
@@ -329,16 +323,16 @@ void Gia_ParTestSimulate2( Gia_Man_t * p, int nWords, int nProcs )
void Gia_ParTest( Gia_Man_t * p, int nWords, int nProcs )
{
abctime clk;
- printf( "Trying with %d words and %d threads.\n", nWords, nProcs );
+ printf( "Trying with %d words and %d threads. ", nWords, nProcs );
printf( "Memory usage = %.2f MB\n", (8.0*nWords*Gia_ManObjNum(p))/(1<<20) );
-
- clk = Abc_Clock();
- Gia_ParTestSimulate2( p, nWords, nProcs );
- Abc_PrintTime( 1, "Time", Abc_Clock() - clk );
clk = Abc_Clock();
Gia_ParTestSimulate( p, nWords );
- Abc_PrintTime( 1, "Time", Abc_Clock() - clk );
+ Abc_PrintTime( 1, "Regular time", Abc_Clock() - clk );
+
+ clk = Abc_Clock();
+ Gia_ParTestSimulate2( p, nWords, nProcs );
+ Abc_PrintTime( 1, "Special time", Abc_Clock() - clk );
}
////////////////////////////////////////////////////////////////////////