version 1.123, 2015/01/27 14:18:06
|
version 1.130, 2015/07/21 12:22:15
|
Line 1
|
Line 1
|
|
#define DEBUG_RETURN |
|
#define DEBUG_ERREURS |
|
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.20 |
RPL/2 (R) version 4.1.22 |
Copyright (C) 1989-2015 Dr. BERTRAND Joël |
Copyright (C) 1989-2015 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
Line 1088 instruction_detach(struct_processus *s_e
|
Line 1091 instruction_detach(struct_processus *s_e
|
return; |
return; |
} |
} |
|
|
|
if (pthread_mutex_lock(&((*s_etat_processus).mutex_allocation_buffer)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
fflush(NULL); |
fflush(NULL); |
|
|
/* |
/* |
Line 1099 instruction_detach(struct_processus *s_e
|
Line 1108 instruction_detach(struct_processus *s_e
|
(*s_argument_thread).pid = fork(); |
(*s_argument_thread).pid = fork(); |
deverrouillage_threads_concurrents(s_etat_processus); |
deverrouillage_threads_concurrents(s_etat_processus); |
|
|
|
if (pthread_mutex_unlock(&((*s_etat_processus).mutex_allocation_buffer)) |
|
!= 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
(*s_argument_thread).thread_pere = pthread_self(); |
(*s_argument_thread).thread_pere = pthread_self(); |
(*s_argument_thread).processus_detache = d_vrai; |
(*s_argument_thread).processus_detache = d_vrai; |
|
|
Line 1256 instruction_detach(struct_processus *s_e
|
Line 1272 instruction_detach(struct_processus *s_e
|
* Processus fils |
* Processus fils |
*/ |
*/ |
|
|
|
liberation_queue_signaux(s_etat_processus); |
|
creation_queue_signaux(s_etat_processus); |
|
|
if (lancement_thread_signaux(s_etat_processus) != d_absence_erreur) |
if (lancement_thread_signaux(s_etat_processus) != d_absence_erreur) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
} |
} |
|
|
liberation_queue_signaux(s_etat_processus); |
|
creation_queue_signaux(s_etat_processus); |
|
routine_recursive = 0; |
routine_recursive = 0; |
|
|
(*s_etat_processus).pointeur_signal_lecture = 0; |
(*s_etat_processus).pointeur_signal_lecture = 0; |
Line 2775 instruction_detach(struct_processus *s_e
|
Line 2792 instruction_detach(struct_processus *s_e
|
|
|
closelog(); |
closelog(); |
|
|
liberation_allocateur(s_etat_processus); |
|
retrait_thread(s_etat_processus); |
retrait_thread(s_etat_processus); |
|
|
pthread_mutex_destroy(&((*s_etat_processus).mutex_pile_processus)); |
pthread_mutex_destroy(&((*s_etat_processus).mutex_pile_processus)); |
Line 2802 instruction_detach(struct_processus *s_e
|
Line 2818 instruction_detach(struct_processus *s_e
|
destruction_queue_signaux(s_etat_processus); |
destruction_queue_signaux(s_etat_processus); |
liberation_contexte_cas(s_etat_processus); |
liberation_contexte_cas(s_etat_processus); |
arret_thread_signaux(s_etat_processus); |
arret_thread_signaux(s_etat_processus); |
|
liberation_allocateur(s_etat_processus); |
liberation_allocateur_buffer(s_etat_processus); |
liberation_allocateur_buffer(s_etat_processus); |
|
pthread_mutex_destroy(&((*s_etat_processus).mutex_allocation_buffer)); |
sys_free(s_etat_processus); |
sys_free(s_etat_processus); |
|
|
# ifdef DEBUG_MEMOIRE |
# ifdef DEBUG_MEMOIRE |