--- rpl/src/operations_atomiques.c 2011/05/09 13:52:23 1.18.2.3 +++ rpl/src/operations_atomiques.c 2018/12/24 15:56:36 1.68 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.0.24 - Copyright (C) 1989-2011 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.30 + Copyright (C) 1989-2018 Dr. BERTRAND Joël This file is part of RPL/2. @@ -70,11 +70,13 @@ read_atomic(struct_processus *s_etat_pro if ((longueur_lue == 0) && (longueur_tampon == longueur_residuelle)) { - return(longueur_tampon - longueur_residuelle); + return(((ssize_t) longueur_tampon) - + ((ssize_t) longueur_residuelle)); } if ((longueur_lue == -1) && (errno == EINTR)) { + scrutation_interruptions(s_etat_processus); nanosleep(&attente, NULL); drapeau = d_vrai; } @@ -86,22 +88,23 @@ read_atomic(struct_processus *s_etat_pro if (longueur_lue != 0) { - if (longueur_lue < (longueur_residuelle > PIPE_BUF) - ? PIPE_BUF : longueur_residuelle) + if (longueur_lue < (ssize_t) ((longueur_residuelle > PIPE_BUF) + ? PIPE_BUF : longueur_residuelle)) { pointeur += longueur_lue; - longueur_residuelle -= longueur_lue; + longueur_residuelle -= (size_t) longueur_lue; - return(longueur_tampon - longueur_residuelle); + return(((ssize_t) longueur_tampon) - + ((ssize_t) longueur_residuelle)); } } } pointeur += longueur_lue; - longueur_residuelle -= longueur_lue; + longueur_residuelle -= (size_t) longueur_lue; } - return(longueur_tampon - longueur_residuelle); + return(((ssize_t) longueur_tampon) - ((ssize_t) longueur_residuelle)); } @@ -153,6 +156,7 @@ write_atomic(struct_processus *s_etat_pr { if (errno == EINTR) { + scrutation_interruptions(s_etat_processus); nanosleep(&attente, NULL); drapeau = d_vrai; } @@ -169,15 +173,16 @@ write_atomic(struct_processus *s_etat_pr if (longueur_ecrite == 0) { + scrutation_interruptions(s_etat_processus); nanosleep(&attente, NULL); } } pointeur += longueur_ecrite; - longueur_residuelle -= longueur_ecrite; + longueur_residuelle -= (size_t) longueur_ecrite; } - return(longueur_tampon); + return((ssize_t) longueur_tampon); } // vim: ts=4