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

Contribuez Delphi Discussion :

convertir little-endian en big-endian


Sujet :

Contribuez Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite
    Avatar de Montor
    Homme Profil pro
    Autre
    Inscrit en
    Avril 2008
    Messages
    879
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Autre

    Informations forums :
    Inscription : Avril 2008
    Messages : 879
    Par défaut convertir little-endian en big-endian
    petite fonction asm pour convertir little-endian en big-endian et vice versa
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    function SwapIndian(AValue:Cardinal):Cardinal;
    asm
      BSWAP EAX
    end;

  2. #2
    Membre Expert
    Avatar de Droïde Système7
    Homme Profil pro
    Inscrit en
    Septembre 2003
    Messages
    2 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 2 288
    Par défaut


    1 = 16777216
    2 = 33554432
    3 = 50331648

    Super ce code, je suis toujours fasciné par les codes très courts produisant des choses...



    Mais quel peut-être son utilisation ? Aller, des exemples !

    @+

  3. #3
    Membre éprouvé

    Homme Profil pro
    Inscrit en
    Mars 2009
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations forums :
    Inscription : Mars 2009
    Messages : 128
    Par défaut
    Un exemple ?

    Admettons que je range des integer dans un array; ceux-ci sont ordonnés 4 octets par 4 octets en convention little-endian (intel), mais si je me mets à vouloir lire mon tableau en extrayant les octets à la queue leu leu, je ne retrouverai pas mes nombres initiaux car je les obtiendrais dans le mode big-endian.
    En delphi, c'est transparent à condition de ne pas accéder aux données par pointeurs et index décalés. Par contre en ASM, attention de bien y prendre garde si on manipule de la chaîne ou du numérique !

  4. #4
    Membre Expert
    Avatar de Droïde Système7
    Homme Profil pro
    Inscrit en
    Septembre 2003
    Messages
    2 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 2 288
    Par défaut
    Citation Envoyé par Rekin85 Voir le message
    Un exemple ?

    Admettons que je range des integer dans un array; ceux-ci sont ordonnés 4 octets par 4 octets en convention little-endian (intel), mais si je me mets à vouloir lire mon tableau en extrayant les octets à la queue leu leu, je ne retrouverai pas mes nombres initiaux car je les obtiendrais dans le mode big-endian.
    En delphi, c'est transparent à condition de ne pas accéder aux données par pointeurs et index décalés. Par contre en ASM, attention de bien y prendre garde si on manipule de la chaîne ou du numérique !
    C'est une sorte d'équivalent du "registre à décalage" électronique alors.

    Merci de ce code et de cette explication

  5. #5
    Expert confirmé

    Avatar de Nono40
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2002
    Messages
    8 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2002
    Messages : 8 640
    Par défaut
    C'est aussi très utile si les données lues/écrites proviennent d'un autre système en Big-endian.

    Dans la pluspart des cas en Delphi sur PC X86 tout est Little-endian et on se pose rarement la question. Mais ce n'est pas le cas avec tous les systèmes. Les systèmes base sur le Motorola 68xxx sont en big-endian.

    Big-endian est aussi la norme des certains protocoles de compmunication : modbus et dérivés par exemple.

    Merci pour ce code ultra court
    Delphi :
    La F.A.Q. , 877 réponses à vos questions !
    264 sources à consulter/télécharger !

  6. #6
    Membre Expert
    Avatar de Dr.Who
    Inscrit en
    Septembre 2009
    Messages
    980
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Septembre 2009
    Messages : 980
    Par défaut
    BSWAP peut être également utile dans certains algorithme de Hash notamment le SHA qui nécessite une inversion des octets en fin de calcul, bswap permettant de ne pas faire appel à un lourd barda de shl/shr.

    on peux aussi l'utiliser dans les conversions de formats de couleurs RGBA <-> ABGR ou autre par combinaison BSWAP r32 et BSWAP r16 ou encore avec ROL ROR.

    il est dommage que SHL et SHR soit présents en Pascal mais que ROL, ROR, BSWAP, XCHG ne soit pas disponible comme opérandes native du pascal.
    cela serait plus facile par moment d'en disposer sans faire appel à une fonction assembleur, surtout que ce sont des instructions disponible depuis les 286/386.
    [ Sources et programmes de Dr.Who | FAQ Delphi | FAQ Pascal | Règlement | Contactez l'équipe ]
    Ma messagerie n'est pas la succursale du forum... merci!

  7. #7
    Membre émérite
    Avatar de Montor
    Homme Profil pro
    Autre
    Inscrit en
    Avril 2008
    Messages
    879
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Autre

    Informations forums :
    Inscription : Avril 2008
    Messages : 879
    Par défaut
    Citation Envoyé par Droïde Système7 Voir le message
    C'est une sorte d'équivalent du "registre à décalage" électronique alors.

    Merci de ce code et de cette explication
    Salut Droïde Système7
    l'ordre des octect est inversé...c'est pour compatibilité avec d'autres protocols...utilise l'affichage en hexadecimal pour visualiser les octets...en hexadecimal deux chiffres (16 * 16) est un octect donc $12345678 (little-endian)le premier octect vaut $78 deuxieme $56...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Showmessagefmt('%x',[SwapIndian($1)]);

  8. #8
    Membre émérite
    Avatar de Montor
    Homme Profil pro
    Autre
    Inscrit en
    Avril 2008
    Messages
    879
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Autre

    Informations forums :
    Inscription : Avril 2008
    Messages : 879
    Par défaut
    Le problème avec les types de base Delphi …souvent il est dite
    les types integer, cardinal ne sont pas garanties qu’ils restent sur 32bit…

Discussions similaires

  1. Réponses: 12
    Dernier message: 08/01/2013, 22h36
  2. Little endian - Big endian
    Par julinho99 dans le forum Ada
    Réponses: 4
    Dernier message: 10/04/2008, 11h13
  3. Conversion little vers big endian
    Par kris1980 dans le forum x86 32-bits / 64-bits
    Réponses: 8
    Dernier message: 16/08/2007, 13h42
  4. Big endian et Little endian?
    Par moon93 dans le forum C
    Réponses: 4
    Dernier message: 07/05/2006, 22h48
  5. Cast et little/big endian
    Par progfou dans le forum C
    Réponses: 8
    Dernier message: 29/03/2006, 18h54

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