version 1.25, 2010/08/26 19:07:36
|
version 1.33.2.2, 2011/04/14 08:46:38
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.0.19 |
RPL/2 (R) version 4.0.23 |
Copyright (C) 1989-2010 Dr. BERTRAND Joël |
Copyright (C) 1989-2011 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 925 surveillance_processus(void *argument)
|
Line 925 surveillance_processus(void *argument)
|
(*s_etat_processus).erreur_systeme_processus_fils = |
(*s_etat_processus).erreur_systeme_processus_fils = |
d_es_processus; |
d_es_processus; |
} |
} |
|
|
|
pthread_kill((*s_argument_thread).thread_pere, |
|
SIGINJECT); |
} |
} |
} |
} |
else |
else |
Line 3397 lecture_pipe(struct_processus *s_etat_pr
|
Line 3400 lecture_pipe(struct_processus *s_etat_pr
|
================================================================================ |
================================================================================ |
*/ |
*/ |
|
|
#ifndef OS2 |
|
extern inline |
|
#endif |
|
void |
void |
scrutation_injection(struct_processus *s_etat_processus) |
scrutation_injection(struct_processus *s_etat_processus) |
{ |
{ |
fd_set ensemble_descripteurs; |
fd_set ensemble_descripteurs; |
|
|
|
logical1 drapeau_erreur; |
|
logical1 registre_arret_si_exception; |
|
|
# if !defined(OpenBSD) && !defined(OS2) |
# if !defined(OpenBSD) && !defined(OS2) |
struct timespec timeout; |
struct timespec timeout; |
# else |
# else |
struct timeval timeout; |
struct timeval timeout; |
# endif |
# endif |
|
|
logical1 drapeau_erreur; |
|
logical1 registre_arret_si_exception; |
|
|
|
unsigned char tampon; |
unsigned char tampon; |
unsigned char tampon_profilage[20]; |
unsigned char tampon_profilage[20]; |
|
|
// Si on est dans le processus père, il n'y a rien à surveiller. |
// Si on est dans le processus père, il n'y a rien à surveiller. |
|
|
if ((*s_etat_processus).var_volatile_processus_pere == 0) |
if ((*s_etat_processus).var_volatile_processus_racine == 0) |
{ |
{ |
FD_ZERO(&ensemble_descripteurs); |
FD_ZERO(&ensemble_descripteurs); |
FD_SET((*s_etat_processus).pipe_nombre_injections, |
FD_SET((*s_etat_processus).pipe_nombre_injections, |
Line 3613 scrutation_injection(struct_processus *s
|
Line 3613 scrutation_injection(struct_processus *s
|
================================================================================ |
================================================================================ |
*/ |
*/ |
|
|
inline int test_arret(struct_processus *s_etat_processus) |
int |
|
test_arret(struct_processus *s_etat_processus) |
{ |
{ |
return((int) (*s_etat_processus).var_volatile_requete_arret); |
return((int) (*s_etat_processus).var_volatile_requete_arret); |
} |
} |