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

Entrée/Sortie Java Discussion :

JNI malloc(): memory corruption


Sujet :

Entrée/Sortie Java

  1. #1
    Membre confirmé
    Inscrit en
    Avril 2008
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Avril 2008
    Messages : 95
    Par défaut JNI malloc(): memory corruption
    Bonsoir !

    J'ai un problème qui se produit de temps en temps sur mon appli qui tourne dans une JVM et appelle du code C++ via une couche JNI.
    De manière aléatoire, j'obtiens un crash complet de la JVM avec la trace d'erreur suivante :

    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
     
    *** glibc detected *** ./monappli.exe: malloc(): memory corruption: 0x08a2b7c8 ***
    ======= Backtrace: =========
    /lib/i686/libc.so.6[0xb7cea8c6]
    /lib/i686/libc.so.6(__libc_malloc+0x94)[0xb7cec2a4]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x630a60a]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x63b842f]
    [0xb36dd792]
    [0xb342ceeb]
    [0xb342cfcd]
    [0xb342ce67]
    [0xb37d6420]
    [0xb342ce67]
    [0xb342cfcd]
    [0xb342d4a9]
    [0xb342cfcd]
    [0xb342cfcd]
    [0xb342cfcd]
    [0xb35c743d]
    [0xb35c5c7c]
    [0xb35bcd6d]
    [0xb36f0d72]
    [0xb342cfc0]
    [0xb342cfcd]
    [0xb342cfcd]
    [0xb342cfcd]
    [0xb342a2cc]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x621b25d]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x630f998]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x621ab70]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x621abfd]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x628b265]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x63a03dd]
    /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so[0x6310ac9]
    /lib/i686/libpthread.so.0[0xb7e204e2]
    /lib/i686/libc.so.6(clone+0x5e)[0xb7d5347e]
    ======= Memory map: ========
    06000000-0642a000 r-xp 00000000 08:07 32170      /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so
    0642a000-06444000 rw-p 0042a000 08:07 32170      /usr/java/jdk1.6.0_13/jre/lib/i386/client/libjvm.so
    06444000-06864000 rw-p 06444000 00:00 0
    08048000-0829b000 r-xp 00000000 08:08 585427     /home/monappli.exe
    0829b000-082a0000 rw-p 00253000 08:08 585427     /home/monappli.exe
    082a0000-08d71000 rw-p 082a0000 00:00 0          [heap]
    70000000-70930000 rwxp 70000000 00:00 0
    70930000-72760000 rwxp 70930000 00:00 0
    72760000-79481000 rwxp 72760000 00:00 0
    etc ...
    Il semblerait que le problème intervienne dans le tas :
    malloc(): memory corruption: 0x08a2b7c8
    Et :
    082a0000-08d71000 rw-p 082a0000 00:00 0 [heap]
    Après avoir exploré plusieurs pistes pour trouver le problème, il semble que ceci se produise à la suite d'une passe du garbage collector en "Full GC".
    Quelqu'un pourrait-il m'aider à confirmer ou infirmer la piste de JNI + Full GC pour ce qui est de la cause du problème ?

    Merci d'avance !

  2. #2
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    généralement, ce genre de crash est du à une mauvaise manip de ton code JNI. (désallocation d'un truc toujours utilisé par la JVM ou autre). Difficile à dire comme ça, d'autant plus que ton stacktrace est incomplet. (Tes modules jni sont bien compilé avec infos de débuggage?). Des outils comme valgrind pourraient peut etre t'aider à localiser le problème.

Discussions similaires

  1. JMS génère memory corruption
    Par lapin_hobbit dans le forum Général Java
    Réponses: 0
    Dernier message: 20/12/2011, 15h47
  2. memory corruption error
    Par CHATon dans le forum Débuter
    Réponses: 23
    Dernier message: 21/07/2009, 13h15
  3. [C] Malloc, memory Corruption
    Par publicStaticVoidMain dans le forum C
    Réponses: 2
    Dernier message: 18/05/2009, 01h39
  4. Réponses: 0
    Dernier message: 18/09/2007, 19h07
  5. memory corruption
    Par GLSpirit dans le forum C++
    Réponses: 2
    Dernier message: 23/05/2007, 08h42

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