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 :

Attempted to read or write protected memory. This is often an indication that other memory is corrupt.


Sujet :

C#

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut Attempted to read or write protected memory. This is often an indication that other memory is corrupt.
    Bonjour,

    J'ai créé une dll en C# (.NET 2.0 et 3.5) qui fait appel à des méthodes venant d'une librairie développée en C/C++.

    Cette dernière est utilisée pour échanger des données à travers le web.

    J'ai rendu la dll visible pour pouvoir l'instancier en VB6.

    Lors de l'utilisation d'une des méthodes de la librairie, j'ai le message suivant:
    Attempted to read or write protected memory. This is often an indication that other memory is corrupt.
    Le problème se produit sous Vista

    J'ai testé toute une série de choses:
    • Ajout de la balise [SecurityPermission(SecurityAction.Assert, Unrestricted = true)]
    • Supprimé toutes les optimisations de compilation
    • Passé d'une version .NET 2 à 3.5


    Voilà le code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    /// <summary>
            /// Retourne le nom du fichier réponse
            /// </summary>
            /// <param name="hdleConnection"></param>
            /// <returns></returns>
            [DllImport("Module.dll", EntryPoint = "getResponse")]
            [SecurityPermission(SecurityAction.Assert, Unrestricted = true)]
            private static extern string getResponse(IntPtr hdleConnection);
    Existerait-il une bonne âme qui a déjà eu le même problème et qui aurait trouvé une solution, ou qui aurait un tuyau (ou plusieurs), une direction à me donner?

    Merci pour votre aide.


    Damzz

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    C'est un Vista 32 ou 64 bits ?

    Si c'est 64, peut-être que ta DLL est compilée en 32 bits, et que ton programme tourne en 64. Pour forcer ton programme à s'exécuter en 32 bits : dans l'onglet "Générer" des propriétés du projet, mets l'option "Plate-forme cible" à "x86"

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par tomlev Voir le message
    C'est un Vista 32 ou 64 bits ?

    Si c'est 64, peut-être que ta DLL est compilée en 32 bits, et que ton programme tourne en 64. Pour forcer ton programme à s'exécuter en 32 bits : dans l'onglet "Générer" des propriétés du projet, mets l'option "Plate-forme cible" à "x86"
    Bonjour,

    Il s'agit bien d'un Vista 32 bits, mais le projet était compilé en "Any configuration". J'ai recompilé en créant une plateforme x86, mais le souci est toujours là.

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    OK...

    Tu es sûr que la signature de la méthode correspond bien au prototype C++ ?
    Comment initialises-tu le pointeur que tu passes en paramètre à la méthode ?

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par tomlev Voir le message
    OK...

    Tu es sûr que la signature de la méthode correspond bien au prototype C++ ?
    Comment initialises-tu le pointeur que tu passes en paramètre à la méthode ?
    Oui, je sous XP cela fonctionne.

    Voilà la ligne qui exécute la méthode extraite avec les déclarations:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Private IntPtr _ConnectionHandle;
    (...)
    _ConnectionHandle = BeginSession();
    (...)
     
    String response = getResponse(_ConnectionHandle);
    (...)

  6. #6
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    et en debug, tu as vérifié que le _ConnectionHandle récupéré n'est pas null (IntPtr.Zero) ?

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par tomlev Voir le message
    et en debug, tu as vérifié que le _ConnectionHandle récupéré n'est pas null (IntPtr.Zero) ?
    Le test est déjà fait préalablement pour voir si la connexion est bien établie. J'ai quand même fait le test et... c'est le même message.

  8. #8
    Expert éminent
    Avatar de smyley
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    6 270
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 6 270
    Points : 8 344
    Points
    8 344
    Par défaut
    Citation Envoyé par tomlev Voir le message
    Si c'est 64, peut-être que ta DLL est compilée en 32 bits, et que ton programme tourne en 64. Pour forcer ton programme à s'exécuter en 32 bits : dans l'onglet "Générer" des propriétés du projet, mets l'option "Plate-forme cible" à "x86"
    Quand c'est un problème du genre il me semble que ça génère un crash avec une histoire d'image invalide ...

    Ceci dit le "String response = cis_getResponseDocument(_ConnectionHandle);" me fait bizarre (une fonction en C++ qui retourne un pointeur vers une chaine et qui marche ? ).
    Si tu essayes de faire les mêmes opérations directement en C++ ça fait quoi ?
    Tu as accès aux sources de la dll ?

  9. #9
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 753
    Points
    39 753
    Par défaut
    Citation Envoyé par smyley Voir le message
    Quand c'est un problème du genre il me semble que ça génère un crash avec une histoire d'image invalide ...
    Ah oui, exact...

    Citation Envoyé par smyley Voir le message
    Ceci dit le "String response = cis_getResponseDocument(_ConnectionHandle);" me fait bizarre (une fonction en C++ qui retourne un pointeur vers une chaine et qui marche ? ).
    Il me semble que c'est géré par le marshalling... d'ailleurs le programme Damzz fonctionne sous XP apparemment

  10. #10
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par tomlev Voir le message
    Ah oui, exact...


    Il me semble que c'est géré par le marshalling... d'ailleurs le programme Damzz fonctionne sous XP apparemment
    Tout à fait, c'est uniquement sous Vista.

  11. #11
    Expert éminent
    Avatar de smyley
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    6 270
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 6 270
    Points : 8 344
    Points
    8 344
    Par défaut
    Citation Envoyé par Damzz Voir le message
    Tout à fait, c'est uniquement sous Vista.
    Citation Envoyé par smyley Voir le message
    Si tu essayes de faire les mêmes opérations directement en C++ ça fait quoi ?
    Tu as accès aux sources de la dll ?

  12. #12
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Pour info, j'ai contacté les concepteurs de la méthode,... ils ont constatés le problème et ils recherchent une solution.

    Solution -ou explication- que je vous ferai parvenir...

  13. #13
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    28
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 28
    Points : 20
    Points
    20
    Par défaut
    Pour ceux que cela intéresse.

    J'ai finalement trouvé un workaround.
    La dll était écrite en C pour être utilisée dans des applications en C. Et renvoyer une chaine, est un peu limite.

    Dès lors, j'ai modifié l'import pour que le retour soit utilisé avec le type IntPtr, (qui représente un pointeur) et le Marshal pour en faire ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    /// <summary>
            /// Retourne le nom du fichier réponse
            /// </summary>
            /// <param name="hdleConnection"></param>
            /// <returns></returns>
            [DllImport("Module.dll", EntryPoint = "getResponse")]
            [SecurityPermission(SecurityAction.Assert, Unrestricted = true)]
            private static extern IntPtr getResponse(IntPtr hdleConnection);
     
    (...)
     
    IntPtr hRespo = getResponse(_connectionHandle)
    string sRespo = Marshal.PtrToStringAnsi(hRespo);
    Et voilà

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 27/03/2014, 21h57
  2. Réponses: 1
    Dernier message: 28/09/2009, 21h41
  3. Attempted to read or write protected memory
    Par identifiant_bidon dans le forum Général Dotnet
    Réponses: 4
    Dernier message: 06/02/2008, 14h37
  4. Réponses: 2
    Dernier message: 22/03/2007, 16h56

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