version 1.97, 2019/02/06 14:23:26
|
version 1.99, 2019/02/07 21:44:15
|
Line 3688 instruction_syseval(struct_processus *s_
|
Line 3688 instruction_syseval(struct_processus *s_
|
|
|
fflush(NULL); |
fflush(NULL); |
|
|
|
verrouillage_threads_concurrents(s_etat_processus); |
|
|
pid = fork(); |
pid = fork(); |
|
|
if (pid < 0) |
if (pid < 0) |
Line 3820 instruction_syseval(struct_processus *s_
|
Line 3822 instruction_syseval(struct_processus *s_
|
} |
} |
else |
else |
{ |
{ |
|
deverrouillage_threads_concurrents(s_etat_processus); |
|
|
if (close(pipes_entree[0]) != 0) |
if (close(pipes_entree[0]) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
Line 4025 instruction_syseval(struct_processus *s_
|
Line 4029 instruction_syseval(struct_processus *s_
|
} |
} |
} |
} |
|
|
|
# ifndef SEMAPHORES_NOMMES |
|
if (sem_wait(&((*s_etat_processus).semaphore_fork)) != 0) |
|
# else |
|
if (sem_wait((*s_etat_processus).semaphore_fork) != 0) |
|
# endif |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
do |
do |
{ |
{ |
if (kill(pid, 0) != 0) |
if (kill(pid, 0) != 0) |
{ |
{ |
|
// Le processus n'existe plus. |
break; |
break; |
} |
} |
|
|
Line 4050 instruction_syseval(struct_processus *s_
|
Line 4065 instruction_syseval(struct_processus *s_
|
{ |
{ |
if (errno != EINTR) |
if (errno != EINTR) |
{ |
{ |
# ifndef SEMAPHORES_NOMMES |
|
if (sem_post(&((*s_etat_processus).semaphore_fork)) |
|
!= 0) |
|
# else |
|
if (sem_post((*s_etat_processus).semaphore_fork) |
|
!= 0) |
|
# endif |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
} |
} |
Line 4081 instruction_syseval(struct_processus *s_
|
Line 4084 instruction_syseval(struct_processus *s_
|
} |
} |
} while((!WIFEXITED(status)) && (!WIFSIGNALED(status))); |
} while((!WIFEXITED(status)) && (!WIFSIGNALED(status))); |
|
|
# ifndef SEMAPHORES_NOMMES |
|
while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0) |
|
# else |
|
while(sem_wait((*s_etat_processus).semaphore_fork) != 0) |
|
# endif |
|
{ |
|
if (errno != EINTR) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
} |
|
|
|
if (ios == -1) |
if (ios == -1) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
Line 4217 instruction_syseval(struct_processus *s_
|
Line 4207 instruction_syseval(struct_processus *s_
|
liberation(s_etat_processus, s_objet_temporaire); |
liberation(s_etat_processus, s_objet_temporaire); |
} |
} |
|
|
|
free(arguments); |
|
|
if ((tampon = malloc(sizeof(unsigned char))) == NULL) |
if ((tampon = malloc(sizeof(unsigned char))) == NULL) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
Line 4286 instruction_syseval(struct_processus *s_
|
Line 4278 instruction_syseval(struct_processus *s_
|
return; |
return; |
} |
} |
|
|
free(arguments); |
|
free(tampon); |
free(tampon); |
} |
} |
else |
else |