1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
/**************************************************************************\
*
* This file is part of the Coin 3D visualization library.
* Copyright (C) by Kongsberg Oil & Gas Technologies.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* ("GPL") version 2 as published by the Free Software Foundation.
* See the file LICENSE.GPL at the root directory of this source
* distribution for additional information about the GNU GPL.
*
* For using Coin with software that can not be combined with the GNU
* GPL, and for taking advantage of the additional benefits of our
* support services, please contact Kongsberg Oil & Gas Technologies
* about acquiring a Coin Professional Edition License.
*
* See http://www.coin3d.org/ for more information.
*
* Kongsberg Oil & Gas Technologies, Bygdoy Alle 5, 0257 Oslo, NORWAY.
* http://www.sim.no/ sales@sim.no coin-support@coin3d.org
*
\**************************************************************************/
#include <Inventor/C/threads/barrier.h>
#include <stdlib.h>
#include <stdio.h>
#include <assert.h>
#include <Inventor/C/threads/mutex.h>
#include <Inventor/C/threads/condvar.h>
#include "threads/barrierp.h"
/* ********************************************************************** */
/*
*/
cc_barrier *
cc_barrier_construct(unsigned int count)
{
cc_barrier * barrier;
barrier = (cc_barrier *) malloc(sizeof(cc_barrier));
barrier->numthreads = count;
barrier->counter = 0;
barrier->mutex = cc_mutex_construct();
barrier->condvar = cc_condvar_construct();
return barrier;
}
/*
*/
void
cc_barrier_destruct(cc_barrier * barrier)
{
assert(barrier != NULL);
cc_condvar_wake_all(barrier->condvar);
cc_condvar_destruct(barrier->condvar);
cc_mutex_destruct(barrier->mutex);
free(barrier);
}
/*
*/
int
cc_barrier_enter(cc_barrier * barrier)
{
assert(barrier != NULL);
cc_mutex_lock(barrier->mutex);
barrier->counter++;
if (barrier->counter == barrier->numthreads) {
barrier->counter = 0;
cc_condvar_wake_all(barrier->condvar);
cc_mutex_unlock(barrier->mutex);
return 1;
}
else {
cc_condvar_wait(barrier->condvar, barrier->mutex);
cc_mutex_unlock(barrier->mutex);
}
return 0;
}
/* ********************************************************************** */
/*!
\class SbBarrier Inventor/threads/SbBarrier.h
\brief The SbBarrier class implements the "barrier" multi-thread
synchronization technique.
\ingroup threads
A barrier is a synchronization mechanism that is used for blocking
threads as they enter the barrier until a given number of threads are
blocked, at which point all the threads are released again.
*/
/*!
\fn SbBarrier::SbBarrier(unsigned int count)
Constructor. The SbBarrier will be set for \c count number of
threads.
*/
/*!
\fn SbBarrier::~SbBarrier(void)
Destructor.
*/
/*!
\fn int SbBarrier::enter(void)
This method blocks the calling thread on this barrier. It returns
when the given number of threads have been blocked. 1 is
returned if the caller was the last thread to enter the barrier,
0 otherwise.
*/
/* ********************************************************************** */
|