--- rpl/src/instructions_c6.c 2012/05/21 17:25:42 1.40 +++ rpl/src/instructions_c6.c 2022/09/07 13:40:34 1.76 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.1.9 - Copyright (C) 1989-2012 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.34 + Copyright (C) 1989-2021 Dr. BERTRAND Joël This file is part of RPL/2. @@ -140,8 +140,8 @@ instruction_col_fleche(struct_processus struct_objet *s_objet; struct_objet *s_objet_elementaire; - unsigned long i; - unsigned long j; + integer8 i; + integer8 j; (*s_etat_processus).erreur_execution = d_ex; @@ -206,8 +206,8 @@ instruction_col_fleche(struct_processus .nombre_lignes; if (((*((struct_matrice *) (*s_objet_elementaire).objet)).tableau = - malloc((*((struct_matrice *) (*s_objet).objet)) - .nombre_lignes * sizeof(integer8 *))) == NULL) + malloc(((size_t) (*((struct_matrice *) (*s_objet).objet)) + .nombre_lignes) * sizeof(integer8 *))) == NULL) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; return; @@ -257,8 +257,8 @@ instruction_col_fleche(struct_processus .nombre_lignes; if (((*((struct_matrice *) (*s_objet_elementaire).objet)).tableau = - malloc((*((struct_matrice *) (*s_objet).objet)) - .nombre_lignes * sizeof(real8 *))) == NULL) + malloc(((size_t) (*((struct_matrice *) (*s_objet).objet)) + .nombre_lignes) * sizeof(real8 *))) == NULL) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; return; @@ -308,8 +308,8 @@ instruction_col_fleche(struct_processus .nombre_lignes; if (((*((struct_matrice *) (*s_objet_elementaire).objet)).tableau = - malloc((*((struct_matrice *) (*s_objet).objet)) - .nombre_lignes * sizeof(complex16 *))) == NULL) + malloc(((size_t) (*((struct_matrice *) (*s_objet).objet)) + .nombre_lignes) * sizeof(complex16 *))) == NULL) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; return; @@ -590,7 +590,8 @@ instruction_continue(struct_processus *s if ((*s_objet).type == PRC) { - 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; } @@ -610,8 +611,8 @@ instruction_continue(struct_processus *s { if (envoi_signal_processus( (*(*((struct_processus_fils *) - (*s_objet).objet)).thread).pid, rpl_sigcont) - != 0) + (*s_objet).objet)).thread).pid, rpl_sigcont, + d_faux) != 0) { // Le processus est peut-être dans l'état zombie. } @@ -641,7 +642,7 @@ instruction_continue(struct_processus *s (*(*l_element_courant).donnee).objet)).thread) .pid)) { - if (envoi_signal_thread( + if (envoi_signal_thread(s_etat_processus, (*(*((struct_processus_fils *) (*s_objet).objet)).thread).tid, rpl_sigcont) != 0) @@ -653,6 +654,8 @@ instruction_continue(struct_processus *s &((*(*((struct_processus_fils *) (*s_objet).objet)).thread).mutex)) != 0) { + pthread_mutex_unlock(&((*s_etat_processus) + .mutex_pile_processus)); (*s_etat_processus).erreur_systeme = d_es_processus; return; @@ -665,6 +668,8 @@ instruction_continue(struct_processus *s if (pthread_mutex_unlock(&((*(*((struct_processus_fils *) (*s_objet).objet)).thread).mutex)) != 0) { + pthread_mutex_unlock(&((*s_etat_processus) + .mutex_pile_processus)); (*s_etat_processus).erreur_systeme = d_es_processus; return; } @@ -673,7 +678,8 @@ instruction_continue(struct_processus *s l_element_courant = (*l_element_courant).suivant; } - 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; } @@ -842,7 +848,7 @@ creation_table(struct_processus *s_etat_ { struct_objet *s_table; - unsigned long i; + integer8 i; if ((s_table = allocation(s_etat_processus, TBL)) == NULL) { @@ -850,13 +856,13 @@ creation_table(struct_processus *s_etat_ } (*((struct_tableau *) (*s_table).objet)).nombre_elements = - (unsigned long) (*((integer8 *) (*(*dimensions).donnee).objet)); + (*((integer8 *) (*(*dimensions).donnee).objet)); dimensions = (*dimensions).suivant; if (((*((struct_tableau *) (*s_table).objet)).elements = - malloc((*((struct_tableau *) (*s_table).objet)) - .nombre_elements * sizeof(struct_objet *))) == NULL) + malloc(((size_t) (*((struct_tableau *) (*s_table).objet)) + .nombre_elements) * sizeof(struct_objet *))) == NULL) { return(NULL); }