version 1.53, 2011/06/21 15:26:35
|
version 1.65, 2011/09/09 12:23:25
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.0.prerelease.2 |
RPL/2 (R) version 4.1.3 |
Copyright (C) 1989-2011 Dr. BERTRAND Joël |
Copyright (C) 1989-2011 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
Line 1318 liberation_threads(struct_processus *s_e
|
Line 1318 liberation_threads(struct_processus *s_e
|
sem_destroy2((*s_etat_processus).semaphore_fork, sem_fork); |
sem_destroy2((*s_etat_processus).semaphore_fork, sem_fork); |
# endif |
# endif |
|
|
|
liberation_contexte_cas(s_etat_processus); |
free(s_etat_processus); |
free(s_etat_processus); |
|
|
s_etat_processus = candidat; |
s_etat_processus = candidat; |
Line 1717 deverrouillage_gestionnaire_signaux()
|
Line 1718 deverrouillage_gestionnaire_signaux()
|
return; |
return; |
} |
} |
|
|
|
#define test_signal(signal) \ |
|
if (signal_test == SIGTEST) { signal_test = signal; return; } |
|
|
void |
void |
interruption1(SIGHANDLER_ARGS) |
interruption1(SIGHANDLER_ARGS) |
{ |
{ |
Line 1728 interruption1(SIGHANDLER_ARGS)
|
Line 1732 interruption1(SIGHANDLER_ARGS)
|
|
|
volatile sig_atomic_t exclusion = 0; |
volatile sig_atomic_t exclusion = 0; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
# ifdef _BROKEN_SIGINFO |
Line 1905 interruption2(SIGHANDLER_ARGS)
|
Line 1910 interruption2(SIGHANDLER_ARGS)
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
# ifdef _BROKEN_SIGINFO |
Line 1990 interruption2(SIGHANDLER_ARGS)
|
Line 1996 interruption2(SIGHANDLER_ARGS)
|
void |
void |
interruption3(SIGHANDLER_ARGS) |
interruption3(SIGHANDLER_ARGS) |
{ |
{ |
pid_t pid; |
pthread_t thread; |
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
static int compteur = 0; |
test_signal(signal); |
|
|
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
|
pid = origine_signal(signal); |
|
# else |
|
pid = (*siginfo).si_pid; |
|
# endif |
|
|
|
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
{ |
{ |
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
Line 2028 interruption3(SIGHANDLER_ARGS)
|
Line 2027 interruption3(SIGHANDLER_ARGS)
|
// Segfault dans une routine interne |
// Segfault dans une routine interne |
if (strncmp(getenv("LANG"), "fr", 2) == 0) |
if (strncmp(getenv("LANG"), "fr", 2) == 0) |
{ |
{ |
printf("+++Système : Violation d'accès (dépassement de pile)\n"); |
printf("+++Système : Violation d'accès\n"); |
} |
} |
else |
else |
{ |
{ |
printf("+++System : Access violation (stack overflow)\n"); |
printf("+++System : Access violation\n"); |
} |
} |
|
|
fflush(stdout); |
fflush(stdout); |
|
|
compteur++; |
(*s_etat_processus).compteur_violation_d_acces++; |
|
|
if (compteur > 1) |
if ((*s_etat_processus).compteur_violation_d_acces > 1) |
{ |
{ |
|
// On vient de récupérer plus d'une erreur de segmentation |
|
// dans le même processus ou le même thread. L'erreur n'est pas |
|
// récupérable et on sort autoritairement du programme. Il peut |
|
// rester des processus orphelins en attente ! |
|
|
|
if (strncmp(getenv("LANG"), "fr", 2) == 0) |
|
{ |
|
printf("+++Système : Violation d'accès, tentative de " |
|
"terminaison de la tâche\n"); |
|
printf(" (defauts multiples)\n"); |
|
} |
|
else |
|
{ |
|
printf("+++System : Access violation, trying to kill task " |
|
"(multiple defaults)\n"); |
|
} |
|
|
|
fflush(stdout); |
|
|
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
exit(EXIT_FAILURE); |
exit(EXIT_FAILURE); |
} |
} |
else |
else |
{ |
{ |
|
// Première erreur de segmentation. On essaie de terminer |
|
// proprement le thread ou le processus. Le signal ne peut être |
|
// envoyé que depuis le même processus. |
|
|
|
if (recherche_thread_principal(getpid(), &thread) == d_vrai) |
|
{ |
|
if (pthread_equal(thread, pthread_self()) != 0) |
|
{ |
|
deverrouillage_gestionnaire_signaux(); |
|
|
|
if ((*s_etat_processus).pid_processus_pere != getpid()) |
|
{ |
|
// On est dans le thread principal d'un processus. |
|
|
|
longjmp(contexte_processus, -1); |
|
} |
|
else |
|
{ |
|
// On est dans le thread principal du processus |
|
// père. |
|
|
|
longjmp(contexte_initial, -1); |
|
} |
|
} |
|
else |
|
{ |
|
// On est dans un thread fils d'un thread principal. |
|
|
|
deverrouillage_gestionnaire_signaux(); |
|
longjmp(contexte_thread, -1); |
|
} |
|
} |
|
|
|
// Là, on ramasse les miettes puisque le thread n'existe plus |
|
// dans la base (corruption de la mémoire). |
|
|
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
longjmp(contexte_initial, -1); |
longjmp(contexte_initial, -1); |
} |
} |
Line 2058 interruption3(SIGHANDLER_ARGS)
|
Line 2112 interruption3(SIGHANDLER_ARGS)
|
void |
void |
interruption4(SIGHANDLER_ARGS) |
interruption4(SIGHANDLER_ARGS) |
{ |
{ |
pid_t pid; |
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
|
pid = origine_signal(signal); |
|
# else |
|
pid = (*siginfo).si_pid; |
|
# endif |
|
|
|
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
{ |
{ |
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
Line 2100 interruption5(SIGHANDLER_ARGS)
|
Line 2147 interruption5(SIGHANDLER_ARGS)
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
# ifdef _BROKEN_SIGINFO |
Line 2166 interruption5(SIGHANDLER_ARGS)
|
Line 2214 interruption5(SIGHANDLER_ARGS)
|
void |
void |
interruption6(SIGHANDLER_ARGS) |
interruption6(SIGHANDLER_ARGS) |
{ |
{ |
pid_t pid; |
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
|
pid = origine_signal(signal); |
|
# else |
|
pid = (*siginfo).si_pid; |
|
# endif |
|
|
|
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
{ |
{ |
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
Line 2198 interruption6(SIGHANDLER_ARGS)
|
Line 2239 interruption6(SIGHANDLER_ARGS)
|
void |
void |
interruption7(SIGHANDLER_ARGS) |
interruption7(SIGHANDLER_ARGS) |
{ |
{ |
pid_t pid; |
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
|
pid = origine_signal(signal); |
|
# else |
|
pid = (*siginfo).si_pid; |
|
# endif |
|
|
|
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
{ |
{ |
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
Line 2239 interruption8(SIGHANDLER_ARGS)
|
Line 2273 interruption8(SIGHANDLER_ARGS)
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
# ifdef _BROKEN_SIGINFO |
Line 2285 interruption8(SIGHANDLER_ARGS)
|
Line 2320 interruption8(SIGHANDLER_ARGS)
|
void |
void |
interruption9(SIGHANDLER_ARGS) |
interruption9(SIGHANDLER_ARGS) |
{ |
{ |
pid_t pid; |
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
|
pid = origine_signal(signal); |
|
# else |
|
pid = (*siginfo).si_pid; |
|
# endif |
|
|
|
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
{ |
{ |
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
Line 2330 interruption10(SIGHANDLER_ARGS)
|
Line 2358 interruption10(SIGHANDLER_ARGS)
|
{ |
{ |
file *fichier; |
file *fichier; |
|
|
pid_t pid; |
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
unsigned char nom[8 + 64 + 1]; |
unsigned char nom[8 + 64 + 1]; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
|
pid = origine_signal(signal); |
|
# else |
|
pid = (*siginfo).si_pid; |
|
# endif |
|
|
|
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
if ((s_etat_processus = recherche_thread(getpid(), pthread_self())) == NULL) |
{ |
{ |
deverrouillage_gestionnaire_signaux(); |
deverrouillage_gestionnaire_signaux(); |
Line 2383 interruption11(SIGHANDLER_ARGS)
|
Line 2404 interruption11(SIGHANDLER_ARGS)
|
|
|
struct_processus *s_etat_processus; |
struct_processus *s_etat_processus; |
|
|
|
test_signal(signal); |
verrouillage_gestionnaire_signaux(); |
verrouillage_gestionnaire_signaux(); |
|
|
# ifdef _BROKEN_SIGINFO |
# ifdef _BROKEN_SIGINFO |