version 1.68, 2013/02/26 19:56:16
|
version 1.93, 2016/03/01 22:12:34
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.12 |
RPL/2 (R) version 4.1.25 |
Copyright (C) 1989-2013 Dr. BERTRAND Joël |
Copyright (C) 1989-2016 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 233 instruction_spawn(struct_processus *s_et
|
Line 233 instruction_spawn(struct_processus *s_et
|
return; |
return; |
} |
} |
|
|
if (pipe((*s_argument_thread).pipe_nombre_interruptions_attente) != 0) |
if (pipe((*s_argument_thread).pipe_nombre_elements_attente) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
Line 251 instruction_spawn(struct_processus *s_et
|
Line 251 instruction_spawn(struct_processus *s_et
|
return; |
return; |
} |
} |
|
|
if (pipe((*s_argument_thread).pipe_nombre_objets_attente) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
|
if (pipe((*s_argument_thread).pipe_injections) != 0) |
if (pipe((*s_argument_thread).pipe_injections) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
Line 293 instruction_spawn(struct_processus *s_et
|
Line 287 instruction_spawn(struct_processus *s_et
|
|
|
(*s_nouvel_etat_processus).pipe_donnees = |
(*s_nouvel_etat_processus).pipe_donnees = |
(*s_argument_thread).pipe_objets[1]; |
(*s_argument_thread).pipe_objets[1]; |
(*s_nouvel_etat_processus).pipe_nombre_objets_attente = |
(*s_nouvel_etat_processus).pipe_nombre_elements_attente = |
(*s_argument_thread).pipe_nombre_objets_attente[1]; |
(*s_argument_thread).pipe_nombre_elements_attente[1]; |
(*s_nouvel_etat_processus).pipe_interruptions = |
(*s_nouvel_etat_processus).pipe_interruptions = |
(*s_argument_thread).pipe_interruptions[1]; |
(*s_argument_thread).pipe_interruptions[1]; |
(*s_nouvel_etat_processus).pipe_nombre_interruptions_attente = |
|
(*s_argument_thread).pipe_nombre_interruptions_attente[1]; |
|
(*s_nouvel_etat_processus).pipe_injections = |
(*s_nouvel_etat_processus).pipe_injections = |
(*s_argument_thread).pipe_injections[0]; |
(*s_argument_thread).pipe_injections[0]; |
(*s_nouvel_etat_processus).pipe_nombre_injections = |
(*s_nouvel_etat_processus).pipe_nombre_injections = |
Line 407 instruction_spawn(struct_processus *s_et
|
Line 399 instruction_spawn(struct_processus *s_et
|
attente.tv_sec = 0; |
attente.tv_sec = 0; |
attente.tv_nsec = GRANULARITE_us * 1000; |
attente.tv_nsec = GRANULARITE_us * 1000; |
|
|
|
if (pthread_mutex_lock(&((*s_argument_thread).mutex)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
while((*s_argument_thread).thread_actif == d_faux) |
while((*s_argument_thread).thread_actif == d_faux) |
{ |
{ |
scrutation_interruptions(s_etat_processus); |
scrutation_interruptions(s_etat_processus); |
|
|
|
if (pthread_mutex_unlock(&((*s_argument_thread).mutex)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
nanosleep(&attente, NULL); |
nanosleep(&attente, NULL); |
|
|
|
if (pthread_mutex_lock(&((*s_argument_thread).mutex)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
INCR_GRANULARITE(attente.tv_nsec); |
INCR_GRANULARITE(attente.tv_nsec); |
} |
} |
|
|
|
if (pthread_mutex_unlock(&((*s_argument_thread).mutex)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
if (pthread_attr_destroy(&attributs) != 0) |
if (pthread_attr_destroy(&attributs) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
Line 471 instruction_spawn(struct_processus *s_et
|
Line 489 instruction_spawn(struct_processus *s_et
|
return; |
return; |
} |
} |
|
|
if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0) |
if (pthread_mutex_lock(&((*s_etat_processus).mutex_pile_processus)) != 0) |
{ |
{ |
pthread_mutex_unlock(&((*s_nouvel_etat_processus).mutex)); |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
} |
} |
Line 502 instruction_spawn(struct_processus *s_et
|
Line 519 instruction_spawn(struct_processus *s_et
|
(*(*l_element_courant).donnee).objet)).thread) |
(*(*l_element_courant).donnee).objet)).thread) |
.tid, (*s_argument_thread).tid) != 0) |
.tid, (*s_argument_thread).tid) != 0) |
{ |
{ |
if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0) |
scrutation_injection(s_etat_processus); |
|
|
|
if (pthread_mutex_lock(&((*s_etat_processus) |
|
.mutex_interruptions)) != 0) |
{ |
{ |
|
pthread_mutex_unlock(&((*s_etat_processus) |
|
.mutex_pile_processus)); |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
} |
} |
|
|
scrutation_injection(s_etat_processus); |
|
|
|
if ((*s_etat_processus).nombre_interruptions_non_affectees |
if ((*s_etat_processus).nombre_interruptions_non_affectees |
!= 0) |
!= 0) |
{ |
{ |
affectation_interruptions_logicielles(s_etat_processus); |
affectation_interruptions_logicielles(s_etat_processus); |
} |
} |
|
|
|
if (pthread_mutex_unlock(&((*s_etat_processus) |
|
.mutex_interruptions)) != 0) |
|
{ |
|
pthread_mutex_unlock(&((*s_etat_processus) |
|
.mutex_pile_processus)); |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
if ((*s_etat_processus).nombre_interruptions_en_queue != 0) |
if ((*s_etat_processus).nombre_interruptions_en_queue != 0) |
{ |
{ |
traitement_interruptions_logicielles(s_etat_processus); |
traitement_interruptions_logicielles(s_etat_processus); |
} |
} |
|
|
|
if (pthread_mutex_unlock(&((*s_etat_processus) |
|
.mutex_pile_processus)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
nanosleep(&attente, NULL); |
nanosleep(&attente, NULL); |
INCR_GRANULARITE(attente.tv_nsec); |
INCR_GRANULARITE(attente.tv_nsec); |
|
|
if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0) |
if (pthread_mutex_lock(&((*s_etat_processus) |
|
.mutex_pile_processus)) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
Line 544 instruction_spawn(struct_processus *s_et
|
Line 581 instruction_spawn(struct_processus *s_et
|
(struct_liste_chainee **) &((*s_etat_processus) |
(struct_liste_chainee **) &((*s_etat_processus) |
.l_base_pile_processus), s_objet_systeme) == d_erreur) |
.l_base_pile_processus), s_objet_systeme) == d_erreur) |
{ |
{ |
pthread_mutex_unlock(&((*s_etat_processus).mutex)); |
pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus)); |
return; |
return; |
} |
} |
|
|
if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0) |
if (pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus)) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
Line 1276 instruction_smphrtrydecr(struct_processu
|
Line 1313 instruction_smphrtrydecr(struct_processu
|
return; |
return; |
} |
} |
|
|
horodatage.tv_sec += (*((integer8 *) (*s_objet_argument_1).objet)); |
horodatage.tv_sec += (time_t) (*((integer8 *) |
|
(*s_objet_argument_1).objet)); |
} |
} |
else |
else |
{ |
{ |
Line 1290 instruction_smphrtrydecr(struct_processu
|
Line 1328 instruction_smphrtrydecr(struct_processu
|
} |
} |
|
|
partie_entiere = floor((*((real8 *) (*s_objet_argument_1).objet))); |
partie_entiere = floor((*((real8 *) (*s_objet_argument_1).objet))); |
horodatage.tv_sec += partie_entiere; |
horodatage.tv_sec += (time_t) partie_entiere; |
horodatage.tv_usec += ((suseconds_t) ((*((real8 *) |
horodatage.tv_usec += ((suseconds_t) ((*((real8 *) |
(*s_objet_argument_1).objet)) - partie_entiere)) * 1000000; |
(*s_objet_argument_1).objet)) - partie_entiere)) * 1000000; |
|
|
Line 1647 instruction_svd(struct_processus *s_etat
|
Line 1685 instruction_svd(struct_processus *s_etat
|
|
|
struct_vecteur s_vecteur; |
struct_vecteur s_vecteur; |
|
|
unsigned long i; |
integer8 i; |
unsigned long j; |
integer8 j; |
|
|
(*s_etat_processus).erreur_execution = d_ex; |
(*s_etat_processus).erreur_execution = d_ex; |
|
|
Line 1740 instruction_svd(struct_processus *s_etat
|
Line 1778 instruction_svd(struct_processus *s_etat
|
.nombre_lignes; |
.nombre_lignes; |
|
|
if (((*((struct_matrice *) (*s_objet_resultat_2).objet)).tableau = |
if (((*((struct_matrice *) (*s_objet_resultat_2).objet)).tableau = |
malloc((*((struct_matrice *) (*s_objet_resultat_2).objet)) |
malloc(((size_t) (*((struct_matrice *) (*s_objet_resultat_2) |
.nombre_lignes * sizeof(real8 *))) == NULL) |
.objet)).nombre_lignes) * sizeof(real8 *))) == NULL) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
return; |
return; |
Line 1751 instruction_svd(struct_processus *s_etat
|
Line 1789 instruction_svd(struct_processus *s_etat
|
.nombre_lignes; i++) |
.nombre_lignes; i++) |
{ |
{ |
if ((((real8 **) (*((struct_matrice *) (*s_objet_resultat_2) |
if ((((real8 **) (*((struct_matrice *) (*s_objet_resultat_2) |
.objet)).tableau)[i] = malloc((*((struct_matrice *) |
.objet)).tableau)[i] = malloc(((size_t) |
(*s_objet_resultat_2).objet)).nombre_colonnes * |
(*((struct_matrice *) (*s_objet_resultat_2).objet)) |
sizeof(real8 *))) == NULL) |
.nombre_colonnes) * sizeof(real8 *))) == NULL) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
return; |
return; |
Line 1840 instruction_svd(struct_processus *s_etat
|
Line 1878 instruction_svd(struct_processus *s_etat
|
.nombre_lignes; |
.nombre_lignes; |
|
|
if (((*((struct_matrice *) (*s_objet_resultat_2).objet)).tableau = |
if (((*((struct_matrice *) (*s_objet_resultat_2).objet)).tableau = |
malloc((*((struct_matrice *) (*s_objet_resultat_2).objet)) |
malloc(((size_t) (*((struct_matrice *) (*s_objet_resultat_2) |
.nombre_lignes * sizeof(real8 *))) == NULL) |
.objet)).nombre_lignes) * sizeof(real8 *))) == NULL) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
return; |
return; |
Line 1851 instruction_svd(struct_processus *s_etat
|
Line 1889 instruction_svd(struct_processus *s_etat
|
.nombre_lignes; i++) |
.nombre_lignes; i++) |
{ |
{ |
if ((((real8 **) (*((struct_matrice *) (*s_objet_resultat_2) |
if ((((real8 **) (*((struct_matrice *) (*s_objet_resultat_2) |
.objet)).tableau)[i] = malloc((*((struct_matrice *) |
.objet)).tableau)[i] = malloc(((size_t) |
(*s_objet_resultat_2).objet)).nombre_colonnes * |
(*((struct_matrice *) (*s_objet_resultat_2).objet)) |
sizeof(real8 *))) == NULL) |
.nombre_colonnes) * sizeof(real8 *))) == NULL) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
return; |
return; |