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

Android Discussion :

C natif print & log.redirect-stdio android redirection logcat


Sujet :

Android

  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    190
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 190
    Points : 182
    Points
    182
    Par défaut C natif print & log.redirect-stdio android redirection logcat
    bonjour,

    je travaille sur un sujet complexe, j'ai une librairie c/c++ qui est compilé et utilisé par le jni/java d'android ou de objective c de IOS

    Sur android je cherche un bug, pour cela j'utilise des printf pour localiser un plantage dans un contexte de thread au niveau C core

    a ce stade je ne peux pas utiliser les logs android a ce niveau.

    Il faut déjà être root, ensuite je dois modifier un fichier build.prop sous /sytem et j'ajoute la ligne ci dessous en fin de fichier de build.prop
    log.redirect-stdio=true

    par défaut les stderr/stdout sont redirigés sur >/dev/null dans android, or j'ai besoin de debuger la propriété log.redirect-stdio=true permet de rediriger
    les stderr/stdout directement dans le logcat, ce qui me permet de voir mes printf injecter dans les programmes C du core dont les fonctions sont appelées par le jni.

    Ca marche très bien avec des android 4, mais pas en android 7, j'utilise le même code et la même configuration, mais sur A7 je n'ai plus mes printf.

    Je cherche à comprendre la différence entre les deux versions


    https://stackoverflow.com/questions/...in-android-ndk

  2. #2
    Membre habitué
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    190
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 190
    Points : 182
    Points
    182
    Par défaut
    J'ai fini par trouver l'explication, Android 4.4 kitkat fonctionne avec la machine virtuelle dalvik, la propriété log.redirect-stdio ne fonctionne que pour cette machine virtuelle

    à partir d'android 5 la VM dalvik est remplacé par ART android runtime, mais la propriété log.redirect-stdio ne semble pas avoir été reprise du moins pour rediriger les printf du code c natif.

    c'est pas cool. faut que je trouve autre chose pour debuger le code natif de mes libraries communes pour android/ios.

  3. #3
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 691
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 691
    Points : 20 224
    Points
    20 224
    Par défaut
    Android studio supporte désormais le débuggage de code natif , tu devrais donc pouvoir faire du pas à pas dans ton code C (sousréserve que ce soit pas un binaire pré compilé, mais compilé par AS)
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 23/04/2019, 03h12
  2. Erreur Log dans Eclipse Android
    Par nabil.brarou dans le forum Android
    Réponses: 1
    Dernier message: 12/08/2013, 23h31
  3. Réponses: 10
    Dernier message: 05/11/2011, 23h20
  4. Réponses: 12
    Dernier message: 23/04/2008, 17h46
  5. [ASE 12.5.1] Redirection de PRINT dans un fichier de log
    Par zayro dans le forum Adaptive Server Enterprise
    Réponses: 1
    Dernier message: 21/04/2006, 12h48

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