--- rpl/src/instructions_c7.c 2012/08/22 10:47:15 1.39 +++ rpl/src/instructions_c7.c 2012/09/15 12:57:09 1.40 @@ -875,4 +875,72 @@ instruction_clratpoke(struct_processus * return; } + +/* +================================================================================ + Fonction 'critical' +================================================================================ + Entrées : +-------------------------------------------------------------------------------- + Sorties : +-------------------------------------------------------------------------------- + Effets de bord : néant +================================================================================ +*/ + +void +instruction_critical(struct_processus *s_etat_processus) +{ + (*s_etat_processus).erreur_execution = d_ex; + + if ((*s_etat_processus).affichage_arguments == 'Y') + { + printf("\n CRITICAL "); + + if ((*s_etat_processus).langue == 'F') + { + printf("(initialisation d'une section critique)\n\n"); + printf(" Aucun argument\n"); + } + else + { + printf("(critical section initialization)\n\n"); + printf(" No argument\n"); + } + + return; + } + else if ((*s_etat_processus).test_instruction == 'Y') + { + (*s_etat_processus).nombre_arguments = -1; + return; + } + + if (test_cfsf(s_etat_processus, 31) == d_vrai) + { + if (empilement_pile_last(s_etat_processus, 0) == d_erreur) + { + return; + } + } + + empilement_pile_systeme(s_etat_processus); + + if ((*s_etat_processus).erreur_systeme != d_es) + { + return; + } + + (*(*s_etat_processus).l_base_pile_systeme).type_cloture = 'Q'; + + if (pthread_mutex_lock(&mutex_sections_critiques) != 0) + { + (*s_etat_processus).erreur_systeme = d_es_processus; + return; + } + + (*s_etat_processus).sections_critiques++; + return; +} + // vim: ts=4