version 1.137, 2017/08/03 17:17:43
|
version 1.149, 2021/03/13 12:50:39
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.28 |
RPL/2 (R) version 4.1.33 |
Copyright (C) 1989-2017 Dr. BERTRAND Joël |
Copyright (C) 1989-2021 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 106 initialisation_allocateur(struct_process
|
Line 106 initialisation_allocateur(struct_process
|
(*s_etat_processus).pointeur_int = 0; |
(*s_etat_processus).pointeur_int = 0; |
(*s_etat_processus).pointeur_mat = 0; |
(*s_etat_processus).pointeur_mat = 0; |
(*s_etat_processus).pointeur_nom = 0; |
(*s_etat_processus).pointeur_nom = 0; |
|
(*s_etat_processus).pointeur_rec = 0; |
(*s_etat_processus).pointeur_rel = 0; |
(*s_etat_processus).pointeur_rel = 0; |
(*s_etat_processus).pointeur_tab = 0; |
(*s_etat_processus).pointeur_tab = 0; |
(*s_etat_processus).pointeur_vec = 0; |
(*s_etat_processus).pointeur_vec = 0; |
Line 141 liberation_allocateur(struct_processus *
|
Line 142 liberation_allocateur(struct_processus *
|
free((*s_etat_processus).objets_mat[i++])); |
free((*s_etat_processus).objets_mat[i++])); |
for(i = 0; i < (*s_etat_processus).pointeur_nom; |
for(i = 0; i < (*s_etat_processus).pointeur_nom; |
free((*s_etat_processus).objets_nom[i++])); |
free((*s_etat_processus).objets_nom[i++])); |
|
for(i = 0; i < (*s_etat_processus).pointeur_rec; |
|
free((*s_etat_processus).objets_rec[i++])); |
for(i = 0; i < (*s_etat_processus).pointeur_rel; |
for(i = 0; i < (*s_etat_processus).pointeur_rel; |
free((*s_etat_processus).objets_rel[i++])); |
free((*s_etat_processus).objets_rel[i++])); |
for(i = 0; i < (*s_etat_processus).pointeur_tab; |
for(i = 0; i < (*s_etat_processus).pointeur_tab; |
Line 623 allocation(struct_processus *s_etat_proc
|
Line 626 allocation(struct_processus *s_etat_proc
|
break; |
break; |
} |
} |
|
|
|
case REC : |
|
{ |
|
if ((*s_etat_processus).pointeur_rec > 0) |
|
{ |
|
(*s_objet).objet = (*s_etat_processus).objets_rec |
|
[--(*s_etat_processus).pointeur_rec]; |
|
} |
|
else |
|
{ |
|
if (((*s_objet).objet = malloc(sizeof(struct_record))) |
|
== NULL) |
|
{ |
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
|
free(s_objet); |
|
return(NULL); |
|
} |
|
} |
|
|
|
break; |
|
} |
|
|
case REL : |
case REL : |
{ |
{ |
if ((*s_etat_processus).pointeur_rel > 0) |
if ((*s_etat_processus).pointeur_rel > 0) |
Line 1273 liberation(struct_processus *s_etat_proc
|
Line 1298 liberation(struct_processus *s_etat_proc
|
break; |
break; |
} |
} |
|
|
|
case REC : |
|
{ |
|
liberation(s_etat_processus, |
|
(*((struct_record *) (*s_objet).objet)).noms); |
|
liberation(s_etat_processus, |
|
(*((struct_record *) (*s_objet).objet)).donnees); |
|
|
|
if (decrementation_atomique(s_objet) > 0) |
|
{ |
|
return; |
|
} |
|
|
|
if ((*s_etat_processus).pointeur_rec < TAILLE_CACHE) |
|
{ |
|
(*s_etat_processus).objets_rec |
|
[(*s_etat_processus).pointeur_rec++] = (*s_objet).objet; |
|
} |
|
else |
|
{ |
|
free((struct_record *) ((*s_objet).objet)); |
|
} |
|
|
|
break; |
|
} |
|
|
case REL : |
case REL : |
{ |
{ |
if (decrementation_atomique(s_objet) > 0) |
if (decrementation_atomique(s_objet) > 0) |
Line 2434 copie_objet(struct_processus *s_etat_pro
|
Line 2484 copie_objet(struct_processus *s_etat_pro
|
break; |
break; |
} |
} |
|
|
|
case REC : |
|
{ |
|
if (type != 'P') |
|
{ |
|
if ((s_nouvel_objet = allocation(s_etat_processus, REC)) |
|
== NULL) |
|
{ |
|
return(NULL); |
|
} |
|
|
|
if (((*((struct_record *) (*s_nouvel_objet).objet)).noms = |
|
copie_objet(s_etat_processus, (*((struct_record *) |
|
(*s_objet).objet)).noms, 'P')) == NULL) |
|
{ |
|
return(NULL); |
|
} |
|
|
|
if (((*((struct_record *) (*s_nouvel_objet).objet)).donnees = |
|
copie_objet(s_etat_processus, (*((struct_record *) |
|
(*s_objet).objet)).donnees, type)) == NULL) |
|
{ |
|
return(NULL); |
|
} |
|
} |
|
else |
|
{ |
|
incrementation_atomique(s_objet); |
|
(*((struct_record *) (*s_objet).objet)).noms = |
|
copie_objet(s_etat_processus, (*((struct_record *) |
|
(*s_objet).objet)).noms, 'P'); |
|
(*((struct_record *) (*s_objet).objet)).donnees = |
|
copie_objet(s_etat_processus, (*((struct_record *) |
|
(*s_objet).objet)).donnees, 'P'); |
|
|
|
return(s_objet); |
|
} |
|
|
|
break; |
|
} |
|
|
case REL : |
case REL : |
{ |
{ |
if (type != 'O') |
if (type != 'O') |
Line 2984 copie_etat_processus(struct_processus *s
|
Line 3074 copie_etat_processus(struct_processus *s
|
return(NULL); |
return(NULL); |
} |
} |
|
|
|
|
|
if (pthread_mutex_lock(&((*s_etat_processus).mutex_interruptions)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return(NULL); |
|
} |
|
|
|
if (pthread_mutex_lock(&((*s_etat_processus).mutex_signaux)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return(NULL); |
|
} |
|
|
(*s_nouvel_etat_processus) = (*s_etat_processus); |
(*s_nouvel_etat_processus) = (*s_etat_processus); |
|
|
|
if (pthread_mutex_unlock(&((*s_etat_processus).mutex_signaux)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return(NULL); |
|
} |
|
|
|
if (pthread_mutex_unlock(&((*s_etat_processus).mutex_interruptions)) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return(NULL); |
|
} |
|
|
// On réinitialise les allocateurs. |
// On réinitialise les allocateurs. |
|
|
pthread_mutexattr_init(&attributs_mutex); |
pthread_mutexattr_init(&attributs_mutex); |
Line 3851 debug_memoire_ajout(size_t taille, const
|
Line 3966 debug_memoire_ajout(size_t taille, const
|
sizeof(unsigned char))) == NULL) |
sizeof(unsigned char))) == NULL) |
{ |
{ |
pthread_mutex_unlock(&mutex_allocation); |
pthread_mutex_unlock(&mutex_allocation); |
|
|
|
uprintf("[%d-%llu] ILLEGAL POINTER (malloc) $%016X\n", |
|
getpid(), (unsigned long long) pthread_self(), NULL); |
|
# ifdef __BACKTRACE |
|
BACKTRACE(PROFONDEUR_PILE); |
|
# endif |
|
|
return(NULL); |
return(NULL); |
} |
} |
|
|
Line 3911 debug_memoire_modification(void *pointeu
|
Line 4033 debug_memoire_modification(void *pointeu
|
{ |
{ |
pthread_mutex_unlock(&mutex_allocation); |
pthread_mutex_unlock(&mutex_allocation); |
|
|
uprintf("[%d-%llu] ILLEGAL POINTER (realloc)\n", |
uprintf("[%d-%llu] ILLEGAL POINTER (realloc) $%016X\n", |
getpid(), (unsigned long long) pthread_self()); |
getpid(), (unsigned long long) pthread_self(), |
|
pointeur); |
# ifdef __BACKTRACE |
# ifdef __BACKTRACE |
BACKTRACE(PROFONDEUR_PILE); |
BACKTRACE(PROFONDEUR_PILE); |
# endif |
# endif |
Line 4008 debug_memoire_retrait(void *pointeur)
|
Line 4131 debug_memoire_retrait(void *pointeur)
|
|
|
if (element_courant == NULL) |
if (element_courant == NULL) |
{ |
{ |
uprintf("[%d-%llu] ILLEGAL POINTER (free)\n", |
uprintf("[%d-%llu] ILLEGAL POINTER (free) $%016X\n", |
getpid(), (unsigned long long) pthread_self()); |
getpid(), (unsigned long long) pthread_self(), pointeur); |
# ifdef __BACKTRACE |
# ifdef __BACKTRACE |
BACKTRACE(PROFONDEUR_PILE); |
BACKTRACE(PROFONDEUR_PILE); |
# endif |
# endif |
Line 4126 debug_memoire_verification()
|
Line 4249 debug_memoire_verification()
|
} |
} |
|
|
pid_t |
pid_t |
debug_fork() |
debug_fork(struct_processus *s_etat_processus) |
{ |
{ |
pid_t pid; |
pid_t pid; |
|
|