]> rtime.felk.cvut.cz Git - frescor/fosa.git/blobdiff - src_partikle/fosa_mutexes_and_condvars.c
FOSA-PaRTiKle implementation
[frescor/fosa.git] / src_partikle / fosa_mutexes_and_condvars.c
index 5d688d73cbba919ae2f33f18100d03c55e777df2..5c7d34cb67e13eefd2be870428a7597aaaf931f1 100644 (file)
-/** fosa_mutexes_and_condvars.h
- *
- * < description >
- * < author >
- * < date >
- */
+// -----------------------------------------------------------------------
+//  Copyright (C) 2006 - 2007 FRESCOR consortium partners:
+//
+//    Universidad de Cantabria,              SPAIN
+//    University of York,                    UK
+//    Scuola Superiore Sant'Anna,            ITALY
+//    Kaiserslautern University,             GERMANY
+//    Univ. Politecnica  Valencia,           SPAIN
+//    Czech Technical University in Prague,  CZECH REPUBLIC
+//    ENEA                                   SWEDEN
+//    Thales Communication S.A.              FRANCE
+//    Visual Tools S.A.                      SPAIN
+//    Rapita Systems Ltd                     UK
+//    Evidence                               ITALY
+//    
+//    See http://www.frescor.org for a link to partners' websites
+//
+//           FRESCOR project (FP6/2005/IST/5-034026) is funded
+//        in part by the European Union Sixth Framework Programme
+//        The European Union is not liable of any use that may be
+//        made of this code.
+//
+//  This file is part of the FRSH implementation
+//
+//  FRSH is free software; you can  redistribute it and/or  modify
+//  it under the terms of  the GNU General Public License as published by
+//  the Free Software Foundation;  either  version 2, or (at  your option)
+//  any later version.
+//
+//  FRSH  is distributed  in  the hope  that  it  will  be useful,  but
+//  WITHOUT  ANY  WARRANTY;     without  even the   implied   warranty  of
+//  MERCHANTABILITY  or  FITNESS FOR  A  PARTICULAR PURPOSE. See  the  GNU
+//  General Public License for more details.
+//
+//  You should have  received a  copy of  the  GNU  General Public License
+//  distributed  with  FRSH;  see file COPYING.   If not,  write to the
+//  Free Software  Foundation,  59 Temple Place  -  Suite 330,  Boston, MA
+//  02111-1307, USA.
+//
+//  As a special exception, if you include this header file into source
+//  files to be compiled, this header file does not by itself cause
+//  the resulting executable to be covered by the GNU General Public
+//  License.  This exception does not however invalidate any other
+//  reasons why the executable file might be covered by the GNU General
+//  Public License.
+// -----------------------------------------------------------------------
+//==============================================
+//  ********  ******    ********  **********
+//  **///// /**    **  **//////  /**     /**
+//  **      /**    ** /**        /**     /**
+//  ******* /**    ** /********* /**********
+//  **////  /**    ** ////////** /**//////**
+//  **      /**    **        /** /**     /**
+//  **      /**    **  ********  /**     /**
+//  //       /******/  ////////   //      // 
+//
+// FOSA(Frescor Operating System Adaptation layer)
+//================================================
 
 #include <fosa_mutexes_and_condvars.h>
 
 /*******************************************************
  * Mutexes with priority ceiling
  ******************************************************/
-int fosa_mutex_init(frsh_mutex_t *mutex, int prioceiling);
-int fosa_mutex_destroy(frsh_mutex_t *mutex);
+int fosa_mutex_init(fosa_mutex_t *mutex, int prioceiling)
+{
+       pthread_mutexattr_t attr;
+       int err;
+       
+       if (err = pthread_mutexattr_init (&attr))
+               return err;
+       
+       pthread_mutexattr_settype (&attr, PTHREAD_MUTEX_ERRORCHECK);
+       pthread_mutexattr_setprotocol (&attr, PTHREAD_PRIO_PROTECT);
+       if (err = pthread_mutexattr_setprioceiling (&attr, prioceiling))
+               return err;
+       
+       return pthread_mutex_init (mutex, &attr);
+}
+               
+int fosa_mutex_destroy(fosa_mutex_t *mutex)
+{
+       return pthread_mutex_destroy (mutex);
+}
+
 int fosa_mutex_set_prioceiling
-               (frsh_mutex_t *mutex, int new_ceiling, int *old_ceiling);
-int fosa_mutex_get_prioceiling(const frsh_mutex_t *mutex, int *ceiling);
-int fosa_mutex_lock(frsh_mutex_t *mutex);
-int fosa_mutex_trylock(frsh_mutex_t *mutex);
-int fosa_mutex_unlock(frsh_mutex_t *mutex);
+               (fosa_mutex_t *mutex, int new_ceiling, int *old_ceiling)
+{
+       return pthread_mutex_setprioceiling (mutex, new_ceiling, old_ceiling);
+}
+
+int fosa_mutex_get_prioceiling(const fosa_mutex_t *mutex, int *ceiling)
+{
+       return pthread_mutex_getprioceiling (mutex, ceiling);
+}
+
+int fosa_mutex_lock(fosa_mutex_t *mutex)
+{
+       return pthread_mutex_lock (mutex);
+}
+
+int fosa_mutex_trylock(fosa_mutex_t *mutex)
+{
+       return pthread_mutex_trylock (mutex);
+}
+
+int fosa_mutex_unlock(fosa_mutex_t *mutex)
+{
+       return pthread_mutex_unlock (mutex);
+}
 
 
 /**********************
  * Condition variables
  *********************/
-int fosa_cond_init(fosa_cond_t *cond);
-int fosa_cond_destroy(fosa_cond_t *cond);
-int fosa_cond_signal(fosa_cond_t *cond);
-int fosa_cond_broadcast(fosa_cond_t *cond);
-int fosa_cond_wait(fosa_cond_t *cond, frsh_mutex_t *mutex);
-int fosa_cond_timedwait(fosa_cond_t *cond, frsh_mutex_t *mutex, 
-                       const struct timespec *abstime);
+int fosa_cond_init(fosa_cond_t *cond)
+{
+       pthread_condattr_t attr;
+       int err;
+       
+       if (err = pthread_condattr_init (&attr))
+               return err;
+       
+       return pthread_cond_init (cond, NULL);
+}
+
+int fosa_cond_destroy(fosa_cond_t *cond)
+{
+       return pthread_cond_destroy (cond);
+}
+
+int fosa_cond_signal(fosa_cond_t *cond)
+{
+       return pthread_cond_signal (cond);
+}
+
+int fosa_cond_broadcast(fosa_cond_t *cond)
+{
+       return pthread_cond_broadcast (cond);
+}
+
+int fosa_cond_wait(fosa_cond_t *cond, fosa_mutex_t *mutex)
+{
+       return pthread_cond_wait (cond, mutex);
+}
+
+int fosa_cond_timedwait 
+               (fosa_cond_t *cond, 
+                fosa_mutex_t *mutex,
+                const struct timespec *abstime)
+{
+       int err;
+       
+       err = pthread_cond_timedwait (cond, mutex, abstime);
+       if (err == ETIMEDOUT)
+               return ETIMEDOUT;
+
+       if (err)
+               return EINVAL;
+       
+       return 0;
+}