--- rpl/src/bibliotheques_externes.c 2010/05/24 10:58:29 1.9 +++ rpl/src/bibliotheques_externes.c 2012/12/18 13:19:34 1.47 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.0.16 - Copyright (C) 1989-2010 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.12 + Copyright (C) 1989-2012 Dr. BERTRAND Joël This file is part of RPL/2. @@ -20,7 +20,7 @@ */ -#include "rpl.conv.h" +#include "rpl-conv.h" static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; @@ -41,9 +41,12 @@ void * chargement_bibliotheque(struct_processus *s_etat_processus, unsigned char *bibliotheque) { - char **(*fonction)(unsigned long *); + char **(*fonction)(unsigned long *, const char *); char *message; + long i; + long nombre_symboles; + struct_rpl_arguments rpl_arguments; struct_liste_chainee *l_element_courant; @@ -52,9 +55,6 @@ chargement_bibliotheque(struct_processus unsigned char **tableau; unsigned char *tampon; - unsigned long nombre_symboles; - unsigned long i; - void *descripteur_bibliotheque; void (*onloading)(struct_rpl_arguments *); @@ -162,32 +162,22 @@ chargement_bibliotheque(struct_processus } # ifndef SEMAPHORES_NOMMES - if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return(NULL); - } + if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) # else - if (sem_post((*s_etat_processus).semaphore_fork) != 0) + if (sem_post((*s_etat_processus).semaphore_fork) != 0) +# endif { (*s_etat_processus).erreur_systeme = d_es_processus; return(NULL); } -# endif (*onloading)(&rpl_arguments); # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) - { - if (errno != EINTR) - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return(NULL); - } - } + while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) == -1) + while(sem_wait((*s_etat_processus).semaphore_fork) != 0) +# endif { if (errno != EINTR) { @@ -195,7 +185,6 @@ chargement_bibliotheque(struct_processus return(NULL); } } -# endif if ((*s_etat_processus).profilage == d_vrai) { @@ -334,6 +323,8 @@ chargement_bibliotheque(struct_processus } } + dlerror(); + if (pthread_mutex_unlock(&mutex) != 0) { (*s_etat_processus).erreur_systeme = d_es_processus; @@ -344,12 +335,24 @@ chargement_bibliotheque(struct_processus * Ajout des symboles externes */ - if ((tableau = (unsigned char **) (*fonction)(&nombre_symboles)) == NULL) + if ((tableau = (unsigned char **) (*fonction)((&nombre_symboles), + d_version_rpl)) == NULL) { + /* + * Nombre symboles : + * 0 : aucun symbole exporté + * >0 : nombre de symboles exportés + * -1 : version de bibliothèque incompatible + */ + if (nombre_symboles == 0) { (*s_etat_processus).erreur_execution = d_ex_aucun_symbole; } + else if (nombre_symboles == -1) + { + (*s_etat_processus).erreur_execution = d_ex_version_bibliotheque; + } else { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; @@ -399,6 +402,7 @@ chargement_bibliotheque(struct_processus strcpy((*s_etat_processus).s_instructions_externes[(*s_etat_processus) .nombre_instructions_externes].nom_bibliotheque, tableau[i]); (*s_etat_processus).nombre_instructions_externes++; + free(tableau[i]); } @@ -577,32 +581,22 @@ retrait_bibliotheque(struct_processus *s } # ifndef SEMAPHORES_NOMMES - if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return(d_erreur); - } + if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) # else - if (sem_post((*s_etat_processus).semaphore_fork) != 0) + if (sem_post((*s_etat_processus).semaphore_fork) != 0) +# endif { (*s_etat_processus).erreur_systeme = d_es_processus; return(d_erreur); } -# endif (*onclosing)(&rpl_arguments); # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) - { - if (errno != EINTR) - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return(d_erreur); - } - } + while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) == -1) + while(sem_wait((*s_etat_processus).semaphore_fork) != 0) +# endif { if (errno != EINTR) { @@ -610,7 +604,6 @@ retrait_bibliotheque(struct_processus *s return(d_erreur); } } -# endif if ((*s_etat_processus).profilage == d_vrai) { @@ -1105,6 +1098,8 @@ execution_fonction_de_bibliotheque(struc } } + dlerror(); + if (pthread_mutex_unlock(&mutex) != 0) { (*s_etat_processus).erreur_systeme = d_es_processus; @@ -1161,32 +1156,22 @@ execution_fonction_de_bibliotheque(struc } # ifndef SEMAPHORES_NOMMES - if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return(d_faux); - } + if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0) # else - if (sem_post((*s_etat_processus).semaphore_fork) != 0) + if (sem_post((*s_etat_processus).semaphore_fork) != 0) +# endif { (*s_etat_processus).erreur_systeme = d_es_processus; return(d_faux); } -# endif (*fonction)(&rpl_arguments); # ifndef SEMAPHORES_NOMMES - while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1) - { - if (errno != EINTR) - { - (*s_etat_processus).erreur_systeme = d_es_processus; - return(d_faux); - } - } + while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0) # else - while(sem_wait((*s_etat_processus).semaphore_fork) == -1) + while(sem_wait((*s_etat_processus).semaphore_fork) != 0) +# endif { if (errno != EINTR) { @@ -1194,7 +1179,6 @@ execution_fonction_de_bibliotheque(struc return(d_faux); } } -# endif if ((*s_etat_processus).profilage == d_vrai) { @@ -1650,7 +1634,6 @@ tri_base_symboles_externes(struct_proces do { indice_i = indice_j; - terminaison_boucle_3 = d_faux; do @@ -1744,7 +1727,7 @@ tri_base_symboles_externes(struct_proces indice_i++; } while((unsigned long) (indice_i + 1) < - (*s_etat_processus).nombre_variables); + (*s_etat_processus).nombre_instructions_externes); return; }