pthread locking and unlocking - Programmers Heaven

Howdy, Stranger!

It looks like you're new here. If you want to get involved, click one of these buttons!

Categories

pthread locking and unlocking

MukindMukind Posts: 2Member
When more than one thread is waiting for a locked mutex, which thread will be granted the lock first after it is released.

In our application we want to implement FIFO thread scheduling policy i.e. Thread should get lock which one requested first for it.
AIX have SCHED_FIFO thread scheduling policy but did not worked, i have added code snap shots below with output.

Plz guys help us ...!!


#include
#include
#define NTHREADS 13


pthread_attr_t attr;
pthread_mutex_t mym;
pthread_once_t OnceInit = PTHREAD_ONCE_INIT;
int once = 1;
void *dowork(void *threadid)
{
pthread_t ThreadID = thread_self();
printf("
---------GOING TO LOCK ==[%u]",ThreadID);
if( pthread_mutex_lock (&mym ) != 0)
{
printf("
Error in Locking Mutex");
exit(1);
}
printf("
------- GOT IT MAN----[%u]",ThreadID);
if( once == 1)
{
++once;
sleep(1);
}
else
sleep(1);

printf("
---------GOING TO UNLOCK ==[%u]",ThreadID);

if( pthread_mutex_unlock ( &mym ) != 0)
{
printf("
Error in UnLocking Mutex");
exit(1);
}
printf("
------------BYE---------[%u]",ThreadID);
pthread_exit(NULL);
}

void init_routine ()
{
if( pthread_mutex_init (&mym,NULL ) != 0)
printf("Error in intialising Mutex "),exit(1);
}

int main(int argc, char *argv[])
{
pthread_attr_t tattr;
int policy;

pthread_t threads[NTHREADS];
size_t stacksize;
int rc;
long *t;
long i=0;
t = (long *)malloc(sizeof(long));
pthread_once (&OnceInit,init_routine);

pthread_attr_init(&attr);
pthread_attr_getschedpolicy(&attr,&policy);
printf("
BEFORE POLICY-------[%d]",policy);
/*if(pthread_attr_setschedpolicy(&attr,SCHED_FIFO)!= 0)
perror("Error is:"); */
pthread_attr_getschedpolicy(&attr,&policy);
printf("
AFTER POLICY-------[%d]",policy);

for(i=0; i<NTHREADS; i++){
rc = pthread_create(&threads[i], &attr, dowork, (void *)t);
if (rc){
printf("ERROR; return code from pthread_create() is %d
", rc);

exit(-1);
}
}
sleep(10);
pthread_exit(NULL);
}
---------------------------------------------------------------------------------------------
OUTPUT without thread policy

BEFORE POLICY-------[0]
AFTER POLICY-------[0]
---------GOING TO LOCK ==[1111421]
------- GOT IT MAN----[1111421]
[color=Red] ---------GOING TO LOCK ==[465893][/color]
---------GOING TO LOCK ==[167661]
---------GOING TO LOCK ==[1132113]
---------GOING TO LOCK ==[951301]
---------GOING TO LOCK ==[1554371]
---------GOING TO LOCK ==[852815]
---------GOING TO LOCK ==[170119]
---------GOING TO LOCK ==[98149]
---------GOING TO LOCK ==[495807]
---------GOING TO LOCK ==[1330225]
---------GOING TO LOCK ==[438407]
---------GOING TO LOCK ==[731879]
---------GOING TO UNLOCK ==[1111421]
------------BYE---------[1111421]
------- GOT IT MAN----[167661]
---------GOING TO UNLOCK ==[167661]
------------BYE---------[167661]
------- GOT IT MAN----[1132113]
---------GOING TO UNLOCK ==[1132113]
------------BYE---------[1132113]
------- GOT IT MAN----[951301]
---------GOING TO UNLOCK ==[951301]
------------BYE---------[951301]
------- GOT IT MAN----[1554371]
---------GOING TO UNLOCK ==[1554371]
------------BYE---------[1554371]
------- GOT IT MAN----[852815]
---------GOING TO UNLOCK ==[852815]
------------BYE---------[852815]
------- GOT IT MAN----[170119]
---------GOING TO UNLOCK ==[170119]
------------BYE---------[170119]
------- GOT IT MAN----[98149]
---------GOING TO UNLOCK ==[98149]
------------BYE---------[98149]
------- GOT IT MAN----[495807]
---------GOING TO UNLOCK ==[495807]
------------BYE---------[495807]
------- GOT IT MAN----[1330225]
---------GOING TO UNLOCK ==[1330225]
------------BYE---------[1330225]
------- GOT IT MAN----[438407]
---------GOING TO UNLOCK ==[438407]
------------BYE---------[438407]
------- GOT IT MAN----[731879]
---------GOING TO UNLOCK ==[731879]
------------BYE---------[731879]
[color=Red] ------- GOT IT MAN----[465893]
---------GOING TO UNLOCK ==[465893]
------------BYE---------[465893][/color]
-----------------------------------------------------------------------------------
OUTPUT with thread scheduling policy
After setting FIFO policy

BEFORE POLICY-------[0]
AFTER POLICY-------[1]
---------GOING TO LOCK ==[40339]
------- GOT IT MAN----[40339]
[color=Red] ---------GOING TO LOCK ==[721475][/color]
---------GOING TO LOCK ==[1174377]
---------GOING TO LOCK ==[449527]
---------GOING TO LOCK ==[98151]
---------GOING TO LOCK ==[495809]
---------GOING TO LOCK ==[1330227]
---------GOING TO LOCK ==[438409]
---------GOING TO LOCK ==[731881]
---------GOING TO LOCK ==[161917]
---------GOING TO LOCK ==[1111423]
---------GOING TO LOCK ==[745475]
---------GOING TO LOCK ==[1180995]
---------GOING TO UNLOCK ==[40339]
------------BYE---------[40339]
------- GOT IT MAN----[1174377]
---------GOING TO UNLOCK ==[1174377]
------------BYE---------[1174377]
------- GOT IT MAN----[449527]
---------GOING TO UNLOCK ==[449527]
------------BYE---------[449527]
------- GOT IT MAN----[98151]
---------GOING TO UNLOCK ==[98151]
------------BYE---------[98151]
------- GOT IT MAN----[495809]
---------GOING TO UNLOCK ==[495809]
------------BYE---------[495809]
------- GOT IT MAN----[1330227]
---------GOING TO UNLOCK ==[1330227]
------------BYE---------[1330227]
------- GOT IT MAN----[438409]
---------GOING TO UNLOCK ==[438409]
------------BYE---------[438409]
------- GOT IT MAN----[731881]
---------GOING TO UNLOCK ==[731881]
------------BYE---------[731881]
------- GOT IT MAN----[161917]
---------GOING TO UNLOCK ==[161917]
------------BYE---------[161917]
------- GOT IT MAN----[1111423]
---------GOING TO UNLOCK ==[1111423]
------------BYE---------[1111423]
------- GOT IT MAN----[745475]
---------GOING TO UNLOCK ==[745475]
------------BYE---------[745475]
------- GOT IT MAN----[1180995]
---------GOING TO UNLOCK ==[1180995]
------------BYE---------[1180995]
[color=Red] ------- GOT IT MAN----[721475]
---------GOING TO UNLOCK ==[721475]
------------BYE---------[721475][/color]
Sign In or Register to comment.