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

C Discussion :

variable globale fixée dans un registre


Sujet :

C

  1. #1
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut variable globale fixée dans un registre
    Bonjour,



    Je souhaiterais fixer une variable globale dans un registre tout au long de l'exécution de mon programme... ce qui pourrait améliorer sensiblement les performances.


    Après avoir consulté diverses documentations, je suis arrivé à ce code

    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
    // vim:set sw=4 ts=4:
     
    #include <stdio.h>
    #include <stdlib.h>
     
    register int* sp asm("eax");
     
    int main(int argc, char** argv) {
    	sp = (int*) malloc(sizeof(int));
     
    	*sp = 0;
    	fprintf(stderr,"%d\n",*sp);
    // avant
    	*sp += 10;
    	*sp *= 5;
    	fprintf(stderr,"%d\n",*sp);
    // après
     
    	return 0;
    }
    je compile avec cette ligne de commande...

    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    gorgonite@GorgonMobile$ gcc -O0 -Wall -ffixed-eax testGlobalRegVar.c

    et ça plante à l'exécution...

    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    gorgonite@GorgonMobile$ ./a.out 
    0
    Erreur de segmentation (core dumped)

    sachant que si je ne mets pas le code situé entre avant et après, tout semble fonctionner... si vous avez une solution, ça m'intéresse fortement
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  2. #2
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Je souhaiterais fixer une variable globale dans un registre tout au long de l'exécution de mon programme... ce qui pourrait améliorer sensiblement les performances.
    A moins que tu travailles sur une implementation ou l'ABI reserve des registres pour une utilisation globale -- je doute que soit le cas avec un x86 mais je n'ai pas regarde -- tu es bon pour recompiler toutes les bibliotheques utilisees, y compris la libc, avec ton ABI a toi.

    Note: eax est utilise pour contenir les valeurs retournees par les fonctions par l'ABI sur Linux. Je crois que si tu veux utiliser ce registre la, tu vas avoir d'autres problemes que simplement tout recompiler, ca ne m'etonnerait pas que tu doives toucher au compilateur. esi, edi sont des meilleurs candidats.

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    pourquoi register et pas simplement globale ??

  4. #4
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet
    A moins que tu travailles sur une implementation ou l'ABI reserve des registres pour une utilisation globale -- je doute que soit le cas
    en fait, mon programme contient surtout un interprète de bytecode, et avec la technique des blocs (que j'ai réussi à implanter, et qui marche avec toutes les optimisations standards ), je suis obligé de déclarer mon pointeur de pile en variable globale

    Citation Envoyé par souviron34
    pourquoi register et pas simplement globale ??

    or j'ai remarqué que cela entrainait une perte de performances sur mon interprète "à la riccardi", et j'essaie donc de contourner le problème... pour voir si cela améliore mon interprète à bloc (qui réussit à être redoutable sur un p4, alors qu'il est à peine meilleur que le riccardi sur un athlon64, et franchement très moyen sur un centrino )

    pour plus détails, cf mon autre post http://www.developpez.net/forums/sho...d.php?t=349503

    Citation Envoyé par Jean-Marc.Bourguet
    Note: eax est utilise pour contenir les valeurs retournees par les fonctions par l'ABI sur Linux. Je crois que si tu veux utiliser ce registre la, tu vas avoir d'autres problemes que simplement tout recompiler, ca ne m'etonnerait pas que tu doives toucher au compilateur. esi, edi sont des meilleurs candidats.

    effectivement, je ne connaissais pas cette convention, je viens de reessayer avec esi, et toute marche parfaitement...


    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  5. #5
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 963
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 963
    Par défaut
    Koi,

    Je ne pense pas que tu puisses, à moins de tout refaire, probablement y compris le système d'exploitation, ton(tes) compilateur(s), toutes les librairies que tu utilises (les recompiler ne suffira sans doute pas), etc.

    Et je doute que tu gagnes autant que tu sembles le croire.

  6. #6
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    Citation Envoyé par droggo
    Je ne pense pas que tu puisses, à moins de tout refaire, probablement y compris le système d'exploitation, ton(tes) compilateur(s), toutes les librairies que tu utilises (les recompiler ne suffira sans doute pas), etc.

    Et je doute que tu gagnes autant que tu sembles le croire.


    de quoi parles-tu ? qu'est-ce qui serait impossible ?
    au niveau des performances, j'ai pu m'apercevoir de la perte nette en passant d'une variable locale à une globale sur un exemple similaire...
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  7. #7
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par gorgonite
    en fait, mon programme contient surtout un interprète de bytecode, et avec la technique des blocs (que j'ai réussi à implanter, et qui marche avec toutes les optimisations standards ),
    45 ieme etage, jusqu'ici tout va bien :-)

    je suis obligé de déclarer mon pointeur de pile en variable globale
    Je me doutais bien qu'il s'agissait de cela.

    effectivement, je ne connaissais pas cette convention, je viens de reessayer avec esi, et toute marche parfaitement...
    Est-ce que tu as verifie qu'il etait reellement disponible et pas simplement inutilise/utilise d'une maniere qui n'interfere pas visiblement avec toi dans le cas present.

    Note sur ton approche, je me demande si tu ne passes pas plus de temps a essayer de contraindre gcc a generer ce que tu veux que tu n'en aurais passe a ecrire l'assembleur toi-meme directement.

  8. #8
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    Citation Envoyé par Jean-Marc.Bourguet
    Est-ce que tu as verifie qu'il etait reellement disponible et pas simplement inutilise/utilise d'une maniere qui n'interfere pas visiblement avec toi dans le cas present. ?
    il n'est pas utilisé dans mon programme actuel... je vais enquêter un peu pour voir s'il peut être utilisé des cas plus généraux


    Citation Envoyé par Jean-Marc.Bourguet
    Note sur ton approche, je me demande si tu ne passes pas plus de temps a essayer de contraindre gcc a generer ce que tu veux que tu n'en aurais passe a ecrire l'assembleur toi-meme directement.
    je ne sais pas... mais c'est quand même plus facile à comprendre que l'assembleur, et lors de ma soutenance, ce sera un point capital. si tout le monde sort en ce disant qu'il leur faudra 3 ans avant de pouvoir se servir de mon truc, et donc que personne ne fera l'effort, j'aurais tout perdu...
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  9. #9
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par gorgonite
    Je souhaiterais fixer une variable globale dans un registre tout au long de l'exécution de mon programme... ce qui pourrait améliorer sensiblement les performances.
    A ma connaissance, ce n'est pas possible en C standard.

    Les performances sont souvent plus liées à l'algorithme, qu'aux détails d'implémentation.

  10. #10
    Rédacteur/Modérateur

    Avatar de gorgonite
    Homme Profil pro
    Ingénieur d'études
    Inscrit en
    Décembre 2005
    Messages
    10 322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur d'études
    Secteur : Transports

    Informations forums :
    Inscription : Décembre 2005
    Messages : 10 322
    Par défaut
    Citation Envoyé par Emmanuel Delahaye
    A ma connaissance, ce n'est pas possible en C standard.
    et que vaut la solution proposée au-dessus ?

    Citation Envoyé par Emmanuel Delahaye
    Les performances sont souvent plus liées à l'algorithme, qu'aux détails d'implémentation.

    c'est sûr... mais j'ai constaté qu'on pouvait gagner 10% de performances si une variable globale "pointeur" était recopier en local pour être utilisée. mais dans ma nouvelle implémentation ceci n'est plus possible, donc je me demande si fixer ce pointeur dans un registre n'aurait pas les mêmes avantages
    Evitez les MP pour les questions techniques... il y a des forums
    Contributions sur DVP : Mes Tutos | Mon Blog

  11. #11
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 393
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    Sur un x86, à mon avis ça aurait plutôt des inconvénients, vue la quantité de registres disponibles...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  12. #12
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par Médinoc
    Sur un x86, à mon avis ça aurait plutôt des inconvénients, vue la quantité de registres disponibles...
    Vu ce qur fait gorgonite, placer cette variable dans un registre est vraissemblement profitable meme sur un x86.

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 14/05/2009, 16h22
  2. variable globale definie dans un .js externe
    Par master_kb2 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 05/04/2008, 17h58
  3. Variable global utilisable dans plusieurs Forms
    Par nams2590 dans le forum Visual C++
    Réponses: 13
    Dernier message: 11/12/2007, 11h34
  4. Réponses: 8
    Dernier message: 09/07/2007, 10h18
  5. [Delphi7]Variable global à lire dans Visual Basic
    Par Shifty44 dans le forum Delphi
    Réponses: 3
    Dernier message: 23/10/2006, 15h51

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