version 1.207, 2013/03/16 11:31:41
|
version 1.270, 2015/06/08 14:11:44
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.13 |
RPL/2 (R) version 4.1.22 |
Copyright (C) 1989-2013 Dr. BERTRAND Joël |
Copyright (C) 1989-2015 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 19
|
Line 19
|
================================================================================ |
================================================================================ |
*/ |
*/ |
|
|
|
|
#ifndef INCLUSION_RPL |
#ifndef INCLUSION_RPL |
#define INCLUSION_RPL |
#define INCLUSION_RPL |
|
|
Line 37
|
Line 38
|
# ifdef OpenBSD |
# ifdef OpenBSD |
# define _BSD_SOURCE |
# define _BSD_SOURCE |
# endif |
# endif |
|
|
|
# ifdef FreeBSD |
|
# define __BSD_VISIBLE 1 |
|
# endif |
#endif |
#endif |
|
|
#ifdef OS2 |
#ifdef OS2 |
Line 55
|
Line 60
|
# define sched_yield(arg) |
# define sched_yield(arg) |
#endif |
#endif |
|
|
|
#ifdef CYGWIN |
|
# define SA_ONSTACK 0 |
|
#endif |
|
|
|
|
/* |
/* |
================================================================================ |
================================================================================ |
Line 72
|
Line 81
|
#include <errno.h> |
#include <errno.h> |
#include <stdarg.h> |
#include <stdarg.h> |
#include <poll.h> |
#include <poll.h> |
|
#include <signal.h> |
|
|
#ifndef RPLARGS |
#ifndef RPLARGS |
# include <sys/mman.h> |
# include <sys/mman.h> |
Line 153
|
Line 163
|
# endif |
# endif |
|
|
# include <setjmp.h> |
# include <setjmp.h> |
# include <signal.h> |
|
# include <termios.h> |
# include <termios.h> |
# include <time.h> |
# include <time.h> |
# include <unistd.h> |
# include <unistd.h> |
Line 163
|
Line 172
|
# include "readline.h" |
# include "readline.h" |
# include "termcap.h" |
# include "termcap.h" |
# include "iconv.h" |
# include "iconv.h" |
|
# include "zlib.h" |
|
|
# include "openssl/evp.h" |
# include "openssl/evp.h" |
# ifndef OPENSSL_NO_MD2 |
# ifndef OPENSSL_NO_MD2 |
Line 206
|
Line 216
|
# undef HAVE_STACK_OVERFLOW_RECOVERY |
# undef HAVE_STACK_OVERFLOW_RECOVERY |
# endif |
# endif |
|
|
# define HAVE_INLINE |
|
# define GSL_RANGE_CHECK_OFF |
# define GSL_RANGE_CHECK_OFF |
# include "gsl/gsl_cdf.h" |
# include "gsl/gsl_cdf.h" |
# include "gsl/gsl_cblas.h" |
# include "gsl/gsl_cblas.h" |
Line 312 enum signaux_rpl
|
Line 321 enum signaux_rpl
|
#ifndef RPLARGS |
#ifndef RPLARGS |
typedef struct queue_signaux |
typedef struct queue_signaux |
{ |
{ |
# ifndef IPCS_SYSV |
|
# ifndef SEMAPHORES_NOMMES |
|
sem_t semaphore; |
|
sem_t signalisation; |
|
# endif |
|
# else |
|
sem_t semaphore; |
|
sem_t signalisation; |
|
# endif |
|
|
|
volatile int pointeur_lecture; |
volatile int pointeur_lecture; |
volatile int pointeur_ecriture; |
volatile int pointeur_ecriture; |
pthread_t thread_signaux; |
|
volatile logical1 requete_arret; |
volatile logical1 requete_arret; |
|
|
|
pthread_t thread_signaux; |
|
|
volatile struct |
volatile struct |
{ |
{ |
pid_t pid; |
pid_t pid; |
enum signaux_rpl signal; |
enum signaux_rpl signal; |
} queue[LONGUEUR_QUEUE_SIGNAUX]; |
} queue[LONGUEUR_QUEUE_SIGNAUX]; |
|
|
|
# ifdef OS2 |
|
sem_t semaphore; |
|
sem_t signalisation; |
|
sem_t arret_signalisation; |
|
# endif |
} struct_queue_signaux; |
} struct_queue_signaux; |
|
|
__EXTERN__ struct_queue_signaux *s_queue_signaux; |
__EXTERN__ struct_queue_signaux *s_queue_signaux; |
__EXTERN__ int f_queue_signaux; |
__EXTERN__ int f_queue_signaux; |
|
|
# ifdef SEMAPHORES_NOMMES |
# ifndef OS2 |
__EXTERN__ sem_t *semaphore_queue_signaux; |
__EXTERN__ sem_t *semaphore_queue_signaux; |
__EXTERN__ sem_t *semaphore_signalisation; |
__EXTERN__ sem_t *semaphore_signalisation; |
|
__EXTERN__ sem_t *semaphore_arret_signalisation; |
# endif |
# endif |
#endif |
#endif |
|
|
#ifdef OS2 |
|
# define readline(s) readline_wrapper(s) |
|
unsigned char *readline_wrapper(unsigned char *s); |
|
#endif |
|
|
|
#if ! defined(UNION_SEMUN) && defined(IPCS_SYSV) |
#if ! defined(UNION_SEMUN) && defined(IPCS_SYSV) |
union semun |
union semun |
{ |
{ |
Line 366 union semun
|
Line 368 union semun
|
# define SIGSTKSZ 65536 |
# define SIGSTKSZ 65536 |
#endif |
#endif |
|
|
|
|
/* |
/* |
================================================================================ |
================================================================================ |
SÉMAPHORES |
SÉMAPHORES |
Line 373 union semun
|
Line 376 union semun
|
*/ |
*/ |
|
|
#ifdef IPCS_SYSV |
#ifdef IPCS_SYSV |
|
# ifdef DEBUG_SEMAPHORES |
|
# define sem_wait(a) ({ int value; sem_getvalue(a, &value); \ |
|
uprintf("[%d-%llu] Semaphore %s (%p) "\ |
|
"waiting at %s() " \ |
|
"line #%d\n", (int) getpid(), (unsigned long long) i\ |
|
pthread_self(), \ |
|
#a, a, __FUNCTION__, __LINE__), fflush(stdout); \ |
|
if (value > 1) BUG(1, uprintf("Value %d\n", value)); \ |
|
sem_wait_SysV(a); }) |
|
# define sem_post(a) ({ int value; sem_getvalue(a, &value); \ |
|
uprintf("[%d-%llu] Semaphore %s (%p) "\ |
|
"posting at %s() " \ |
|
"line #%d\n", (int) getpid(), (unsigned long long) \ |
|
pthread_self(), \ |
|
#a, a, __FUNCTION__, __LINE__), fflush(stdout); \ |
|
if (value > 0) BUG(1, uprintf("Value %d\n", value)); \ |
|
sem_post_SysV(a); }) |
|
# define sem_destroy(a) ({ int value; sem_getvalue(a, &value); \ |
|
if (value == 0) BUG(1, uprintf("Value %d\n", value)); \ |
|
sem_destroy_SysV(a); }) |
|
# else |
|
# define sem_destroy(a) sem_destroy_SysV(a) |
|
# define sem_wait(a) sem_wait_SysV(a) |
|
# define sem_post(a) sem_post_SysV(a) |
|
# endif |
|
|
# define sem_init(a, b, c) sem_init_SysV(a, b, c) |
# define sem_init(a, b, c) sem_init_SysV(a, b, c) |
# define sem_destroy(a) sem_destroy_SysV(a) |
|
# define sem_wait(a) sem_wait_SysV(a) |
|
# define sem_trywait(a) sem_trywait_SysV(a) |
# define sem_trywait(a) sem_trywait_SysV(a) |
# define sem_timedwait(a, b) sem_timedwait_SysV(a, b) |
# define sem_timedwait(a, b) sem_timedwait_SysV(a, b) |
# define sem_post(a) sem_post_SysV(a) |
|
# define sem_getvalue(a, b) sem_getvalue_SysV(a, b) |
# define sem_getvalue(a, b) sem_getvalue_SysV(a, b) |
# define sem_open(...) sem_open_SysV(__VA_ARGS__) |
# define sem_open(...) sem_open_SysV(__VA_ARGS__) |
# define sem_close(a) sem_close_SysV(a) |
# define sem_close(a) sem_close_SysV(a) |
# define sem_unlink(a) sem_unlink_SysV(a) |
# define sem_unlink(a) sem_unlink_SysV(a) |
|
#else |
|
# ifdef DEBUG_SEMAPHORES |
|
# define sem_wait(a) ({ int value; sem_getvalue(a, &value); \ |
|
uprintf("[%d-%llu] Semaphore %s (%p) "\ |
|
"waiting at %s() " \ |
|
"line #%d\n", (int) getpid(), (unsigned long long) \ |
|
pthread_self(), \ |
|
#a, a, __FUNCTION__, __LINE__), fflush(stdout); \ |
|
if (value > 1) BUG(1, uprintf("Value %d\n", value)); sem_wait(a); }) |
|
# define sem_post(a) ({ int value; sem_getvalue(a, &value); \ |
|
uprintf("[%d-%llu] Semaphore %s (%p) "\ |
|
"posting at %s() " \ |
|
"line #%d\n", (int) getpid(), (unsigned long long) \ |
|
pthread_self(), \ |
|
#a, a, __FUNCTION__, __LINE__), fflush(stdout); \ |
|
if (value > 0) BUG(1, uprintf("Value %d\n", value)); sem_post(a); }) |
|
# define sem_destroy(a) ({ int value; sem_getvalue(a, &value); \ |
|
if (value == 0) BUG(1, uprintf("Value %d\n", value)); \ |
|
sem_destroy(a); }) |
|
# endif |
#endif |
#endif |
|
|
|
|
Line 453 union semun
|
Line 499 union semun
|
#ifndef RPLARGS |
#ifndef RPLARGS |
# ifdef SEMAPHORES_NOMMES |
# ifdef SEMAPHORES_NOMMES |
# define LONGUEUR_NOM_SEMAPHORE 64 |
# define LONGUEUR_NOM_SEMAPHORE 64 |
# endif |
|
|
|
# ifdef SEMAPHORES_NOMMES |
|
# define __PTR__ * |
# define __PTR__ * |
# else |
# else |
# define __PTR__ |
# define __PTR__ |
Line 471 union semun
|
Line 514 union semun
|
|
|
__EXTERN__ pid_t pid_processus_pere; |
__EXTERN__ pid_t pid_processus_pere; |
|
|
# ifdef SEMAPHORES_NOMMES |
|
__EXTERN__ pthread_mutex_t mutex_sem __STATIC_MUTEX_INITIALIZATION__; |
|
# endif |
|
|
|
__EXTERN__ pthread_mutex_t mutex_liste_threads |
__EXTERN__ pthread_mutex_t mutex_liste_threads |
__STATIC_MUTEX_INITIALIZATION__; |
__STATIC_MUTEX_INITIALIZATION__; |
__EXTERN__ pthread_mutex_t mutex_gestionnaires_signaux_atomique |
|
__STATIC_MUTEX_INITIALIZATION__; |
|
__EXTERN__ pthread_mutex_t mutex_creation_variable_partagee |
__EXTERN__ pthread_mutex_t mutex_creation_variable_partagee |
__STATIC_MUTEX_INITIALIZATION__; |
__STATIC_MUTEX_INITIALIZATION__; |
__EXTERN__ pthread_mutex_t mutex_sections_critiques; |
__EXTERN__ pthread_mutex_t mutex_sections_critiques; |
__EXTERN__ pthread_mutex_t mutex_liste_variables_partagees; |
__EXTERN__ pthread_mutex_t mutex_liste_variables_partagees; |
|
__EXTERN__ pthread_mutex_t mutex_sem __STATIC_MUTEX_INITIALIZATION__; |
__EXTERN__ sem_t __PTR__ semaphore_gestionnaires_signaux; |
|
|
|
__EXTERN__ volatile int routine_recursive; |
__EXTERN__ volatile int routine_recursive; |
#endif |
|
|
|
#ifdef SEMAPHORES_NOMMES |
# define SEM_FORK 0 |
#define SEM_FORK 0 |
# define SEM_QUEUE 1 |
#define SEM_QUEUE 1 |
# define SEM_SIGNALISATION 2 |
#define SEM_SIGNAUX 2 |
# define SEM_ARRET_SIGNALISATION 3 |
#define SEM_SIGNALISATION 3 |
|
sem_t *sem_init2(unsigned int valeur, pid_t pid, int ordre); |
sem_t *sem_init2(unsigned int valeur, pid_t pid, int ordre); |
sem_t *sem_init3(unsigned int valeur, pid_t pid, pthread_t tid, int ordre); |
sem_t *sem_init3(unsigned int valeur, pid_t pid, pthread_t tid, int ordre); |
int sem_destroy2(sem_t *semaphore_p, pid_t pid, int ordre); |
int sem_destroy2(sem_t *semaphore_p, pid_t pid, int ordre); |
int sem_destroy3(sem_t *semaphore_p, pid_t pid, pthread_t tid, int ordre); |
int sem_destroy3(sem_t *semaphore_p, pid_t pid, pthread_t tid, int ordre); |
int sem_getvalue2(sem_t *semaphore, int *valeur); |
int sem_getvalue2(sem_t *semaphore, int *valeur); |
sem_t *sem_open2(pid_t pid, int ordre); |
sem_t *sem_open2(pid_t pid, int ordre); |
|
#endif |
|
|
// Le mutex est là uniquement pour pouvoir émuler le comportement |
// Le mutex est là uniquement pour pouvoir émuler le comportement |
// de sem_getvalue() sur un système comme MacOS X qui ne possède pas |
// de sem_getvalue() sur un système comme MacOS X qui ne possède pas |
// cette fonction. |
// cette fonction. |
|
|
|
#ifdef Darwin |
#define sem_getvalue(semaphore, value) sem_getvalue2(semaphore, value) |
#define sem_getvalue(semaphore, value) sem_getvalue2(semaphore, value) |
#define sem_post(semaphore) \ |
#define sem_post(semaphore) \ |
({ int r; pthread_mutex_lock(&mutex_sem); \ |
({ int r; pthread_mutex_lock(&mutex_sem); \ |
Line 530 sem_t *sem_open2(pid_t pid, int ordre);
|
Line 567 sem_t *sem_open2(pid_t pid, int ordre);
|
stderr, __VA_ARGS__) |
stderr, __VA_ARGS__) |
#define fprintf(flux, ...) transliterated_fprintf(s_etat_processus, \ |
#define fprintf(flux, ...) transliterated_fprintf(s_etat_processus, \ |
flux, __VA_ARGS__) |
flux, __VA_ARGS__) |
#define uprintf(...) transliterated_fprintf(NULL, \ |
#define uprintf(...) std_fprintf(stderr, __VA_ARGS__) |
stderr, __VA_ARGS__) |
#define ufprintf(flux, ...) std_fprintf(flux, __VA_ARGS__) |
#define ufprintf(flux, ...) transliterated_fprintf(NULL, \ |
|
flux, __VA_ARGS__) |
|
|
|
#ifdef SunOS |
#ifdef SunOS |
# define fopen(...) ({ FILE *desc; \ |
# define fopen(...) ({ FILE *desc; \ |
Line 615 sem_t *sem_open2(pid_t pid, int ordre);
|
Line 650 sem_t *sem_open2(pid_t pid, int ordre);
|
{ \ |
{ \ |
for(i = 0; i < nb; i++) \ |
for(i = 0; i < nb; i++) \ |
uprintf(" %s\n", appels[i]); \ |
uprintf(" %s\n", appels[i]); \ |
free(appels); \ |
sys_free(appels); \ |
} \ |
} \ |
else \ |
else \ |
uprintf("Nullified backtrace\n"); \ |
uprintf("Nullified backtrace\n"); \ |
Line 689 pid_t debug_fork();
|
Line 724 pid_t debug_fork();
|
pthread_mutex_unlock(mutex) |
pthread_mutex_unlock(mutex) |
#endif |
#endif |
|
|
#ifdef DEBUG_SEMAPHORES |
|
#define sem_wait(a) ({ int value; sem_getvalue(a, &value); \ |
|
uprintf("[%d-%llu] Semaphore %s (%p) "\ |
|
"waiting at %s() " \ |
|
"line #%d\n", (int) getpid(), (unsigned long long) pthread_self(), \ |
|
#a, a, __FUNCTION__, __LINE__), fflush(stdout); \ |
|
if (value > 1) BUG(1, uprintf("Value %d\n", value)); sem_wait(a); }) |
|
#define sem_post(a) ({ int value; sem_getvalue(a, &value); \ |
|
uprintf("[%d-%llu] Semaphore %s (%p) "\ |
|
"posting at %s() " \ |
|
"line #%d\n", (int) getpid(), (unsigned long long) pthread_self(), \ |
|
#a, a, __FUNCTION__, __LINE__), fflush(stdout); \ |
|
if (value > 0) BUG(1, uprintf("Value %d\n", value)); sem_post(a); }) |
|
#define sem_destroy(a) ({ int value; sem_getvalue(a, &value); \ |
|
if (value == 0) BUG(1, uprintf("Value %d\n", value)); sem_destroy(a); }) |
|
#endif |
|
|
|
|
|
/* |
/* |
================================================================================ |
================================================================================ |
Line 1024 enum t_type { ADR = 0, ALG, BIN, CHN, C
|
Line 1042 enum t_type { ADR = 0, ALG, BIN, CHN, C
|
SLB, SPH, SQL, TBL, VCX, VIN, VRL }; |
SLB, SPH, SQL, TBL, VCX, VIN, VRL }; |
|
|
/* |
/* |
ADR : adresse sur 32 bits (au moins) non signés (unsigned long) |
ADR : adresse sur 64 bits signés. |
Adresse d'une définition à interpréter. |
Adresse d'une définition à interpréter. |
|
|
ALG : expression algébrique (struct_liste_chainee *) |
ALG : expression algébrique (struct_liste_chainee *) |
Line 1036 enum t_type { ADR = 0, ALG, BIN, CHN, C
|
Line 1054 enum t_type { ADR = 0, ALG, BIN, CHN, C
|
Sans objet. |
Sans objet. |
Type C/Fortran : unsigned integer8 |
Type C/Fortran : unsigned integer8 |
|
|
CHN : chaine de caracteres (character*(*), unsigned char *) |
CHN : chaine de caracteres (unsigned char *) |
Sans objet. |
Sans objet. |
|
|
CPL : complexe sur 2*64 bits (complex*16, struct_complexe16 *) |
CPL : complexe sur 2*64 bits (complex*16, struct_complexe16 *) |
Line 1126 typedef struct objet
|
Line 1144 typedef struct objet
|
#ifndef RPLARGS |
#ifndef RPLARGS |
typedef struct fichier |
typedef struct fichier |
{ |
{ |
unsigned long descripteur; |
int descripteur; |
|
|
unsigned char acces; /* S/D/I */ |
unsigned char acces; /* S/D/I */ |
unsigned char binaire; /* Y/N/F */ |
unsigned char binaire; /* Y/N/F */ |
Line 1219 typedef struct bibliotheque
|
Line 1237 typedef struct bibliotheque
|
#ifndef RPLARGS |
#ifndef RPLARGS |
typedef struct descripteur_fichier |
typedef struct descripteur_fichier |
{ |
{ |
unsigned long identifiant; |
int identifiant; |
|
|
unsigned char effacement; |
unsigned char effacement; |
unsigned char type; // C (file *) ou S (sqlite *) |
unsigned char type; // C (file *) ou S (sqlite *) |
Line 1458 typedef struct descripteur_thread
|
Line 1476 typedef struct descripteur_thread
|
int pipe_injections[2]; |
int pipe_injections[2]; |
int pipe_nombre_injections[2]; |
int pipe_nombre_injections[2]; |
int pipe_interruptions[2]; |
int pipe_interruptions[2]; |
int pipe_nombre_objets_attente[2]; |
// pipe_nombre_elements_attente == 0 => initialisation ou terminaison |
int pipe_nombre_interruptions_attente[2]; |
// pipe_nombre_elements_attente == 1 => objet en attente |
|
// pipe_nombre_elements_attente == 2 => interruption en attente |
|
int pipe_nombre_elements_attente[2]; |
int pipe_acquittement[2]; |
int pipe_acquittement[2]; |
|
|
volatile integer8 nombre_objets_dans_pipe; |
volatile integer8 nombre_objets_dans_pipe; |
Line 1542 typedef struct liste_pile_systeme
|
Line 1562 typedef struct liste_pile_systeme
|
A FORALL : NEXT termine une boucle sur un objet. |
A FORALL : NEXT termine une boucle sur un objet. |
*/ |
*/ |
|
|
unsigned long adresse_retour; |
integer8 adresse_retour; |
unsigned long niveau_courant; |
integer8 niveau_courant; |
struct_liste_chainee *pointeur_objet_retour; |
struct_liste_chainee *pointeur_objet_retour; |
} struct_liste_pile_systeme; |
} struct_liste_pile_systeme; |
#endif |
#endif |
Line 1558 typedef struct liste_pile_systeme
|
Line 1578 typedef struct liste_pile_systeme
|
#ifndef RPLARGS |
#ifndef RPLARGS |
typedef union position_variable |
typedef union position_variable |
{ |
{ |
unsigned long adresse; |
integer8 adresse; |
struct_objet *pointeur; |
struct_objet *pointeur; |
} union_position_variable; |
} union_position_variable; |
|
|
Line 1567 typedef struct variable
|
Line 1587 typedef struct variable
|
unsigned char *nom; |
unsigned char *nom; |
unsigned char origine; // P(rogramme) ou E(valuation) |
unsigned char origine; // P(rogramme) ou E(valuation) |
|
|
unsigned long niveau; |
integer8 niveau; |
|
|
union_position_variable variable_statique; |
union_position_variable variable_statique; |
union_position_variable variable_partagee; |
union_position_variable variable_partagee; |
Line 1592 typedef struct variable_partage
|
Line 1612 typedef struct variable_partage
|
unsigned char *nom; |
unsigned char *nom; |
unsigned char origine; |
unsigned char origine; |
|
|
unsigned long niveau; |
integer8 niveau; |
|
|
union_position_variable variable_partagee; |
union_position_variable variable_partagee; |
|
|
Line 1619 typedef struct variable_statique
|
Line 1639 typedef struct variable_statique
|
// Position de création de la variable statique dans le programme ou dans |
// Position de création de la variable statique dans le programme ou dans |
// l'expression. 'origine' vaut 'P' pour programme ou 'E' pour expression. |
// l'expression. 'origine' vaut 'P' pour programme ou 'E' pour expression. |
|
|
unsigned long niveau; |
integer8 niveau; |
|
|
union_position_variable variable_statique; |
union_position_variable variable_statique; |
|
|
Line 1636 typedef struct variable_statique
|
Line 1656 typedef struct variable_statique
|
|
|
typedef struct vecteur |
typedef struct vecteur |
{ |
{ |
unsigned long taille; |
integer8 taille; |
|
|
unsigned char type; /* C (complex*16), R (real*8), I (integer*8) */ |
unsigned char type; /* C (complex*16), R (real*8), I (integer*8) */ |
|
|
Line 1652 typedef struct vecteur
|
Line 1672 typedef struct vecteur
|
|
|
typedef struct matrice |
typedef struct matrice |
{ |
{ |
unsigned long nombre_lignes; |
integer8 nombre_lignes; |
unsigned long nombre_colonnes; |
integer8 nombre_colonnes; |
|
|
unsigned char type; /* C (complex*16), R (real*8), I (integer*8) */ |
unsigned char type; /* C (complex*16), R (real*8), I (integer*8) */ |
|
|
Line 1669 typedef struct matrice
|
Line 1689 typedef struct matrice
|
|
|
typedef struct tableau |
typedef struct tableau |
{ |
{ |
unsigned long nombre_elements; |
integer8 nombre_elements; |
|
|
struct_objet **elements; |
struct_objet **elements; |
} struct_tableau; |
} struct_tableau; |
Line 1683 typedef struct tableau
|
Line 1703 typedef struct tableau
|
|
|
typedef struct arbre |
typedef struct arbre |
{ |
{ |
struct_objet *objet; |
struct_liste_chainee *feuille; |
|
|
unsigned long nombre_feuilles; |
integer8 nombre_branches; |
struct arbre **feuilles; |
struct arbre **branches; |
} struct_arbre; |
} struct_arbre; |
|
|
|
|
Line 1805 typedef struct arbre_variables_partagees
|
Line 1825 typedef struct arbre_variables_partagees
|
do { \ |
do { \ |
pthread_mutexattr_t attributs_mutex; \ |
pthread_mutexattr_t attributs_mutex; \ |
pthread_mutexattr_init(&attributs_mutex); \ |
pthread_mutexattr_init(&attributs_mutex); \ |
pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_NORMAL); \ |
pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE); \ |
pthread_mutex_init(&(mutex), &attributs_mutex); \ |
pthread_mutex_init(&(mutex), &attributs_mutex); \ |
pthread_mutexattr_destroy(&attributs_mutex); \ |
pthread_mutexattr_destroy(&attributs_mutex); \ |
} while(0) |
} while(0) |
Line 1815 typedef struct tableau_variables
|
Line 1835 typedef struct tableau_variables
|
unsigned char origine; |
unsigned char origine; |
unsigned char *nom; // pointeur sur la struct_variable |
unsigned char *nom; // pointeur sur la struct_variable |
// réelle et non copie de la chaîne |
// réelle et non copie de la chaîne |
unsigned long niveau; |
integer8 niveau; |
|
|
struct_objet *objet; // pointeur sur l'objet et non copie |
struct_objet *objet; // pointeur sur l'objet et non copie |
// de l'objet. |
// de l'objet. |
|
|
logical1 variable_verrouillee; |
logical1 variable_verrouillee; |
logical1 variable_masquee; |
logical1 variable_masquee; |
|
pthread_mutex_t *mutex; |
union_position_variable variable_statique; |
union_position_variable variable_statique; |
union_position_variable variable_partagee; |
union_position_variable variable_partagee; |
} struct_tableau_variables; |
} struct_tableau_variables; |
Line 1866 typedef struct liste_variables_partagees
|
Line 1887 typedef struct liste_variables_partagees
|
} struct_liste_variables_partagees; |
} struct_liste_variables_partagees; |
#endif |
#endif |
|
|
|
|
|
/* |
|
-------------------------------------------------------------------------------- |
|
Structure fonction |
|
-------------------------------------------------------------------------------- |
|
*/ |
|
|
|
#ifndef RPLARGS |
|
typedef struct fonction |
|
{ |
|
unsigned char *nom_fonction; |
|
integer8 nombre_arguments; |
|
|
|
void (*fonction)(struct processus *); |
|
|
|
volatile struct_liste_chainee *prediction_saut; |
|
volatile logical1 prediction_execution; |
|
} struct_fonction; |
|
#endif |
|
|
|
|
|
/* |
|
-------------------------------------------------------------------------------- |
|
Structure buffer |
|
-------------------------------------------------------------------------------- |
|
*/ |
|
|
|
typedef struct buffer |
|
{ |
|
unsigned char *buffer; |
|
|
|
size_t longueur_requise; |
|
int classe; |
|
} struct_buffer; |
|
|
|
|
/* |
/* |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
Structure processus |
Structure processus |
Line 1904 typedef struct processus
|
Line 1961 typedef struct processus
|
unsigned char traitement_cycle_exit; /*N/E/C*/ |
unsigned char traitement_cycle_exit; /*N/E/C*/ |
unsigned char recherche_type; /*Y/N*/ |
unsigned char recherche_type; /*Y/N*/ |
|
|
unsigned long position_courante; |
integer8 position_courante; |
unsigned long longueur_definitions_chainees; |
integer8 longueur_definitions_chainees; |
|
|
/* Pointeurs sur les instructions */ |
/* Pointeurs sur les instructions */ |
|
|
Line 1922 typedef struct processus
|
Line 1979 typedef struct processus
|
struct_liste_chainee *l_base_pile; |
struct_liste_chainee *l_base_pile; |
struct_liste_chainee *l_base_pile_last; |
struct_liste_chainee *l_base_pile_last; |
|
|
unsigned long hauteur_pile_operationnelle; |
integer8 hauteur_pile_operationnelle; |
|
|
/* Piles systemes */ |
/* Piles systemes */ |
|
|
struct_liste_pile_systeme *l_base_pile_systeme; |
struct_liste_pile_systeme *l_base_pile_systeme; |
|
|
unsigned long hauteur_pile_systeme; |
integer8 hauteur_pile_systeme; |
|
|
/* Gestion des processus */ |
/* Gestion des processus */ |
|
|
Line 1942 typedef struct processus
|
Line 1999 typedef struct processus
|
int pipe_injections; |
int pipe_injections; |
int pipe_nombre_injections; |
int pipe_nombre_injections; |
int pipe_interruptions; |
int pipe_interruptions; |
int pipe_nombre_objets_attente; |
int pipe_nombre_elements_attente; |
int pipe_nombre_interruptions_attente; |
|
int nombre_objets_envoyes_non_lus; |
int nombre_objets_envoyes_non_lus; |
int nombre_objets_injectes; |
int nombre_objets_injectes; |
|
|
Line 1999 typedef struct processus
|
Line 2055 typedef struct processus
|
int *pointeurs_caracteres_variables; |
int *pointeurs_caracteres_variables; |
int nombre_caracteres_variables; |
int nombre_caracteres_variables; |
|
|
unsigned long niveau_courant; |
integer8 niveau_courant; |
unsigned long niveau_initial; |
integer8 niveau_initial; |
|
|
logical1 creation_variables_statiques; |
logical1 creation_variables_statiques; |
logical1 creation_variables_partagees; |
logical1 creation_variables_partagees; |
Line 2022 typedef struct processus
|
Line 2078 typedef struct processus
|
|
|
struct_liste_chainee *s_bibliotheques; |
struct_liste_chainee *s_bibliotheques; |
struct_instruction_externe *s_instructions_externes; |
struct_instruction_externe *s_instructions_externes; |
unsigned long nombre_instructions_externes; |
integer8 nombre_instructions_externes; |
|
|
/* Fichier d'impression */ |
/* Fichier d'impression */ |
|
|
Line 2172 typedef struct processus
|
Line 2228 typedef struct processus
|
/* Traitement des exceptions */ |
/* Traitement des exceptions */ |
|
|
logical1 arret_si_exception; |
logical1 arret_si_exception; |
unsigned int exception; |
int exception; |
unsigned int derniere_exception; |
int derniere_exception; |
unsigned int exception_processus_fils; |
int exception_processus_fils; |
|
|
/* Traitement des erreurs */ |
/* Traitement des erreurs */ |
|
|
unsigned int erreur_compilation; |
int erreur_compilation; |
unsigned int erreur_execution; |
volatile int erreur_execution; |
unsigned int erreur_systeme; |
volatile int erreur_systeme; |
|
|
struct_objet *s_objet_errone; |
struct_objet *s_objet_errone; |
struct_objet *s_objet_erreur; |
struct_objet *s_objet_erreur; |
|
|
logical1 erreur_scrutation; |
logical1 erreur_scrutation; |
|
|
volatile unsigned int erreur_systeme_processus_fils; |
volatile int erreur_systeme_processus_fils; |
unsigned int erreur_execution_processus_fils; |
int erreur_execution_processus_fils; |
|
|
pid_t pid_erreur_processus_fils; |
pid_t pid_erreur_processus_fils; |
|
|
Line 2196 typedef struct processus
|
Line 2252 typedef struct processus
|
|
|
integer8 derniere_erreur_fonction_externe; |
integer8 derniere_erreur_fonction_externe; |
|
|
unsigned int derniere_erreur_systeme; |
int derniere_erreur_systeme; |
unsigned int derniere_erreur_execution; |
int derniere_erreur_execution; |
unsigned int derniere_erreur_evaluation; |
int derniere_erreur_evaluation; |
|
|
unsigned char *instruction_derniere_erreur; |
unsigned char *instruction_derniere_erreur; |
|
|
unsigned long niveau_derniere_erreur; |
integer8 niveau_derniere_erreur; |
|
|
logical1 core; |
logical1 core; |
logical1 invalidation_message_erreur; |
logical1 invalidation_message_erreur; |
Line 2210 typedef struct processus
|
Line 2266 typedef struct processus
|
/* Debug */ |
/* Debug */ |
|
|
logical1 debug; |
logical1 debug; |
integer8 type_debug; |
logical8 type_debug; |
logical1 debug_programme; |
logical1 debug_programme; |
logical1 execution_pas_suivant; |
logical1 execution_pas_suivant; |
logical1 traitement_instruction_halt; |
logical1 traitement_instruction_halt; |
Line 2285 typedef struct processus
|
Line 2341 typedef struct processus
|
unsigned char retour_routine_evaluation; |
unsigned char retour_routine_evaluation; |
unsigned char *localisation; |
unsigned char *localisation; |
|
|
unsigned long niveau_recursivite; |
integer8 niveau_recursivite; |
|
|
pid_t pid_processus_pere; |
pid_t pid_processus_pere; |
pthread_t tid_processus_pere; |
pthread_t tid_processus_pere; |
Line 2293 typedef struct processus
|
Line 2349 typedef struct processus
|
|
|
logical1 processus_detache; |
logical1 processus_detache; |
|
|
|
enum t_type type_en_cours; |
|
|
/* Profilage */ |
/* Profilage */ |
|
|
logical1 profilage; |
logical1 profilage; |
Line 2301 typedef struct processus
|
Line 2359 typedef struct processus
|
struct_liste_profilage2 *pile_profilage_fonctions; |
struct_liste_profilage2 *pile_profilage_fonctions; |
struct timeval horodatage_profilage; |
struct timeval horodatage_profilage; |
|
|
// Mutex spécifique au processus et donnant accès à la pile des processus |
|
pthread_mutex_t mutex; |
|
pthread_mutex_t mutex_allocation; |
pthread_mutex_t mutex_allocation; |
|
pthread_mutex_t mutex_allocation_buffer; |
|
pthread_mutex_t mutex_interruptions; |
|
pthread_mutex_t mutex_pile_processus; |
|
pthread_mutex_t mutex_signaux; |
|
|
// Mutex autorisant les fork() |
// Mutex autorisant les fork() |
sem_t __PTR__ semaphore_fork; |
sem_t __PTR__ semaphore_fork; |
Line 2314 typedef struct processus
|
Line 2374 typedef struct processus
|
pthread_mutex_t protection_liste_mutexes; |
pthread_mutex_t protection_liste_mutexes; |
unsigned int sections_critiques; |
unsigned int sections_critiques; |
|
|
/* Drapeau nécessaire à RESTART */ |
/* Variable d'initialisation pour SCHED */ |
|
|
|
logical1 initialisation_scheduler; |
|
|
|
/* Drapeau nécessaire à RESTART */ |
|
|
volatile logical1 requete_redemarrage; |
volatile logical1 requete_redemarrage; |
|
|
/* Gestion optimisée de la mémoire */ |
/* Gestion optimisée de la mémoire */ |
|
|
double estimation_taille_pile_tampon; |
double estimation_taille_pile_tampon; |
unsigned long taille_pile_tampon; |
integer8 taille_pile_tampon; |
struct_liste_chainee *pile_tampon; |
struct_liste_chainee *pile_tampon; |
|
|
double estimation_taille_pile_systeme_tampon; |
double estimation_taille_pile_systeme_tampon; |
unsigned long taille_pile_systeme_tampon; |
integer8 taille_pile_systeme_tampon; |
struct_liste_pile_systeme *pile_systeme_tampon; |
struct_liste_pile_systeme *pile_systeme_tampon; |
|
|
unsigned long taille_pile_objets; |
integer8 taille_pile_objets; |
struct_objet *pile_objets; |
struct_objet *pile_objets; |
|
|
# define TAILLE_CACHE 16384 |
# define TAILLE_CACHE 1024 |
|
# define CACHE(type, nom) \ |
unsigned long *objets_adr[TAILLE_CACHE]; |
type *objets_##nom[TAILLE_CACHE]; \ |
int pointeur_adr; |
volatile int pointeur_##nom; |
|
|
logical8 *objets_bin[TAILLE_CACHE]; |
# define CACHE2(type, nom) \ |
int pointeur_bin; |
type *nom[TAILLE_CACHE]; \ |
|
volatile int pointeur_##nom; |
complex16 *objets_cpl[TAILLE_CACHE]; |
|
int pointeur_cpl; |
CACHE(integer8, adr) |
|
CACHE(logical8, bin) |
struct fonction *objets_fct[TAILLE_CACHE]; |
CACHE(complex16, cpl) |
int pointeur_fct; |
CACHE(struct_fonction, fct) |
|
CACHE(integer8, int) |
integer8 *objets_int[TAILLE_CACHE]; |
CACHE(struct_matrice, mat) |
int pointeur_int; |
CACHE(struct_nom, nom) |
|
CACHE(real8, rel) |
struct_matrice *objets_mat[TAILLE_CACHE]; |
CACHE(struct_tableau, tab) |
int pointeur_mat; |
CACHE(struct_vecteur, vec) |
|
|
struct_nom *objets_nom[TAILLE_CACHE]; |
CACHE2(struct_liste_chainee, maillons) |
int pointeur_nom; |
CACHE2(struct_arbre_variables, variables_noeud) |
|
CACHE2(struct_arbre_variables_partagees, variables_partagees_noeud) |
real8 *objets_rel[TAILLE_CACHE]; |
CACHE2(struct_liste_variables, variables_feuille) |
int pointeur_rel; |
CACHE2(struct_variable, variables_variable) |
|
CACHE2(struct_arbre_variables *, variables_tableau_noeuds) |
struct_tableau *objets_tab[TAILLE_CACHE]; |
CACHE2(struct_arbre_variables_partagees *, |
int pointeur_tab; |
variables_tableau_noeuds_partages) |
|
|
struct_vecteur *objets_vec[TAILLE_CACHE]; |
CACHE2(struct_buffer, enveloppes_buffers) |
int pointeur_vec; |
unsigned char ***cache_buffer; |
|
int *pointeur_cache_buffer; |
struct_liste_chainee *maillons[TAILLE_CACHE]; |
|
int pointeur_maillons; |
|
|
|
struct_arbre_variables *variables_noeud[TAILLE_CACHE]; |
|
int pointeur_variables_noeud; |
|
|
|
struct_arbre_variables_partagees |
|
*variables_partagees_noeud[TAILLE_CACHE]; |
|
int pointeur_variables_partagees_noeud; |
|
|
|
struct_liste_variables *variables_feuille[TAILLE_CACHE]; |
|
int pointeur_variables_feuille; |
|
|
|
struct_variable *variables_variable[TAILLE_CACHE]; |
|
int pointeur_variables_variable; |
|
|
|
struct_arbre_variables **variables_tableau_noeuds[TAILLE_CACHE]; |
|
int pointeur_variables_tableau_noeuds; |
|
|
|
struct_arbre_variables_partagees |
|
**variables_tableau_noeuds_partages |
|
[TAILLE_CACHE]; |
|
int pointeur_variables_tableau_noeuds_partages; |
|
} struct_processus; |
} struct_processus; |
#endif |
#endif |
|
|
|
|
/* |
/* |
-------------------------------------------------------------------------------- |
================================================================================ |
Structure fonction |
MISE EN PLACE DE L'ALLOCATEUR SPÉCIFIQUE |
-------------------------------------------------------------------------------- |
================================================================================*/ |
*/ |
|
|
|
#ifndef RPLARGS |
#ifndef DEBUG_MEMOIRE |
typedef struct fonction |
# define malloc(a) rpl_malloc(s_etat_processus, a) |
{ |
# define realloc(a, b) rpl_realloc(s_etat_processus, a, b) |
unsigned char *nom_fonction; |
# define free(a) rpl_free(s_etat_processus, a) |
unsigned long nombre_arguments; |
#endif |
|
|
void (*fonction)(struct_processus *); |
void *rpl_malloc(struct_processus *s_etat_processus, size_t s); |
|
void *rpl_realloc(struct_processus *s_etat_processus, void *ptr, size_t s); |
|
void rpl_free(struct_processus *s_etat_processus, void *ptr); |
|
void *sys_malloc(size_t s); |
|
void sys_free(void *ptr); |
|
|
volatile struct_liste_chainee *prediction_saut; |
/* |
volatile logical1 prediction_execution; |
* Wrapper de readline() pour que la fonction renvoie un pointeur sur un |
} struct_fonction; |
* buffer alloué par rpl_malloc(). |
#endif |
*/ |
|
|
|
#define readline(s) readline_wrapper(s_etat_processus, s) |
|
unsigned char *readline_wrapper(struct_processus *s_etat_processus, |
|
unsigned char *s); |
|
|
|
|
/* |
/* |
Line 2481 void instruction_col_fleche(struct_proce
|
Line 2530 void instruction_col_fleche(struct_proce
|
void instruction_col_moins(struct_processus *s_etat_processus); |
void instruction_col_moins(struct_processus *s_etat_processus); |
void instruction_col_plus(struct_processus *s_etat_processus); |
void instruction_col_plus(struct_processus *s_etat_processus); |
void instruction_comb(struct_processus *s_etat_processus); |
void instruction_comb(struct_processus *s_etat_processus); |
|
void instruction_compress(struct_processus *s_etat_processus); |
void instruction_con(struct_processus *s_etat_processus); |
void instruction_con(struct_processus *s_etat_processus); |
void instruction_cond(struct_processus *s_etat_processus); |
void instruction_cond(struct_processus *s_etat_processus); |
void instruction_cont(struct_processus *s_etat_processus); |
void instruction_cont(struct_processus *s_etat_processus); |
Line 2548 void instruction_elseif(struct_processus
|
Line 2598 void instruction_elseif(struct_processus
|
void instruction_end(struct_processus *s_etat_processus); |
void instruction_end(struct_processus *s_etat_processus); |
void instruction_eng(struct_processus *s_etat_processus); |
void instruction_eng(struct_processus *s_etat_processus); |
void instruction_epsilon(struct_processus *s_etat_processus); |
void instruction_epsilon(struct_processus *s_etat_processus); |
|
void instruction_eqv(struct_processus *s_etat_processus); |
void instruction_erase(struct_processus *s_etat_processus); |
void instruction_erase(struct_processus *s_etat_processus); |
void instruction_errm(struct_processus *s_etat_processus); |
void instruction_errm(struct_processus *s_etat_processus); |
void instruction_errn(struct_processus *s_etat_processus); |
void instruction_errn(struct_processus *s_etat_processus); |
Line 2788 void instruction_return(struct_processus
|
Line 2839 void instruction_return(struct_processus
|
void instruction_revlist(struct_processus *s_etat_processus); |
void instruction_revlist(struct_processus *s_etat_processus); |
void instruction_rewind(struct_processus *s_etat_processus); |
void instruction_rewind(struct_processus *s_etat_processus); |
void instruction_rfuse(struct_processus *s_etat_processus); |
void instruction_rfuse(struct_processus *s_etat_processus); |
|
void instruction_rgdl(struct_processus *s_etat_processus); |
|
void instruction_rgdr(struct_processus *s_etat_processus); |
void instruction_rl(struct_processus *s_etat_processus); |
void instruction_rl(struct_processus *s_etat_processus); |
void instruction_rlb(struct_processus *s_etat_processus); |
void instruction_rlb(struct_processus *s_etat_processus); |
void instruction_rnd(struct_processus *s_etat_processus); |
void instruction_rnd(struct_processus *s_etat_processus); |
Line 2907 void instruction_t_vers_l(struct_process
|
Line 2960 void instruction_t_vers_l(struct_process
|
|
|
void instruction_ucase(struct_processus *s_etat_processus); |
void instruction_ucase(struct_processus *s_etat_processus); |
void instruction_uchol(struct_processus *s_etat_processus); |
void instruction_uchol(struct_processus *s_etat_processus); |
|
void instruction_uncompress(struct_processus *s_etat_processus); |
void instruction_unlock(struct_processus *s_etat_processus); |
void instruction_unlock(struct_processus *s_etat_processus); |
void instruction_unprotect(struct_processus *s_etat_processus); |
void instruction_unprotect(struct_processus *s_etat_processus); |
void instruction_until(struct_processus *s_etat_processus); |
void instruction_until(struct_processus *s_etat_processus); |
Line 2957 void instruction_yield(struct_processus
|
Line 3011 void instruction_yield(struct_processus
|
#ifndef RPLARGS |
#ifndef RPLARGS |
void affectation_interruptions_logicielles(struct_processus *s_etat_processus); |
void affectation_interruptions_logicielles(struct_processus *s_etat_processus); |
void affichage_pile(struct_processus *s_etat_processus, |
void affichage_pile(struct_processus *s_etat_processus, |
struct_liste_chainee *l_element_courant, unsigned long |
struct_liste_chainee *l_element_courant, integer8 niveau_courant); |
niveau_courant); |
|
#endif |
#endif |
|
|
void *allocation_maillon(struct_processus *s_etat_processus); |
void *allocation_maillon(struct_processus *s_etat_processus); |
Line 2976 void conversion_chaine(struct_processus
|
Line 3029 void conversion_chaine(struct_processus
|
unsigned char *chaine, unsigned char type); |
unsigned char *chaine, unsigned char type); |
void conversion_decimal_vers_hms(real8 *angle); |
void conversion_decimal_vers_hms(real8 *angle); |
void conversion_degres_vers_radians(real8 *angle); |
void conversion_degres_vers_radians(real8 *angle); |
void conversion_element_tex(unsigned char **element, unsigned char *fonction); |
void conversion_element_tex(struct_processus *s_etat_processus, |
|
unsigned char **element, unsigned char *fonction); |
void conversion_format(struct_processus *s_etat_processus, |
void conversion_format(struct_processus *s_etat_processus, |
unsigned char *chaine); |
unsigned char *chaine); |
void conversion_hms_vers_decimal(real8 *angle); |
void conversion_hms_vers_decimal(real8 *angle); |
void conversion_majuscule_limitee(unsigned char *chaine_entree, |
void conversion_majuscule_limitee( |
unsigned char *chaine_sortie, unsigned long longueur); |
unsigned char *chaine_entree, unsigned char *chaine_sortie, |
|
integer8 longueur); |
void conversion_radians_vers_degres(real8 *angle); |
void conversion_radians_vers_degres(real8 *angle); |
void copie_arbre_variables(struct_processus *s_etat_processus, |
void copie_arbre_variables(struct_processus *s_etat_processus, |
struct_processus *s_nouvel_etat_processus); |
struct_processus *s_nouvel_etat_processus); |
Line 2994 void determinant(struct_processus *s_eta
|
Line 3049 void determinant(struct_processus *s_eta
|
void *valeur); |
void *valeur); |
void deverrouillage_threads_concurrents(struct_processus *s_etat_processus); |
void deverrouillage_threads_concurrents(struct_processus *s_etat_processus); |
void ecriture_pile(struct_processus *s_etat_processus, file *flux, |
void ecriture_pile(struct_processus *s_etat_processus, file *flux, |
struct_liste_chainee *l_element_courant, unsigned long niveau_courant); |
struct_liste_chainee *l_element_courant, integer8 niveau_courant); |
void ecriture_profil(struct_processus *s_etat_processus); |
void ecriture_profil(struct_processus *s_etat_processus); |
void effacement_pile_systeme(struct_processus *s_etat_processus); |
void effacement_pile_systeme(struct_processus *s_etat_processus); |
void empilement_pile_systeme(struct_processus *s_etat_processus); |
void empilement_pile_systeme(struct_processus *s_etat_processus); |
void encart(struct_processus *s_etat_processus, unsigned long duree); |
void encart(struct_processus *s_etat_processus, integer8 duree); |
void evaluation_romberg(struct_processus *s_etat_processus, |
void evaluation_romberg(struct_processus *s_etat_processus, |
struct_objet *s_expression, unsigned char *variable, real8 *point, |
struct_objet *s_expression, unsigned char *variable, real8 *point, |
real8 *valeur, logical1 *validite); |
real8 *valeur, logical1 *validite); |
Line 3019 void formateur_elementaire_tex(struct_pr
|
Line 3074 void formateur_elementaire_tex(struct_pr
|
file *fichier, struct_objet *s_objet, unsigned char environnement); |
file *fichier, struct_objet *s_objet, unsigned char environnement); |
void impression_pile(struct_processus *s_etat_processus, |
void impression_pile(struct_processus *s_etat_processus, |
struct_liste_chainee *l_element_courant, |
struct_liste_chainee *l_element_courant, |
unsigned char methode, unsigned long niveau_courant); |
unsigned char methode, integer8 niveau_courant); |
void impression_tex(struct_processus *s_etat_processus); |
void impression_tex(struct_processus *s_etat_processus); |
void informations(struct_processus *s_etat_processus); |
void informations(struct_processus *s_etat_processus); |
void initialisation_allocateur(struct_processus *s_etat_processus); |
void initialisation_allocateur(struct_processus *s_etat_processus); |
Line 3027 void initialisation_completion(void);
|
Line 3082 void initialisation_completion(void);
|
void initialisation_contexte_cas(struct_processus *s_etat_processus); |
void initialisation_contexte_cas(struct_processus *s_etat_processus); |
void initialisation_drapeaux(struct_processus *s_etat_processus); |
void initialisation_drapeaux(struct_processus *s_etat_processus); |
void initialisation_generateur_aleatoire(struct_processus *s_etat_processus, |
void initialisation_generateur_aleatoire(struct_processus *s_etat_processus, |
logical1 initialisation_automatique, unsigned long int racine); |
logical1 initialisation_automatique, integer8 racine); |
void initialisation_instructions(struct_processus *s_etat_processus); |
void initialisation_instructions(struct_processus *s_etat_processus); |
void initialisation_variables(struct_processus *s_etat_processus); |
void initialisation_variables(struct_processus *s_etat_processus); |
#endif |
#endif |
Line 3096 void scrutation_injection(struct_process
|
Line 3151 void scrutation_injection(struct_process
|
void scrutation_interruptions(struct_processus *s_etat_processus); |
void scrutation_interruptions(struct_processus *s_etat_processus); |
void sf(struct_processus *s_etat_processus, unsigned char indice_drapeau); |
void sf(struct_processus *s_etat_processus, unsigned char indice_drapeau); |
void *surveillance_processus(void *argument); |
void *surveillance_processus(void *argument); |
void swap(void *variable_1, void *variable_2, unsigned long taille_octets); |
void swap(void *variable_1, void *variable_2, integer8 taille_octets); |
void *thread_signaux(void *argument); |
void *thread_signaux(void *argument); |
void trace(struct_processus *s_etat_processus, FILE *flux); |
void trace(struct_processus *s_etat_processus, FILE *flux); |
void traitement_asynchrone_exceptions_gsl(struct_processus *s_etat_processus); |
void traitement_asynchrone_exceptions_gsl(struct_processus *s_etat_processus); |
Line 3104 void traitement_exceptions_gsl(const cha
|
Line 3159 void traitement_exceptions_gsl(const cha
|
int line, int gsl_errno); |
int line, int gsl_errno); |
void traitement_interruptions_logicielles(struct_processus *s_etat_processus); |
void traitement_interruptions_logicielles(struct_processus *s_etat_processus); |
void tri_base_symboles_externes(struct_processus *s_etat_processus); |
void tri_base_symboles_externes(struct_processus *s_etat_processus); |
void tri_vecteur(real8 *vecteur, unsigned long taille); |
void tri_vecteur(real8 *vecteur, integer8 taille); |
void valeurs_propres(struct_processus *s_etat_processus, |
void valeurs_propres(struct_processus *s_etat_processus, |
struct_matrice *s_matrice, |
struct_matrice *s_matrice, |
struct_vecteur *s_valeurs_propres, |
struct_vecteur *s_valeurs_propres, |
Line 3144 int envoi_signal_thread(pthread_t tid, e
|
Line 3199 int envoi_signal_thread(pthread_t tid, e
|
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
*/ |
*/ |
|
|
real8 sommation_vecteur_reel(real8 *vecteur, unsigned long *taille, |
real8 sommation_vecteur_reel(real8 *vecteur, integer8 *taille, |
logical1 *erreur_memoire); |
logical1 *erreur_memoire); |
complex16 sommation_vecteur_complexe(complex16 *vecteur, unsigned long *taille, |
complex16 sommation_vecteur_complexe(complex16 *vecteur, integer8 *taille, |
logical1 *erreur_memoire); |
logical1 *erreur_memoire); |
|
|
/* |
/* |
Line 3168 int rplinit(int argc, char *argv[], char
|
Line 3223 int rplinit(int argc, char *argv[], char
|
|
|
#ifndef RPLARGS |
#ifndef RPLARGS |
real8 correlation_statistique(struct_matrice *s_matrice, |
real8 correlation_statistique(struct_matrice *s_matrice, |
unsigned long colonne_1, unsigned long colonne_2, logical1 *erreur); |
integer8 colonne_1, integer8 colonne_2, logical1 *erreur); |
real8 covariance_statistique(struct_matrice *s_matrice, |
real8 covariance_statistique(struct_matrice *s_matrice, |
unsigned long colonne_1, unsigned long colonne_2, |
integer8 colonne_1, integer8 colonne_2, |
unsigned char type, logical1 *erreur); |
unsigned char type, logical1 *erreur); |
struct_vecteur *ecart_type_statistique(struct_matrice *s_matrice, |
struct_vecteur *ecart_type_statistique(struct_processus *s_etat_processus, |
unsigned char type); |
struct_matrice *s_matrice, unsigned char type); |
struct_vecteur *moyenne_statistique(struct_matrice *s_matrice); |
struct_vecteur *moyenne_statistique(struct_processus *s_etat_processus, |
struct_vecteur *sommation_colonne_statistique(struct_matrice *s_matrice, |
struct_matrice *s_matrice); |
unsigned long colonne); |
struct_vecteur *sommation_colonne_statistique( |
struct_vecteur *sommation_produits_colonnes_statistiques(struct_matrice |
struct_processus *s_etat_processus, struct_matrice *s_matrice, |
*s_matrice, unsigned long colonne_1, unsigned long colonne_2); |
integer8 colonne); |
struct_vecteur *sommation_statistique(struct_matrice *s_matrice); |
struct_vecteur *sommation_produits_colonnes_statistiques( |
struct_vecteur *variance_statistique(struct_matrice *s_matrice, |
struct_processus *s_etat_processus, struct_matrice |
unsigned char type); |
*s_matrice, integer8 colonne_1, integer8 colonne_2); |
|
struct_vecteur *sommation_statistique(struct_processus *s_etat_processus, |
|
struct_matrice *s_matrice); |
|
struct_vecteur *variance_statistique(struct_processus *s_etat_processus, |
|
struct_matrice *s_matrice, unsigned char type); |
#endif |
#endif |
|
|
/* |
/* |
Line 3204 struct_liste_chainee *depilement_pile_op
|
Line 3263 struct_liste_chainee *depilement_pile_op
|
struct_liste_chainee *empilement_pile_operationnelle(struct_rpl_arguments |
struct_liste_chainee *empilement_pile_operationnelle(struct_rpl_arguments |
*s_rpl_arguments, struct_objet *s_objet); |
*s_rpl_arguments, struct_objet *s_objet); |
struct_liste_chainee *sauvegarde_arguments(struct_rpl_arguments |
struct_liste_chainee *sauvegarde_arguments(struct_rpl_arguments |
*s_rpl_arguments, unsigned long nombre_arguments); |
*s_rpl_arguments, integer8 nombre_arguments); |
|
|
/* |
/* |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
Line 3216 struct_liste_chainee *sauvegarde_argumen
|
Line 3275 struct_liste_chainee *sauvegarde_argumen
|
unsigned char *analyse_algebrique(struct_processus *s_etat_processus, |
unsigned char *analyse_algebrique(struct_processus *s_etat_processus, |
unsigned char *chaine_algebrique, struct_liste_chainee **l_base_liste); |
unsigned char *chaine_algebrique, struct_liste_chainee **l_base_liste); |
unsigned char *analyse_flux(struct_processus *s_etat_processus, |
unsigned char *analyse_flux(struct_processus *s_etat_processus, |
unsigned char *flux, long longueur); |
unsigned char *flux, integer8 longueur); |
unsigned char *chiffrement(const EVP_CIPHER *type_chiffrement, |
unsigned char *chiffrement(struct_processus *s_etat_processus, |
logical1 encodage, unsigned char *message, unsigned int |
const EVP_CIPHER *type_chiffrement, |
longueur_message, unsigned char *clef, unsigned int longueur_clef, |
logical1 encodage, unsigned char *message, integer8 longueur_message, |
|
unsigned char *clef, integer8 longueur_clef, |
unsigned char *vecteur_initialisation, |
unsigned char *vecteur_initialisation, |
unsigned int *longueur_message_chiffre); |
integer8 *longueur_message_chiffre); |
unsigned char *compactage(unsigned char *chaine); |
unsigned char *compactage(struct_processus *s_etat_processus, |
unsigned char *conversion_majuscule(unsigned char *chaine); |
unsigned char *chaine); |
|
unsigned char *conversion_majuscule(struct_processus *s_etat_processus, |
|
unsigned char *chaine); |
unsigned char *creation_nom_fichier(struct_processus *s_etat_processus, |
unsigned char *creation_nom_fichier(struct_processus *s_etat_processus, |
unsigned char *chemin); |
unsigned char *chemin); |
unsigned char *date_compilation(); |
unsigned char *date_compilation(struct_processus *s_etat_processus); |
unsigned char *extraction_chaine(unsigned char *chaine, unsigned long i, |
unsigned char *extraction_chaine(struct_processus *s_etat_processus, |
unsigned long j); |
unsigned char *chaine, integer8 i, integer8 j); |
unsigned char *formateur(struct_processus *s_etat_processus, long offset, |
unsigned char *formateur(struct_processus *s_etat_processus, long offset, |
struct_objet *s_objet); |
struct_objet *s_objet); |
unsigned char *formateur_fichier(struct_processus *s_etat_processus, |
unsigned char *formateur_fichier(struct_processus *s_etat_processus, |
struct_objet *s_objet, struct_objet *s_format, |
struct_objet *s_objet, struct_objet *s_format, |
long longueur, long longueur_champ, unsigned char format, |
integer8 longueur, integer8 longueur_champ, unsigned char format, |
unsigned char type, long *longueur_effective, long *recursivite, |
unsigned char type, integer8 *longueur_effective, integer8 *recursivite, |
logical1 export_fichier); |
logical1 export_fichier); |
unsigned char *formateur_flux(struct_processus *s_etat_processus, |
unsigned char *formateur_flux(struct_processus *s_etat_processus, |
unsigned char *donnees, long *longueur); |
unsigned char *donnees, integer8 *longueur); |
unsigned char *formateur_fichier_nombre(struct_processus *s_etat_processus, |
unsigned char *formateur_fichier_nombre(struct_processus *s_etat_processus, |
void *valeur_numerique, unsigned char type, |
void *valeur_numerique, unsigned char type, |
long longueur, long longueur_champ, unsigned char format); |
integer8 longueur, integer8 longueur_champ, unsigned char format); |
unsigned char *formateur_fichier_binaire_nombre(struct_processus |
unsigned char *formateur_fichier_binaire_nombre(struct_processus |
*s_etat_processus, void *valeur_numerique, unsigned char type_entree, |
*s_etat_processus, void *valeur_numerique, unsigned char type_entree, |
unsigned char type, long longueur, long *longueur_conversion); |
unsigned char type, integer8 longueur, integer8 *longueur_conversion); |
unsigned char *formateur_fichier_reel(struct_processus *s_etat_processus, |
unsigned char *formateur_fichier_reel(struct_processus *s_etat_processus, |
void *valeur_numerique, unsigned char type, |
void *valeur_numerique, unsigned char type, |
long longueur, long longueur_champ, unsigned char format); |
integer8 longueur, integer8 longueur_champ, unsigned char format); |
unsigned char *formateur_nombre(struct_processus *s_etat_processus, |
unsigned char *formateur_nombre(struct_processus *s_etat_processus, |
void *valeur_numerique, unsigned char type); |
void *valeur_numerique, unsigned char type); |
unsigned char *formateur_reel(struct_processus *s_etat_processus, |
unsigned char *formateur_reel(struct_processus *s_etat_processus, |
Line 3254 unsigned char *formateur_reel(struct_pro
|
Line 3316 unsigned char *formateur_reel(struct_pro
|
unsigned char *messages(struct_processus *s_etat_processus); |
unsigned char *messages(struct_processus *s_etat_processus); |
unsigned char *pointeur_ieme_caractere(struct_processus *s_etat_processus, |
unsigned char *pointeur_ieme_caractere(struct_processus *s_etat_processus, |
unsigned char *chaine, integer8 position); |
unsigned char *chaine, integer8 position); |
unsigned char *purification_chaine(unsigned char *chaine); |
unsigned char *purification_chaine(struct_processus *s_etat_processus, |
|
unsigned char *chaine); |
unsigned char *recherche_chemin_fichiers_temporaires(struct_processus |
unsigned char *recherche_chemin_fichiers_temporaires(struct_processus |
*s_etat_processus); |
*s_etat_processus); |
unsigned char *reencodage(struct_processus *s_etat_processus, |
unsigned char *reencodage(struct_processus *s_etat_processus, |
Line 3297 logical1 destruction_fichier(unsigned ch
|
Line 3360 logical1 destruction_fichier(unsigned ch
|
logical1 empilement(struct_processus *s_etat_processus, |
logical1 empilement(struct_processus *s_etat_processus, |
struct_liste_chainee **l_base_liste, struct_objet *s_objet); |
struct_liste_chainee **l_base_liste, struct_objet *s_objet); |
logical1 empilement_pile_last(struct_processus *s_etat_processus, |
logical1 empilement_pile_last(struct_processus *s_etat_processus, |
unsigned long nombre_arguments); |
integer8 nombre_arguments); |
logical1 evaluation(struct_processus *s_etat_processus, struct_objet *s_objet, |
logical1 evaluation(struct_processus *s_etat_processus, struct_objet *s_objet, |
unsigned char type_evaluation); |
unsigned char type_evaluation); |
logical1 initialisation_fichier_acces_direct(struct_processus *s_etat_processus, |
logical1 initialisation_fichier_acces_direct(struct_processus *s_etat_processus, |
Line 3306 logical1 initialisation_fichier_acces_in
|
Line 3369 logical1 initialisation_fichier_acces_in
|
sqlite3 *sqlite, integer8 position_clef, logical1 binaire); |
sqlite3 *sqlite, integer8 position_clef, logical1 binaire); |
logical1 lancement_thread_signaux(struct_processus *s_etat_processus); |
logical1 lancement_thread_signaux(struct_processus *s_etat_processus); |
logical1 recherche_instruction_suivante(struct_processus *s_etat_processus); |
logical1 recherche_instruction_suivante(struct_processus *s_etat_processus); |
|
logical1 recherche_instruction_suivante_recursive( |
|
struct_processus *s_etat_processus, integer8 recursivite); |
logical1 retrait_variable(struct_processus *s_etat_processus, |
logical1 retrait_variable(struct_processus *s_etat_processus, |
unsigned char *nom_variable, unsigned char type); |
unsigned char *nom_variable, unsigned char type); |
logical1 retrait_variables_par_niveau(struct_processus *s_etat_processus); |
logical1 retrait_variables_par_niveau(struct_processus *s_etat_processus); |
Line 3366 ssize_t write_atomic(struct_processus *s
|
Line 3431 ssize_t write_atomic(struct_processus *s
|
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
*/ |
*/ |
|
|
int alsprintf(unsigned char **strp, const char *fmt, ...); |
int alsprintf(struct_processus *s_etat_processus, |
|
unsigned char **strp, const char *fmt, ...); |
|
#ifndef RPLARGS |
|
int association_etat_processus_readline(); |
|
#endif |
int interruption_violation_access(void *adresse_fautive, int gravite); |
int interruption_violation_access(void *adresse_fautive, int gravite); |
#ifndef RPLARGS |
#ifndef RPLARGS |
int liste_variables(struct_processus *s_etat_processus, |
int initialisation_etat_processus_readline(); |
|
int liberation_etat_processus_readline(); |
|
integer8 liste_variables(struct_processus *s_etat_processus, |
struct_tableau_variables *tableau); |
struct_tableau_variables *tableau); |
int nombre_variables(struct_processus *s_etat_processus); |
integer8 nombre_variables(struct_processus *s_etat_processus); |
int readline_analyse_syntaxique(int count, int key); |
int readline_analyse_syntaxique(int count, int key); |
int readline_effacement(int count, int key); |
int readline_effacement(int count, int key); |
#endif |
#endif |
|
int std_fprintf(file *flux, const char *format, ...); |
int tex_fprintf(struct_processus *s_etat_processus, |
int tex_fprintf(struct_processus *s_etat_processus, |
file *flux, const char *format, ...); |
file *flux, const char *format, ...); |
int transliterated_fprintf(struct_processus *s_etat_processus, file *flux, |
int transliterated_fprintf(struct_processus *s_etat_processus, file *flux, |
const char *format, ...); |
const char *format, ...); |
int valsprintf(unsigned char **strp, const char *fmt, va_list ap); |
int valsprintf(struct_processus *s_etat_processus, |
|
unsigned char **strp, const char *fmt, va_list ap); |
int wrapper_instruction_intrinseque(void (*fonction)(), |
int wrapper_instruction_intrinseque(void (*fonction)(), |
struct_rpl_arguments *rpl_arguments); |
struct_rpl_arguments *rpl_arguments); |
|
|
Line 3430 struct_liste_chainee *analyse_rpn(struct
|
Line 3503 struct_liste_chainee *analyse_rpn(struct
|
|
|
/* |
/* |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
|
Allocateur de buffers à cache |
|
-------------------------------------------------------------------------------- |
|
*/ |
|
|
|
void initialisation_allocateur_buffer(struct_processus *s_etat_processus); |
|
void liberation_allocateur_buffer(struct_processus *s_etat_pocessus); |
|
struct_buffer *allocation_buffer(struct_processus *s_etat_processus, |
|
size_t longueur); |
|
void liberation_buffer(struct_processus *s_etat_processus, |
|
struct_buffer *buffer); |
|
|
|
/* |
|
-------------------------------------------------------------------------------- |
Fonctions renvoyant une copie de la structure de description des processus |
Fonctions renvoyant une copie de la structure de description des processus |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
*/ |
*/ |
Line 3491 struct_liste_variables_partagees *recher
|
Line 3577 struct_liste_variables_partagees *recher
|
#endif |
#endif |
|
|
/* |
/* |
-------------------------------------------------------------------------------- |
|
Fonctions gérant les arbres de simplification |
|
-------------------------------------------------------------------------------- |
|
*/ |
|
|
|
#ifndef RPLARGS |
|
struct_arbre *creation_arbre(struct_processus *s_etat_processus, |
|
struct_objet **t_objets, unsigned long indice, |
|
unsigned long indice_maximal); |
|
void liberation_arbre(struct_processus *s_etat_processus, |
|
struct_arbre *s_noeud); |
|
void parcours_arbre(struct_processus *s_etat_processus, struct_arbre *s_noeud); |
|
void simplification_arbre(struct_processus *s_etat_processus, |
|
struct_arbre *s_noeud); |
|
#endif |
|
|
|
/* |
|
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |
Fonctions gérant la complétion automatique |
Fonctions gérant la complétion automatique |
-------------------------------------------------------------------------------- |
-------------------------------------------------------------------------------- |