Précédent   Forum des professionnels en informatique > Systèmes > Linux
Linux Forum d'entraide sur le système Linux. Avant de poster -> Tutoriels Linux, F.A.Q Linux
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 14/08/2007, 19h17   #1
Candidat au titre de Membre du Club
 
Inscription : juin 2007
Messages : 52
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 52
Points : 11
Points : 11
Par défaut Champs de bits & noyau linux

Bonjour,

Je suis actuellement en train d'écrire un driver sous Linux (donc dans l'espace noyau) pour un carte d'acquisition entrees/sorties.
Je suis actuellement en train d'essayer de modifier certains registres de ma carte. Donc pour les modifier, et pour rendre mon code bien plus lisible que de simples valeurs hexadécimales, je souhaite utiliser les champs de bits. Les fonctions que j'utilise sont donc "inb()" et "outb()".
Pour écrire certains bits a '1' et d'autres à '0', j'utilise la méthode suivante:
- lecture de mon registre actuel en faisant un "inb()"
- copie de celui-ci dans mon champ de bits
- définition des bits
- ecriture dans le registre avec "oub()"

Mon programme ressemble donc à ca:

typedef struct{
unsigned char bit0 :1;
[...]
}CHAMP1;

{
[...]
CHAMP champ;
[...]
champ=inb(reg);
champ.bit0=1;
out(champ,reg);
[...]
}

Lorsque je compile j'ai les erreurs suivantes:
- "incompatible type in assignment" pour la ligne "champ=inb(reg);"
- "incompatible type for argument 1 of 'outb'" pour la ligne "out(champ,reg);"

Auriez-vous une idée pour résoudre ces erreurs ?
J'ai essayé de typecasté avec (unsigned char), (char) mais ça ne fonctionne toujours pas...

Je vous remercie d'avance pour votre aide.
damdam78 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/08/2007, 11h16   #2
Membre émérite
 
Inscription : mai 2002
Messages : 727
Détails du profil
Informations forums :
Inscription : mai 2002
Messages : 727
Points : 982
Points : 982
Salut

Vérifie les types que tu utilise (déjà dans le bout de code que tu donne, la structure que tu déclare (CMAMP1) n'est pas celle que tu utilise (CHAMP)... Je suppose que c'est une erreur de frappe en recopiant ici

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include <stdlib.h>
 
typedef struct {
  unsigned char bit0 :1; 
} CHAMP;
 
CHAMP
inb(int i)
{
  CHAMP r;
  r.bit0 = 0;
  return(r);
} /* inb() */
 
void
out(CHAMP champ, int reg)
{
} /* out() */
 
 
int
main(int argc, char *argv[])
{
  CHAMP champ;
  int reg = 0;
 
  champ=inb(reg);
  champ.bit0=1;
  out(champ,reg);
 
  exit(EXIT_SUCCESS);
} /* main() */
Ceci se compile avec pour seul warning:
foo.c:4: warning: type of bit-field `bit0' is a GCC extension
__________________

Smortex

Les FAQ Assembleur - Linux
In The Beginning Was The Command Line Neal Stephenson
Smortex est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/08/2007, 10h13   #3
Candidat au titre de Membre du Club
 
Inscription : juin 2007
Messages : 52
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 52
Points : 11
Points : 11
Bonjour,

Merci pour ton aide. En effet tu as raison, j'ai comis une erreur en recopiant. C'est bien CHAMP

Par contre toi tu définis les fonctions inb() et outb() alors que se sont deux fonctions déja existantes...

J'ai réussi en castant de la manière suivante:
*(unsigned char *)&champ=(unsigned char)inb(reg);

outb(*(unsigned char *)&champ);

Merci pour tin aide en tout cas !!
damdam78 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/08/2007, 16h57   #4
Membre Expert
 
Avatar de SnakemaN
 
Bidouille-tout Android
Inscription : juillet 2006
Messages : 871
Détails du profil
Informations personnelles :
Âge : 27
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations professionnelles :
Activité : Bidouille-tout Android

Informations forums :
Inscription : juillet 2006
Messages : 871
Points : 1 102
Points : 1 102
Super si c'est résolu, mais n'oublie pas le petit en bas de page
__________________
C'est le signe d'un fou, qu'avoir honte d'apprendre
Ubuntu 10.04 Lucid Lynx @home
LE guide libre Linux & Ubuntu pour tous : Simple comme Ubuntu
SnakemaN est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 04h44.


 
 
 
 
Partenaires

Hébergement Web