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 :

Warning compilation conversion


Sujet :

C

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    228
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 228
    Par défaut Warning compilation conversion
    Bonjour,
    je suis entrain de déveloper un programme et j'ai un warning
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    attention : assignment makes pointer from integer without a cast [-Wint-conversion]
       if ((tmp = sbrk(size)) == NULL)
    voila mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     Unit                *g_unit= NULL;
     
     
     int                    getMemory()
     {
       Unit              *tmp;
     
       size = getSize();
       if ((tmp = sbrk(size)) == NULL)
         return 0;
       printf("%x", tmp);
      return (0);
    }
    je ne comprend pas mon erreur, pouvez vous m'aider ? merci d'avance

  2. #2
    Expert confirmé
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 599
    Par défaut
    Bonjour,

    L'include indiquant bien que sbrk() retourne un void* a-t-il été fait? (<unistd.h> il me semble)

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    228
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 228
    Par défaut
    Bonjour,
    l'include a bien étais inclue dans le projet.
    Il trouve bien le prototype.

  4. #4
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Bonjour,

    size est-il du bon type ?
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    228
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 228
    Par défaut
    oui size est de type size_t

  6. #6
    Expert éminent

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 202
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 202
    Par défaut
    "assignement"
    le seul "assignement", c'est unit = sbrk(...). Que retourne sbrk()? je parierai sur un size_t (donc un entier), plutot que void*.

  7. #7
    Membre Expert

    Homme Profil pro
    Responsable des études
    Inscrit en
    Mars 2009
    Messages
    553
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2009
    Messages : 553
    Par défaut
    Salut,

    sbrk() semble, sur certains systèmes, attendre un pointeur comme argument. Quel est le type de 'size' ?

  8. #8
    Membre très actif
    Avatar de sambia39
    Homme Profil pro
    No Comment
    Inscrit en
    Mai 2010
    Messages
    550
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : No Comment
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Mai 2010
    Messages : 550
    Par défaut
    Bonsoir,
    Citation Envoyé par vodkline Voir le message
    Bonjour,
    je suis entrain de déveloper un programme et j'ai un warning
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    attention : assignment makes pointer from integer without a cast [-Wint-conversion]
       if ((tmp = sbrk(size)) == NULL)
    je ne comprend pas mon erreur, pouvez vous m'aider ? merci d'avance

    C'est tout à fait normale que le compilateur émet des warnings et ceux pour des raisons suivantes.
    La première est que sur certain système d'exploitation comme Mac Os ou UNIX; émettent tous deux des warnings en précisant que "sbrk is deprecated void *sbrk(int)" deuxième points le warning vient également du fait que vous avez effectué une conversion de pointeur en un entier sans utilisation de l'opérateur de conversion.

    Comme sur certain système d'exploitation l'utilisation de "sbrk" n'est pas recommandée il faut dans ce cas (si je peux le dire ainsi) contourné le problème en utilisant le mots-clés "extern" en redéfinisant la fonction et ainsi permettre au compilateur de connaitre/importer la fonctions "adéquat" définies dans le fichier source "unistd h". Sur GNU/Linux pas besoin de externe sauf si peut-être dans vos option de compilation vous exigez plus. Tout de même sur Unix et Mac Os le warning restera d'actualité sauf si vous ignorez le warning.
    Voici un exemple: Attention le code-souces ci-dessous est susceptible de comporter des erreurs.
    -> Cas 1 extern sbrk mise sous commentaire.
    Code C : 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
     
    /*
     ============================================================================
     Name        : source.c
     Date        : 13/02/2017
     Author      : SAMBIA39
     Version     : 0.1
     Copyright   : Copyright © 2017 SAMBIA39 All rights reserved.
     Description : Ansi-style
     ============================================================================
     */
     
    #define MAXSIZE_UINT 10		/* Taille max d'une variable unsigned int  */
    #define MAXSIZE_CHAR 50		/* Taille max d'une variable unsigned char */
     
    #include <errno.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <stdint.h>
    #include <unistd.h>
     
     
    /*
    *	La fonction utilise sbrk qui permet d'incrémenté 
    *	l’espace de données du programme.
    *      Nul permet d’obtenir l’emplacement de la limite actuelle.
    *      le contraire a pour effet d’allouer de la mémoire au processus.
    *	la reduire à  pour  effet de désallouer de la mémoire.
    *
    *	/!\ Attetion sur certain système la fonction est "deprecated"
    */
    void *f_get_sbrk_mem_init( intptr_t size ){
     
    	void *p = NULL;
    	extern void *sbrk(intptr_t);
    	if( ((void*)-1) == ( p = sbrk(size) ) )
    		return ( (void*)-1 );
    	memset( p, 0x00, size );
    	return ( p );
    }
     
    /*
    *	Fonction d'informations
    */
    void f_print_addr( const char*p_str, void *pData ){
    	fprintf( stdout, "(%s)\t:%p\n",p_str, pData );
    }
     
    int main( void ){
     
    	unsigned int i = 0;
    	unsigned int *ptr_uint = NULL;
     
    	/*
    	* Attention il faut être attentif a la taille 
    	* des élemnts que l'on souhaites. Cas contraire
    	* sela résultera par des erreurs.
    	*/
    	ptr_uint = f_get_sbrk_mem_init( 
    		MAXSIZE_UINT*sizeof(unsigned int) ); 
    	if(	((void*)-1) == (void*)ptr_uint )
    		return EXIT_FAILURE;
     
    	f_print_addr( "Var ptr_uint", (void*)ptr_uint );
     
    	/*
    	*	Initialisation & affichage 
    	*/
    	for( i = 0; i < MAXSIZE_UINT; i++ ){
    		*(ptr_uint+i) = i;
    		fprintf( stdout, "(%d)\t:%d\n", i,
    			*(ptr_uint+i) );
    	}
     
    	return (EXIT_SUCCESS);
    }

    Code Sortie : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    root@vm:~$ gcc -std=c99 -Wall -pedantic -Werror -g *.c -o Deb
    source.c: In function ‘f_get_sbrk_mem_init’:
    source.c:36:27: error: implicit declaration of function ‘sbrk’ [-Werror=implicit-function-declaration]
      if( ((void*)-1) == ( p = sbrk(size) ) )
                               ^~~~
    source.c:36:25: error: assignment makes pointer from integer without a cast [-Werror=int-conversion]
      if( ((void*)-1) == ( p = sbrk(size) ) )
                             ^
    cc1: all warnings being treated as errors
    root@vm
    Cas deux
    Code c : 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
     
    /*
    *	La fonction utilise sbrk qui permet d'incrémenté 
    *	l’espace de données du programme.
    *   Nul permet d’obtenir l’emplacement de la limite actuelle.
    *   le contraire a pour effet d’allouer de la mémoire au processus.
    *	la reduire à  pour  effet de désallouer de la mémoire.
    *
    *	/!\ Attetion sur certain système la fonction est "deprecated"
    */
    void *f_get_sbrk_mem_init( intptr_t size ){
     
    	void *p = NULL;
    	extern void *sbrk(intptr_t);
    	if( ((void*)-1) == ( p = sbrk(size) ) )
    		return ( (void*)-1 );
    	memset( p, 0x00, size );
    	return ( p );
    }
    Code Sortie : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    root@vm:~$ gcc -std=c99 -Wall -pedantic -Werror -g *.c -o Deb
    root@vm:~$ ./Deb 
    (Var ptr_uint)	:0x8a8f000
    (0)	:0
    (1)	:1
    (2)	:2
    (3)	:3
    (4)	:4
    (5)	:5
    (6)	:6
    (7)	:7
    (8)	:8
    (9)	:9
    root@vm:~$

    Tout de même, si l'on souhaite allouer du mémoire l'idéal reste la fonction d'allocation "malloc". "sbrk" est à utiliser dans des cas bien précis et justifier de plus, quand vous sollicitez de la mémoire, il faudrait également rendre ce qui vous a été prêté. Cependant, dans quels buts utilisiez-vous "sbrk" ?
    à bientôt.

  9. #9
    Membre Expert
    Inscrit en
    Mars 2005
    Messages
    1 431
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 1 431

Discussions similaires

  1. Réponses: 4
    Dernier message: 22/12/2008, 16h17
  2. warnings compilation wx 2.9 (svn)
    Par gbdivers dans le forum wxWidgets
    Réponses: 0
    Dernier message: 11/11/2008, 18h50
  3. [COMPILER] Conversion MATLAB vers C++
    Par milach dans le forum MATLAB
    Réponses: 5
    Dernier message: 07/05/2008, 11h47
  4. [Compiler] Conversion Matlab C++ builder
    Par nadjib2007 dans le forum MATLAB
    Réponses: 5
    Dernier message: 22/07/2007, 14h02
  5. Warning : Compilation Bcc 5.5
    Par Henri dans le forum Autres éditeurs
    Réponses: 1
    Dernier message: 10/01/2006, 10h39

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