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 :

sprintf


Sujet :

C

  1. #1
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    85
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 85
    Par défaut sprintf
    J'ai un probleme probablement du faut que je comprend pas bien le sprintf

    Mon but c'est d'écrire un buffer de 256X256 donc jai 256 message de 256 caractere!

    j'ai donc fait une boucle qui parcourt chaque ligne, mais voila quand j 'appel cela la seul chose qui est imprimé c'est la dernière ligne !

    Quelqu'un a une idée pourquoi ?

    C'est au niveau d'un procfs dans le kernel de linux


    Merci

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
     
    #ifndef __KERNEL__
    #  define __KERNEL__
    #endif
    #ifndef MODULE
    #  define MODULE
    #endif
    #include <linux/module.h>
    #include <linux/kernel.h>
    #include <linux/init.h>
    #include <linux/proc_fs.h>
    #include <linux/sched.h>
    #include <asm/uaccess.h>
    #include <linux/fs.h>
    #include <linux/types.h>
    #include <linux/slab.h>		/* kmalloc() */
    #include <asm/semaphore.h>
    #include <linux/mm.h> 
    #include <linux/wrapper.h> 
    #include <linux/errno.h>
    #include <asm/page.h>
    #include <linux/config.h>
     
    #define MODULE_VERSION "1.0"
    #define MODULE_NAME "spying"
    #define FOOBAR_LEN 256
     
     
     
    static struct proc_dir_entry  *virtual_file;
     
    struct Memoire
    {
       char message[256][256];
    };
     
    struct Memoire pointeurDebut;
     
    int messageRendu=0;
    int start = 0;
    int end=0;
    int nbMessage=0;
     
    static int proc_read_foobar(char *page, char **start,off_t off, int count,int *eof, void *data)
    {
    	int len=0;
    	struct Memoire * bufferMemoire=(struct Memoire *)data;
    	MOD_INC_USE_COUNT;
    	int nbMessageEcrit = 0;
    	if( nbMessage > 255 )
    	{
    		messageRendu = nbMessage%256;
    		end = messageRendu-1;
     
    	}
    	else
    	{
    		messageRendu = 0;
    	}
    	printk("Message rendu avant print : %i",messageRendu);
    	printk("Message Count avant print : %i",count);
    	while(nbMessageEcrit< 256)
    	{
    		if( messageRendu > 255 )
    		{
    			messageRendu =0;
    		}
    		if(  bufferMemoire->message[messageRendu][0] !=  '\0' )
    		{
    			len= sprintf(page,"\nMessage #%i : %s",messageRendu,bufferMemoire->message);
    			printk("Longeur : %i",len);
    			printk("\nMessage #%i : %s",messageRendu,bufferMemoire->message[messageRendu]);
    			int j=0;
    			while(j<256)
    			{
    				bufferMemoire->message[messageRendu][j] =  '\0';
    				j++;
    			}
    		}
    		else
    		{
    			//break;
    		}
    		messageRendu++;
    		nbMessageEcrit++;
    	}
    	printk("Message Longeur : %i",len);
    	messageRendu=0;
    	nbMessage=0;
    	MOD_DEC_USE_COUNT;
    	return len;
    }
     
    static int proc_write_foobar(struct file *file,const char *buffer,unsigned long count,void *data)
    {
    	struct Memoire * messageData=(struct Memoire *)data;
    	//struct fb_data_t *fb_data = (struct fb_data_t *)data;
    	MOD_INC_USE_COUNT;
    	unsigned long longeurMessage = count;
    	if( longeurMessage > 255 )
    	{
    		printk("<1>\nLe message a ete tronque au 256 caractere");
    		longeurMessage = 255;
    	}
    	if( nbMessage > 255 )
    	{
    		messageRendu = nbMessage%256;
    	}
    	printk("Message ecrit : %s \n",buffer);
    	printk("Message count : %i \n",count);
    	printk("Message nbMessage : %i \n",nbMessage);
    	printk("Message messageRendu : %i \n",messageRendu);
    	//printk("Adresse : %i \n",messageData->message[messageRendu]);
    	if(copy_from_user(&messageData->message[messageRendu], buffer, longeurMessage)) 
    	{
    		MOD_DEC_USE_COUNT;
    		return -EFAULT;
    	}
    	messageData->message[messageRendu][longeurMessage] = '\0';
    	end++;
    	messageRendu++;
    	nbMessage++;
    	MOD_DEC_USE_COUNT;
    	return longeurMessage;
    }
     
    static int __init init_procfs_example(void)
    {
    	int rv = 0;
    	//
    	// virutal
    	// 
    	virtual_file = create_proc_entry(MODULE_NAME, 0644, NULL);
    	printk("<1>vitual creer\n");
    	if(virtual_file == NULL) 
    	{
    		return -ENOMEM;
    	}
    	virtual_file->data = &pointeurDebut;
    	virtual_file->read_proc = proc_read_foobar;
    	virtual_file->write_proc = proc_write_foobar;
    	virtual_file->owner = THIS_MODULE;
    	/* everything OK */
    	printk(KERN_INFO "%s %s initialised\n",	MODULE_NAME, MODULE_VERSION);
    	messageRendu=0;
    	nbMessage=0;
    	return 0;
     
     
    static void __exit cleanup_procfs_example(void)
    {
     
    	remove_proc_entry(MODULE_NAME, NULL);
    	//remove_proc_entry(MODULE_NAME, NULL);
    	printk(KERN_INFO "%s %s removed\n",	MODULE_NAME, MODULE_VERSION);
    }
     
    module_init(init_procfs_example);
    module_exit(cleanup_procfs_example);
    EXPORT_NO_SYMBOLS;

  2. #2
    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
    J'ai du mal à comprendre comment tu écris...

    1) Que sont exactement les compteur messageRendu et nbMessageEcrit ?
    2) Que fait la fonction printk() ?
    3) Où est supposé être le sprintf() ?
    4) Comment est initialisé len ?

    5) Que fait exactement la fonction ? Pour chaque message, elle affiche son contenu puis l'efface ?
    6) Les boucles for, tu connais?
    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.

  3. #3
    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 Re: sprintf
    Citation Envoyé par royrremi
    J'ai un probleme probablement du faut que je comprend pas bien le sprintf
    ? Il n'y a pas de sprintf() dans ton code ...
    Mon but c'est d'écrire un buffer de 256X256 donc jai 256 message de 256 caractere!
    C'est pas rien (65536 bytes). Esperons que c'est une donnée statique ou dynamique et pas automatique, et que le 0 final a été compté dans les 256...
    [EDIT]
    Ok, c'est un module Linux.
    • Soit tu as un problème Linux et le bon forum est "Développement Linux",
    • soit tu as un problème C, et dans ce cas, tu réduis le code (en C standard, bien sûr) au minimum, compilable qui montre le problème.

  4. #4
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    85
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 85
    Par défaut
    je m'excuse !
    je remis ma fonction a jour... mais pour compilier il faudrai que le poste mon module en entier .

    Pour ce qui est de la grandeur du buffer ... c'est énorme dans le kernel... mais c'est a des fin éducative.

  5. #5
    Membre éprouvé
    Avatar de granquet
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2005
    Messages
    1 201
    Détails du profil
    Informations personnelles :
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2005
    Messages : 1 201
    Par défaut
    2) Que fait la fonction printk() ?
    fonction unixoide.
    elle ecrit du texte dans les logs du kernel (en version tres simpliste)
    logs du kernel accesible par dmesg (c'est rare que je puisse repondre, j'en profite !)

    tu devrais donner plus de details sur tes "problemes" sur l'objectif de ton module etc etc ...
    --
    si ca peux aider (premiers resultats avec google)
    http://www.lri.fr/~aze/page_c/aide_c/sprintf.html
    ---
    en fait, j'ai du mal a comprendre pourquoi tu fait un sprintf, et jme demande meme si tu voulais pas faire un sscanf ...
    ton char *page, il est deja plein, ou tu veux le remplir avec ta fonction :

  6. #6
    Membre confirmé
    Inscrit en
    Avril 2004
    Messages
    85
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 85
    Par défaut
    merci c'est aussi niaseux que cela !

    ce code ce qu'il fait n'est pas tres compliqué.

    C'est au niveau du kernel de linux. On a une file de message.

    et dans le kernel on a pas acces au aucune librairie standard stdlib ne compile pas !

    j'avais pas compris que sprintf ne faisait qu'écrire dans le buffer page. Donc c'est normal que le code qu'il y a ici me retourne tjrs que la dernier copie effectué.

    Merci du petit lien j'avais pourtant cherché.

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

Discussions similaires

  1. Connaitre la taille du résultat de sprintf
    Par gege2061 dans le forum C
    Réponses: 6
    Dernier message: 09/01/2006, 14h56
  2. [Débutant(e)] equivalence de sprintf en JAVA
    Par GuillaumeCorbineau dans le forum API standards et tierces
    Réponses: 4
    Dernier message: 06/09/2005, 19h18
  3. [débutant] equivalent à sprintf pour les std::string
    Par Biosox dans le forum SL & STL
    Réponses: 22
    Dernier message: 26/08/2005, 12h46
  4. pb sprintf
    Par peuf23 dans le forum Langage
    Réponses: 4
    Dernier message: 02/08/2005, 17h46
  5. sprintf : le point devient virgule ?!
    Par jula dans le forum C++
    Réponses: 4
    Dernier message: 17/09/2004, 12h50

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