Diff for /rpl/src/rpl.h between versions 1.123 and 1.126

version 1.123, 2011/09/15 19:23:54 version 1.126, 2011/09/19 17:33:17
Line 101 Line 101
 #   include <pwd.h>  #   include <pwd.h>
 #   include <sys/shm.h>  #   include <sys/shm.h>
   
 #   ifndef IPCS_SYSV  #   ifndef __RPLCAS
 #       include <semaphore.h>  #       ifndef IPCS_SYSV
 #   else  #           include <semaphore.h>
 #       include <sys/ipc.h>  
 #       include <sys/sem.h>  
   
 #       ifdef OS2  
 #           define INCL_DOSSEMAPHORES  
 #           define INCL_DOSMEMMGR  
 #           define INCL_DOSERRORS  
 #           include <os2.h>  
   
             typedef struct _OS2SEM  
             {  
                 HMTX    hmtx;  
                 HEV     hev;  
                 ULONG   shared;  
                 ULONG   *cnt;  
                 ULONG   *nopened;  
                 ULONG   allocated;  
             } sem_t;  
 #       else  #       else
             typedef struct  #           include <sys/ipc.h>
             {  #           include <sys/sem.h>
                 int             sem;  
                 unsigned char   *path;  
                 pid_t           pid;  
             } sem_t;  
 #       endif  
   
 #       define SEM_FAILED   NULL  
   
         sem_t *sem_open_SysV(const char *nom, int oflag, ...);  #           ifdef OS2
         int sem_init_SysV(sem_t *sem, int shared, unsigned int value);  #               define INCL_DOSSEMAPHORES
         int sem_close_SysV(sem_t *sem);  #               define INCL_DOSMEMMGR
         int sem_wait_SysV(sem_t *sem);  #               define INCL_DOSERRORS
         int sem_trywait_SysV(sem_t *sem);  #               include <os2.h>
         int sem_post_SysV(sem_t *sem);  
         int sem_getvalue_SysV(sem_t *sem, int *value);                  typedef struct _OS2SEM
         int sem_unlink_SysV(const char *nom);                  {
         int sem_destroy_SysV(sem_t *sem);                      HMTX    hmtx;
                       HEV     hev;
                       ULONG   shared;
                       ULONG   *cnt;
                       ULONG   *nopened;
                       ULONG   allocated;
                   } sem_t;
   #           else // IPCS_SYSV
                   typedef struct
                   {
                       int             sem;
                       int             alloue;
                       unsigned char   *path;
                       pid_t           pid;
                   } sem_t;
   #           endif
   
   #           ifndef SEM_FAILED
   #               define SEM_FAILED   NULL
   #           endif
   
               sem_t *sem_open_SysV(const char *nom, int oflag, ...);
               int sem_init_SysV(sem_t *sem, int shared, unsigned int value);
               int sem_close_SysV(sem_t *sem);
               int sem_wait_SysV(sem_t *sem);
               int sem_trywait_SysV(sem_t *sem);
               int sem_post_SysV(sem_t *sem);
               int sem_getvalue_SysV(sem_t *sem, int *value);
               int sem_unlink_SysV(const char *nom);
               int sem_destroy_SysV(sem_t *sem);
   #       endif
 #   endif  #   endif
   
 #   include <setjmp.h>  #   include <setjmp.h>
Line 239  enum signaux_rpl Line 244  enum signaux_rpl
   
 typedef struct queue_signaux  typedef struct queue_signaux
 {  {
     sem_t  #   ifndef IPCS_SYSV
 #   ifdef SEMAPHORES_NOMMES  #       ifndef SEMAPHORES_NOMMES
         *              sem_t               semaphore;
   #       endif
   #   else
           sem_t                   semaphore;
 #   endif  #   endif
                                 semaphore;  
   
     volatile int                pointeur_lecture;      volatile int                pointeur_lecture;
     volatile int                pointeur_ecriture;      volatile int                pointeur_ecriture;
Line 259  typedef struct queue_signaux Line 266  typedef struct queue_signaux
 #   ifndef MAIN_RPL  #   ifndef MAIN_RPL
         extern struct_queue_signaux         *s_queue_signaux;          extern struct_queue_signaux         *s_queue_signaux;
         extern int                          f_queue_signaux;          extern int                          f_queue_signaux;
   #       ifdef SEMAPHORES_NOMMES
               extern sem_t                    *semaphore_queue_signaux;
   #       endif
 #   else  #   else
         struct_queue_signaux                *s_queue_signaux;          struct_queue_signaux                *s_queue_signaux;
         int                                 f_queue_signaux;          int                                 f_queue_signaux;
   #       ifdef SEMAPHORES_NOMMES
               sem_t                           *semaphore_queue_signaux;
   #       endif
 #   endif  #   endif
 #endif  #endif
   
Line 428  typedef unsigned char   t_8_bits; Line 441  typedef unsigned char   t_8_bits;
   
         pthread_mutex_t             mutex_liste_threads =          pthread_mutex_t             mutex_liste_threads =
                                             PTHREAD_MUTEX_INITIALIZER;                                              PTHREAD_MUTEX_INITIALIZER;
         pthread_mutex_t             mutex_gestiionnaires_signaux =          pthread_mutex_t             mutex_gestionnaires_signaux =
                                             PTHREAD_MUTEX_INITIALIZER;                                              PTHREAD_MUTEX_INITIALIZER;
         pthread_mutex_t             mutex_gestionnaires_signaux_atomique =          pthread_mutex_t             mutex_gestionnaires_signaux_atomique =
                                             PTHREAD_MUTEX_INITIALIZER;                                              PTHREAD_MUTEX_INITIALIZER;
Line 441  typedef unsigned char   t_8_bits; Line 454  typedef unsigned char   t_8_bits;
 #endif  #endif
   
 #ifdef SEMAPHORES_NOMMES  #ifdef SEMAPHORES_NOMMES
 enum t_semaphore    { sem_liste_threads = 0,  sem_t *sem_init2(unsigned int valeur, pid_t pid);
         sem_gestionnaires_signaux = 1,  int sem_destroy2(sem_t *semaphore_p, pid_t pid);
         sem_gestionnaires_signaux_atomique = 2,  
         sem_fork = 3 };  
   
 sem_t *sem_init2(unsigned int valeur, enum t_semaphore semaphore);  
 int sem_destroy2(sem_t *semaphore_p, enum t_semaphore semaphore);  
 int sem_getvalue2(sem_t *semaphore, int *valeur);  int sem_getvalue2(sem_t *semaphore, int *valeur);
   sem_t *sem_open2(pid_t pid);
   
   // Le mutex est là uniquement pour pouvoir émuler le comportement
   // de sem_getvalue() sur un système comme MacOS X qui ne possède pas
   // cette fonction.
   
 #define sem_getvalue(semaphore, value) sem_getvalue2(semaphore, value)  #define sem_getvalue(semaphore, value) sem_getvalue2(semaphore, value)
 #define sem_post(semaphore) \  #define sem_post(semaphore) \
Line 480  int sem_getvalue2(sem_t *semaphore, int Line 493  int sem_getvalue2(sem_t *semaphore, int
 #define ufprintf(flux, ...) transliterated_fprintf(NULL, \  #define ufprintf(flux, ...) transliterated_fprintf(NULL, \
             flux, __VA_ARGS__)              flux, __VA_ARGS__)
   
 // Tous les messages pour DISP, INPUT et les E/S par readline sont sur stderr.  
 // Cela évite aux messages envoyés par les gestionnaires de signaux d'être  
 // indéfiniment bloqués.  
   
 #ifdef SunOS  #ifdef SunOS
 #   define fopen(...) ({ FILE *desc; \  #   define fopen(...) ({ FILE *desc; \
             while((desc = fopen(__VA_ARGS__)) == NULL) \              while((desc = fopen(__VA_ARGS__)) == NULL) \
Line 732  pid_t debug_fork(); Line 741  pid_t debug_fork();
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
 */  */
   
 #define DEBUG_ERREURS  
 #ifdef DEBUG_ERREURS  #ifdef DEBUG_ERREURS
 #   ifdef MESSAGES  #   ifdef MESSAGES
 #       define __erreur(i)  i  #       define __erreur(i)  i

Removed from v.1.123  
changed lines
  Added in v.1.126


CVSweb interface <joel.bertrand@systella.fr>