IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Linux Discussion :

appels système et "errno"


Sujet :

Linux

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 200
    Par défaut appels système et "errno"
    Bonjour,
    Petite question au sujet des appels systèmes retournant '-1', et positionnant la variable système globale "errno" :

    Code c : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    int iRet =0 ;
    iRet=MaFonctionSysteme() ;
    if(-1==iRet)
    {
        if (EACCESS==errno)
        {
            printf("bla bla\n") ;
        }
    }
    else
    {
    ...
    }

    Qu'est ce qui garenti que errno n'a pas été modifié par une autre tâche entre l'exécution de MaFonctionSysteme et le test de la valeur errno ?

    Merci

    Nicolas

  2. #2
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Bonjour,

    Qu'est ce qui garanti que errno n'a pas été modifiée par une autre tâche entre l'exécution de MaFonctionSysteme et le test de la valeur errno ?
    Si tu es en environnement multi-thread, rien : errno n'est pas thread-safe. Ou tout du moins, pas obligatoirement, même si ca peut être vrai sur certains systèmes.

    Si tu es en environnement mono-thread, alors errno est une variable locale à ton programme, et non pas globale au système comme tu sembles l'entendre. Donc tant que tu n'as pas fait d'autre appel a une fonction, tu n'as pas de risque qu'errno soit modifiée.

    Pour information, il est recommande de mettre errno à 0 avant utilisation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
     
    int iRet =0 ;
     
    errno = 0;
    iRet=MaFonctionSysteme() ;
     
    if(-1 == iRet)
    {
        if (EACCESS == errno)
        {
            printf("bla bla\n") ;
        }
        else
        {
            printf("Errno %d, %s\n", errno, strerror (errno) ) ;
        }
    }
    else
    {
        ...
    }
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 200
    Par défaut
    Si tu es en environnement multi-thread, rien : errno n'est pas thread-safe.
    Donc RIEN.
    Pas simple alors pour un système multi-thread qui doit pouvoir être sécuritaire...

    Merci

  4. #4
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Il faut que tu te tournes vers les fonctions proposées par ton environnement : il y en a peut-être une qui te garantie un errno thread-safe

    En fait, ton soucis vient du fait que dans un cas d'erreur, en fonction de la valeur d'errno, tu as un traitement a faire, c'est bien ca ?

    Quel OS, quel langage de programmation, et quel compilateur utilises-tu ?


    Edit : j'ai répondu pour le langage C, dans lequel la norme ne précise pas si errno est thread-safe ou non, et de par mon expérience, qui m'a permis de vérifier que c'était bien le cas. Si tu utilises un langage diffèrent, il faut vérifier avec la spécification de ce langage.
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 200
    Par défaut
    Citation Envoyé par gangsoleil Voir le message

    Quel OS, quel langage de programmation, et quel compilateur utilises-tu
    OS : QNX (UNIX-like) développement en C et compilateur qcc (gcc-like)

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    200
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 200
    Par défaut
    Je viens de relire la doc et j'ai la réponse à ma question :

    Each thread in a multi-threaded program has its own error value in its thread local storage. No matter which thread you're in, you can simply refer to errno -- it's defined in such a way that it refers to the correct variable for the thread.
    Dans un programme multi-thread, chaque thread a sa valeur d'erreur propre dans son stockage local ....

    Merci encore

  7. #7
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 863
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 863
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par gangsoleil Voir le message
    Bonjour,
    Pour information, il est recommande de mettre errno à 0 avant utilisation :
    Bonjour

    Je n'en vois pas l'utilité. Il n'y a aucune raison d'initialiser errno puisqu'on n'ira la vérifier qu'en cas de soucis et que ledit soucis aura alors modifié sa valeur initiale...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  8. #8
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Bonjour

    Je n'en vois pas l'utilité. Il n'y a aucune raison d'initialiser errno puisqu'on n'ira la vérifier qu'en cas de soucis et que ledit soucis aura alors modifié sa valeur initiale...
    Parce que la norme précise pour de nombreuses fonctions qu'en cas d'erreur, le code de retour est X et que la valeur d'errno peut être modifiée :

    Citation Envoyé par chapitre 7.5
    The value of errno may be set to nonzero by a library function call
    C'est le cas des fonctions de complex.h, mais aussi de math.h, de signal, strtod, strtof, strtold, wcstod, wcstof, wcstold, ...

    Donc si tu as une erreur, et qu'ensuite tu accèdes a la valeur d'errno sans l'avoir préalablement réinitialisée à 0, tu n'es pas certain que la valeur de errno corresponde au dernier appel que tu as fait.
    Et comme la norme précise qu'aucune fonction ne remet errno à 0, ce cas peut être encore plus fréquent que tu ne le crois.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    The value of errno is zero at program startup, but is never set to zero by any library function.
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  9. #9
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 863
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 863
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par gangsoleil Voir le message
    Parce que la norme précise pour de nombreuses fonctions qu'en cas d'erreur, le code de retour est X et que la valeur d'errno peut être modifiée :
    Vu. Ce qui signifie surtout qu'elle peut ne pas avoir été modifiée. Ca je ne le savais pas.

    Citation Envoyé par gangsoleil Voir le message
    Donc si tu as une erreur, et qu'ensuite tu accèdes a la valeur d'errno sans l'avoir préalablement réinitialisée à 0, tu n'es pas certain que la valeur de errno corresponde au dernier appel que tu as fait.
    Ce qui est logique...

    Citation Envoyé par gangsoleil Voir le message
    Et comme la norme précise qu'aucune fonction ne remet errno à 0
    Cà je le savais. Mais ce détail n'aurait eu aucune importance si la valeur de errno avait été modifiée à chaque fois qu'une fonction système remontait une erreur...

    Ok, merci
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Appel javascript et interprétation double quote
    Par saluts92 dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 06/03/2015, 11h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo