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 :

Opération pour positionner un bit sur un byte


Sujet :

C

  1. #1
    Membre du Club
    Profil pro
    Developer
    Inscrit en
    Juin 2004
    Messages
    194
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Developer

    Informations forums :
    Inscription : Juin 2004
    Messages : 194
    Points : 58
    Points
    58
    Par défaut Opération pour positionner un bit sur un byte
    Bonjour,

    Il s'agit de programmer un circuit intégré ce CI possède un registre de 8 bits
    et les 6 premiers bits (0->5) permettent de fixer le niveau de volume du minimum: 00 (00 0000) au maximum: 3F (11 1111).

    Cette valeur est contenue dans une variable: unsigned char variable1


    Actuellement le programme est formaté pour cette configuration et donc on ne peut que changer le niveau de volume_periph. Mais le 7 ème bit permet d'activiter une autre fonctionnalité. Si je veux activité cette fonctionnalité, je dois mettre le 7ème bit à 1.

    J'utilise une deuxième variable : unsigned char binaire J'ai donc fait une opération OU avec cette variable qui devrait valloir donc 64 car cela represente en binaire ceci : 100 0000 et si je somme (operation OU) cette variable avec la variable volume :

    exemple niveau de volume 30 :
    11 0000 (30)
    + 100 0000 (64)
    ----------------
    111 0000 (70)

    C'est ce que j'obtient avec DevC++ mais avec mon IDE pour mon µC j'ai une autre valeur.

    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
    22
    23
    24
     
    #include <stdio.h>
     
    unsigned char variable1;
     
    unsigned char binaire;
    unsigned char binaireinv;
     
     
    int main()
    {
    int i;
    variable1=0x31;
     
    binaire=64;
    binaireinv=63;     
     
    printf("variable1 avant: %X\n",variable1);
     
    variable1= variable1|binaire;
     
    printf("variable1 apres: %X\n",variable1);
     
    getch();
    Voici le problème auquel je suis confronté, en fesant un printf de la valeur
    volume_periph, j'obtient la valeur 74 que je ne comprend pas bien car si on convertit simplment 30 en binaire on obtient 01 1110 en sommant avec le 64 on aura un 94 mais c'est pas le cas. Donc ma question est de savoir comment on peut faire l'operation binaire pour choisir le format de 30.

    Deplus le niveau maximal est depassé car il y a saturation du signal alors que à 30 le signal était audible donc je pense qu'il faut un algorithme qui gere le niveau si le bit 7 est à 1 ou bien c'est le IC qui ne gère pas correctement les fonctions associées aux bits?

    Pouvez vous m'aider ?

    Merci

  2. #2
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 945
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 945
    Points : 5 659
    Points
    5 659
    Par défaut
    Hoa,

    - Tu n'as pas de variable = 30 dans ton code.

    - le plus proche serait 0x31, à ceci près que c'est de l'hexa, donc = 49 en décimal.

    Il faut faire attention à ce qu'on écrit, et ne pas allègrement mélanger les bases.
    Si les cons volaient, il ferait nuit à midi.

  3. #3
    Membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    54
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 54
    Points : 67
    Points
    67
    Par défaut
    En réponse a ton problème je te conseille cette page:
    http://c.developpez.com/cours/bernar...gne/node91.php
    j'espère que cela pourra vous aider.

  4. #4
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    comme le dit droggo, c'est vrai qu'il y a des confusions dans ce que tu dis.

    D'abord les confusions tu compares et additionnes les chiffres en base10 et base16:
    Citation Envoyé par Aliveli Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    exemple niveau de volume 30 :
        11 0000            // ceci fait 48 en decimal ou encore 30 en hexa
    +  100 0000            // ceci fait 64 en décimal ou encore 40 en hexa
    ----------------
       111 0000            // ceci fait 112 en décimal ou encore 70 en hexa
    La fonction qui permet de positionner ton registre devrait ressembler à quelque chose comme cela

    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
     
    vois SetRegister(const int Feature, const int Volume)
    {
    int val_registre_ic = 0;         // intialise la valeur
    int new_volume = Volume;
       if(Feature != 0)
       {
          val_registre_ic = 0x40;  // positionne le bit de la fonctionnalité
       }
     
       // force le volume à être dans le range 0 -> 0x3f
       new_volume &= 0x3f;
     
       // positionne le volume
       val_registre_ic |= new_volume;
     
       // maintenant, il reste à transferer la valeur dans le registre du circuit intégré
    }
    Je ne connais pas le nom de la fonctionnalité du bit 6, donc je t'engage a changer le nom de la variable 'Feature'
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  5. #5
    Membre du Club
    Profil pro
    Developer
    Inscrit en
    Juin 2004
    Messages
    194
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Developer

    Informations forums :
    Inscription : Juin 2004
    Messages : 194
    Points : 58
    Points
    58
    Par défaut
    Merci,


    en fait oui dsl je n'ai oas été clair en fait je ne veut pas specialment à positionner sur un bit donné mais faire en sorte que les valeurs n'excedent pas les limites (3F) je vais tester la fonction de ram_0000.

    Merci à tous.

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par Aliveli Voir le message
    Bonjour,

    Il s'agit de programmer un circuit intégré ce CI possède un registre de 8 bits
    et les 6 premiers bits (0->5) permettent de fixer le niveau de volume du minimum: 00 (00 0000) au maximum: 3F (11 1111).

    Cette valeur est contenue dans une variable: unsigned char variable1

    Actuellement le programme est formaté pour cette configuration et donc on ne peut que changer le niveau de volume_periph. Mais le 7 ème bit permet d'activiter une autre fonctionnalité. Si je veux activité cette fonctionnalité, je dois mettre le 7ème bit à 1.
    Apprendre à utiliser les opérateurs bit à bit...

    http://emmanuel-delahaye.developpez.com/bits.htm
    Pas de Wi-Fi à la maison : CPL

Discussions similaires

  1. Réponses: 31
    Dernier message: 13/09/2010, 09h27
  2. Mémoire dispo pour appli 32 bits sur systeme 64 bits
    Par qdaemon_fr dans le forum Windows
    Réponses: 1
    Dernier message: 26/05/2009, 06h49
  3. Padding pour aligner paquet IP sur 32-bit.
    Par elraton dans le forum Développement
    Réponses: 0
    Dernier message: 17/12/2008, 11h24
  4. Excel : Macro pour positionnement sur ligne
    Par danielh dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 19/10/2006, 08h45
  5. opérations sur les bits d'un byte
    Par petitours dans le forum C++Builder
    Réponses: 4
    Dernier message: 10/02/2004, 20h42

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