Sauvegarder son Android phone the Unix way…

Bien, je poursuis donc mon exploration d’Android et surtout ma préparation au « grand saut » qui est le changement de ROM. Avec ce type de passage il convient de prendre toutes ces précautions. Les choses ne se déroulent que rarement « comme prévues ».

La sauvegarde des données du téléphone apparaît presque comme le plus facile: une app du type Helium vous permet facilement de sauvegarder des données pas essentielles mais parfois importantes (sms par exemple ou logs des appels). D’autres, peut être plus importantes, peuvent faire l’objet d’une plus grande attention comme vos contacts. Deux solutions: une app comme Bump (si vous avez un iPad ou une tablette ou un autre téléphone) ou la sauvegarde via un clic gauche, puis « Import/Export » on choisit une formule (export sur SD ou SIM card etc…) et hop! Perso j’ai fait le choix de les sauvegarder sur ma carte SD + d’utiliser Bump. Deux sécurités valent mieux qu’une.

Une fois ces données superficielles (mais néanmoins importantes) on peut se pencher plus avant sur la restauration du téléphone en lui-même. La ROM en clair. Si je foire malencontreusement un flashage, comment je peux retrouver ma rom originel? Ben je fais un NAND-backup sur une carte SD via ClockWorkMod. Chez moi cela donne:

[root@hades 2013-06-18.14.13.06_backup]# ls
boot.img      data.ext4.tar.a  recovery.img       system.ext4.tar.b
cache.ext4.tar    data.ext4.tar.b  recovery.log
cache.ext4.tar.a  data.ext4.tar.c  system.ext4.tar
data.ext4.tar     nandroid.md5     system.ext4.tar.a

Sont donc sauvegardées les partitions /boot, /data, /system, /cache et /recovery . Cependant nulle trace de la partition /EFS. En étant parano, si ça se passe mal /EFS peut être corrompu. Si /EFS est corrompu et que vous avez pas de sauvegardes c’est le brick assuré. En effet /EFS contient toutes les données de connexion au réseau téléphonique, en particulier votre précieux International Mobile station Equipment Identity (aka IMEI). Si on en croit Wikipedia: « The IMEI number is used by a GSM network to identify valid devices ». Autant dire qu’il ne faut pas le perdre sinon vous ne pouvez plus accéder au réseau téléphonique avec votre … téléphone. Un peu balôt quoi…
J’ai donc sauvegardé /EFS et ce de façon bien plus simple que les nombreux tutos à base d’installations de *.exe en folie. En fait j’ai juste fait ça, après avoir isolé ma partition EFS grâce à mount:

shell@android:/ $ su
root@android:/ # dd if=/dev/block/mmcblk0p3 of=/storage/extSdCard/efs.rfs
40960+0 records in
40960+0 records out
20971520 bytes transferred in 4.489 secs (4671757 bytes/sec)

Cela m’a crée un magnifique fichier *.rfs . Le RFS, comme son nom ne l’indique pas, est un format de fichier propre à Samsung, le Linux Robust File System . Je voulais quand même m’assurer que tout y était. J’ai donc regagné mon bash favori et:

[xxx@hades ~]$ adb pull /storage/extSdCard/efs.rfs SGS3/
5442 KB/s (20971520 bytes in 3.763s)

Puis ensuite:

[root@hades ~]# mount -o loop SGS3/efs.rfs /mnt/rfs/
[root@hades ~]# ls /mnt/rfs/
00000000.authtokcont  FactoryApp     imei         nv.log      wv.keys
bluetooth         gyro_cal_data  nv_data.bin      redata.bin
drm           h2k.dat        nv_data.bin.md5  wifi

Bien, ça m’a l’air d’être complet. Et si jamais je me rate, comment je vais faire pour la restaurer. Eh bien ma solution qui est non testée et que j’espère ne JAMAIS devoir tester est la suivante:

# heimdall flash --EFS --efs.rfs

Pourvu que ça n’arrive jamais, mais là j’ai au moins le sentiment rassurer d’avoir vraiment sauvegarder tout ce qui était vraiment nécessaire avant de me lancer.

Le prochain post concernera la ROM et ses déclinaisons. Ainsi que les raisons qui m’ont poussé à choisir une custom rom plutôt qu’une autre…

EDIT: je ne l’avais pas anticipé mais tous mes contacts et toutes mes applications ont été restaurés via mon compte Google qui était synchronisé avec mon téléphone!! Ca m’a simplifié considérablement la vie. Je suis néanmoins content d’avoir une sauvegarde en « dur » de l’essentiel de mon téléphone. J’ai d’ailleurs refait un backup complet dès ma nouvelle ROM installée…

Comment j’ai « rooté » mon Samsung Galaxy S3 avec Heimdall…

Ceci est un récit, d’une histoire vraie, la mienne (palpitant non?). Si jamais vous me copiez et que vous brickez votre téléphone, c’est pas ma faute. Désolé, il ne faudra vous en prendre qu’à vous même :)

Voilà près de une année que je possède ce téléphone. C’est un très bon téléphone. Je l’aime beaucoup. Je le préfère nettement au iPhone que je possédais auparavant. A un détail près: la durée de vie de la batterie. Franchement avec toutes ces apps qui tournent, sans que je sache bien lesquelles d’ailleurs, je suis quasi obligé d’éteindre mon portable tous les soirs si je ne veux pas me retrouver à court de batterie au petit matin!!! Je trouve ça scandaleux!!!

Etant (un chouilla) bidouilleur et un (gros) geek, j’avais bien entendu connaissance des ROMs alternatives. Mais j’avoue, je n’avais pas creusé le sujet. En fait, ce qui m’agacait c’était de lire des forums où des manoeuvres toutes connes passaient pour des trucs de hackxxor. Mais là, trop c’est trop. Entre la batterie, les updates à la con de AllShareCast et les applis que je veux pas qui tournent en tâche de fond; c’est décidé je reprends le contrôle!!!

La première étape est de passer root. Pour toute personne un tant soit peu informé, root c’est l’administrateur Unix basique. Il s’agit simplement d’élever ses privilèges pour pouvoir supprimer des merdes applis non désirés qui bouffent de la batterie. Arrivé là, c’est très simple: il faut flasher sa recovery pour installer un SU. Flasher est un bien grand mot pour indiquer que l’on va copier une image à la place d’une autre (en croisant les doigts pour que tout se passe bien!). La recovery est une partition à part sur le Samsung S3 (pas sur tous les téléphones de la série Samsung S, le S2 il paraît que c’est pas le cas, mais qui utilise encore un S2 pff…^^). Ce qui est plutôt sympa: aucune perte de données à envisager!!!

Comme je travaille sous Linux, l’outil de base est Heimdall. On l’utilise en download mode. C’est le mode que l’on utilise lorsque l’on veut charger quelque chose sur son téléphone. Sur le S3, un simple VolDown + Power + bouton central (ou Home Button ou button pour les intimes ^^) et vous y êtes. L’utilisation d’après

# heimdall help

est très simple:

# heimdall flash --partition_à_flasher image_à_flasher

C’est vraiment pas compliqué. Ca va aller vite, me voilà rassuré!! Je me suis quand même assuré d’avoir une partition recovery (on sait jamais, le diable est dans les détails!!). Là aussi c’est assez simple, il suffit de demander à heimdall de m’afficher la table des … partitions ou PIT (Partition Information Table)!!

# heimdall print-pit

--- Entry #9 ---
Binary Type: 0 (AP)
Device Type: 2 (MMC)
Identifier: 6
Attributes: 5 (Read/Write)
Update Attributes: 1 (FOTA)
Partition Block Size/Offset: 98304
Partition Block Count: 16384
File Offset (Obsolete): 0
File Size (Obsolete): 0
Partition Name: RECOVERY
Flash Filename: recovery.img
FOTA Filename:

Bon, pas besoin de faire de sauvegarde. A priori on va prendre une image pour en écraser une autre à un endroit bien précis, qui n’est pas un endroit sensible comme DATA ou SYSTEM ou EFS. C’est pas aujourd’hui que je vais bricker mon téléphone. On attendra le changement de ROM pour frissonner. Je note quand même au passage que j’ai 15 entries. 15!!! Je n’ai jamais eu autant de partition sur un de mes disques à usage perso!!

Bon, pas de quoi fouetter un chat. Allons-y: passage en download mode (VDown, Power, button) puis

[root@hades SGS3]# heimdall flash --RECOVERY recovery.img
Heimdall v1.4.0

Copyright (c) 2010-2013, Benjamin Dobell, Glass Echidna
http://www.glassechidna.com.au/

This software is provided free of charge. Copying and redistribution is
encouraged.

If you appreciate this software and you would like to support future
development please consider donating:
http://www.glassechidna.com.au/donate/

Initialising connection...
Detecting device...
Claiming interface...
Attempt failed. Detaching driver...
Claiming interface again...
Setting up interface...

Initialising protocol...
Protocol initialisation successful.

Beginning session...

Some devices may take up to 2 minutes to respond.
Please be patient!

Session begun.

Downloading device's PIT file...
PIT file download successful.

Uploading RECOVERY
100%
RECOVERY upload successful

Ending session...
Releasing device interface...
Re-attaching kernel driver...

Je n’ai même pas eu le temps de frissonner que c’est déjà fait. Notez que recovery doit être mis en majuscules: Unix est case-sensitive, c’est sensible ces bêtes-là. J’ai choisi d’installer ClockWorkMod . Y’en a d’autres. Mais celle-ci m’avait l’air attrayante au niveau richesse des fonctionnalités et design. Ca avait l’air beau sur le prospectus ^^

D’ailleurs, il serait peut-être temps d’aller voir. Le téléphone redémarre comme un grand, tout seul, une fois le flashage effectué. Je décide donc d’aller direct dans le recovery mode pour installer SuperSU (je sais, c’est un nom ridicule!). Et là, stupeur, je me retrouve face à « Android System Recovery ». Plutôt que face à « ClockWorkMod Recovery ». Késako??? Eh bien, après un peu beaucoup de recherches, j’ai découvert que lors du reboot le système pouvait réinstaller lui-même tout seul comme un grand une « stock recovery » qui écrase votre audacieux et fort risqué flashage. La bonne commande est donc:

[root@hades SGS3]# heimdall flash --RECOVERY recovery.img --no-reboot

et ensuite une fois la barre bleue complète, vous retirez le câble USB et la batterie pour éteindre le téléphone. Franchement c’est le moment qui m’a le plus fait flipper: retirer la batterie pour sortir du download mode. Ca fait débranchage sauvage, et sous Linux, c’est pas bon, mais pas bon du tout. Mais là ça a marché: j’ai ensuite rebooté directement dans le recovery mode (VolUP + Power + Button) et j’ai pu installer tranquillement SuperSU. A noter que ClockWorkMod prévient à un moment qu’il peut être écrasé lors du reboot, j’aurai apprécié de le savoir avant…

Les prochaines étapes sont les suivantes: un NAND-backup, terme barbare qui signifie que je vais sauvegarder ma ROM (stock samsung) avant de passer à la deuxième étape: CyanogenMod. Parce que, là, c’est un chouilla plus risqué et il faut posséder une sauvegarde pour restaurer le téléphone si ça va pas (ou si on veut plus de Cyanogen). Je vous raconterai certainement tout ça…

EDIT: lors de la première sortie de Clockworkmod, après l’installation de SuperSU, il faut bien cliquer sur « Yes, prevent ROM recovery flash », sinon votre ROM standard re-flashera une image stock recovery et il faudra recommencer toute la procédure.

RTFM et Android SDK

Etant un linuxien patenté, mon premier réflexe face une question relative à du matériel ou à du logiciel est assez simple: rtfm. Ce qui signifie: lire le put*** de manuel. Seulement voilà: la manuel n’était pas fourni avec mon téléphone. N’ayant pas (encore!) d’accès shell sur mon Samsnung Galaxy S3 (aka SGS3), je n’ai pas pu faire un man quelque chose. Je doute de toute façon de pouvoir trouver, par exemple, une énumération des gestures par exemple.

J’ai donc fini par trouver un manuel. Je cherchai quelque chose de beaucoup plus technique, en particulier au niveau logiciel. Un vrai détail de ce que sont les procédures de boot par exemple. Un manuel technique, je le cherche encore. Je finirai bien par trouver :)

Concernant le manuel de l’utilisateur, il y a beaucoup de choses très intéressantes. Je me demande pourquoi je n’avais pas cherché plutôt ce type de manuel pour l’iPhone ou l’iPad. Le chapitre « Getting Started » est plein de ces petits tips qu’on découvre un peu au hasard si on ne lit pas le manuel dès le début. Comme ceci par exemple.

C’est aussi le moment de lire les chapitres type « Camera » pour apprendre à (bien!) se servir de l’appareil photo ou encore « Settings » qui permet de faire le tour de toutes les options. Pour savoir comment rapidement, par exemple, modifier le timeout de l’écran avant qu’il se mette en veille.

Bref même si je n’ai pas trouvé les détails techniques que je cherchais, j’ai tout de même après plein de choses fort utiles pour utiliser mon téléphone tel qu’il est.

Mais je voudrais vraiment voir de plus près les entrailles de ce téléphone. Après tout, j’ai choisi un Android _aussi_ pour pouvoir appréhender de façon plus complète et ouverte la bête que i0S qui est fermé comme une huître. L’idéal m’a semblé être d’installer le SDK. Visiblement, d’après un article page 49 de MISC de ce mois ci, c’est un must-have pour faire du pentest d’Android. Je ne cherche pas à pentester Android. Par contre j’aimerai bien avoir une vue plus synthétique de la façon dont ça fonctionne en général et surtout sur mon Samsung en particulier.

J’ai donc entrepris d’installer le SDK, sous Arch Linux, c’est très simple puisque tout le nécessaire se trouve dans AUR. Mon téléphone semble détecté:

# lsusb | grep Samsung
Bus 001 Device 006: ID 04e8:6860 Samsung Electronics Co., Ltd GT-I9100 Phone [Galaxy S II], GT-I9300 Phone [Galaxy S III], GT-P7500 [Galaxy Tab 10.1]

Mais en fait non: adb devices ne me renvoie pas de périphérique. C’est alors que j’ai appris que l’activation USB du périphérique était possible. En clair: on peut utiliser le téléphone par USB. Mais pas par défaut (cf premier post). Pour cela il suffit d’aller dans « Paramètres => Options de développement ==> débogage USB ». Un pop-up vous indique que votre périphérique va être monté comme un périphérique de stockage et que cela ne doit être utilisé qu’à des fins de développement. En effet:

$ adb devices
List of devices attached
4df1... device

Alors ADB c’est quoi? Eh bien c’est le Android Debug Bridge dont la page nous dit:
« Android Debug Bridge (adb) is a versatile command line tool that lets you communicate with an emulator instance or connected Android-powered device. It is a client-server program that includes three components (…) » ce qui signifie: « Android Debug Bridge est un utilitaire en ligne de commande polyvalent qui vous permet de communiquer avec une plateforme Android émulée ou un périphérique Android connecté. C’est un programme client-serveur composé de 3 éléments (…) »

Bien, alors comment avoir un shell sur mon téléphone? Ce qui a quand même motivé cet article en premier lieu!! C’est simple:

$ adb shell
shell@android:/ $

Bon, par contre, on gardera le pdf niveau manuel :

shell@android:/ $ man man
/system/bin/sh: man: not found

Pour le reste c’est du grand classique:

shell@android:/ $ ls -l
drwxr-xr-x root     root              2012-09-26 18:46 acct
drwxrwx--- system   cache             2012-09-27 14:00 cache
dr-x------ root     root              2012-09-26 18:46 config
lrwxrwxrwx root     root              2012-09-26 18:46 d -> /sys/kernel/debug
drwxrwx--x system   system            2012-09-26 18:46 data
-rw-r--r-- root     root          116 1970-01-01 01:00 default.prop
drwxr-xr-x root     root              2012-09-26 18:46 dev
drwxrwx--x radio    system            2012-06-25 16:35 efs
lrwxrwxrwx root     root              2012-09-26 18:46 etc -> /system/etc
lrwxrwxrwx root     root              2012-09-26 18:46 factory -> /efs
-rwxr-x--- root     root       152288 1970-01-01 01:00 init
-rwxr-x--- root     root         3612 1970-01-01 01:00 init.bt.rc
-rwxr-x--- root     root         2344 1970-01-01 01:00 init.goldfish.rc
-rwxr-x--- root     root        40154 1970-01-01 01:00 init.rc
-rwxr-x--- root     root         2751 1970-01-01 01:00 init.smdk4x12.rc
-rwxr-x--- root     root         4359 1970-01-01 01:00 init.smdk4x12.usb.rc
drwxr-xr-x root     root              1970-01-01 01:00 lib
-rw-r--r-- root     root         1619 1970-01-01 01:00 lpm.rc
drwxrwxr-x root     system            2012-09-26 18:46 mnt
drwxr-xr-x root     root              1970-01-01 01:00 preload
dr-xr-xr-x root     root              1970-01-01 01:00 proc
drwx------ root     root              2012-06-25 17:29 root
drwxr-x--- root     root              1970-01-01 01:00 sbin
lrwxrwxrwx root     root              2012-09-26 18:46 sdcard -> /mnt/sdcard
drwxr-xr-x root     root              2012-09-26 18:46 sys
drwxr-xr-x root     root              2012-09-26 18:46 system
-rw-r--r-- root     root          272 1970-01-01 01:00 ueventd.goldfish.rc
-rw-r--r-- root     root         3873 1970-01-01 01:00 ueventd.rc
-rw-r--r-- root     root         1666 1970-01-01 01:00 ueventd.smdk4x12.rc
lrwxrwxrwx root     root              2012-09-26 18:46 vendor -> /system/vendor

N’étant pas (encore!) root, je n’ai finalement pas le droit de faire grand chose…Et il y a énormément de commandes de base qui ne sont pas présentes: less, cut, groups, find etc… « Command not found ». C’est sacrément frustrant d’ailleurs…

Je sens que je vais bien m’amuser avec ce téléphone, je sais pas pourquoi mais je sens que je vais vraiment bien m’amuser…une fois root ;)

A la découverte d’Airdroid euh…d’Android ^^

Ah…Ca y’est, j’ai enfin reçu mon nouveau téléphone. Il s’agit d’un Samsung Galaxy S3,le Pebble Blue, si c’est pas poétique ça…J’ai décrit par ailleurs les raisons qui m’ont fait lâcher mon iPhone américain pour un Samsung coréen.
En ouvrant la boîte, j’avoue, j’ai été un peu déçu par son aspect plastique. Ca fait un peu « plastok » comme dirait l’autre. Pour le coup la petite bande de fer cerclant les iPhones me devient rassurante. J’ai acheté une coque, mais contrairement à celle que j’avais prise pour mon iPhone, je me suis centré sur l’aspect « solide » plutôt que sur l’aspect « esthétique ». On verra à l’usage.

Une fois toute installée, première découverte de l’interface Samsung. comment peut on encore faire « Ã§a » dans le monde Linux. Mystère et boule de gomme..Ma prochaine mission sera de trouver un équivalent à E17 sur Android. Je veux changer de WM :'(
C’est, en effet, un peu mal léché (« cumbersome » est l’adjectif qui me vient à l’esprit) et nettement moins intuitif que le design iOS, de mon point de vue c’est indéniable. Bizarrement les apps au bord carré ça me saute aux yeux par rapport à celles d’Apple tout en rondeur. Comme quoi, le procès pour « bords ronds » infligé à Samsung par Apple ce n’est pas que du pinaillage de brevet à 2 balles ;)

Mais bon, après tout, il passera les 3/4 de son temps dans ma poche et, surtout, il a un grand écran avec une bonne définition. Enfin, contrairement à l’iPhone, je vais pouvoir gérer ma musique _très important pour moi ça_ sans iTunes et avec un simple mount, comme pour une clé USB. Le bonheur sur terre quoi :)

J’ai donc branché mon bout de plastique Samsung Galaxy S3 sur mon PC en USB. J’ai ouvert Thunar et je m’attendais tranquillou à cliquer sur le dossier qui va bien pour stocker la musique qui va bien. Et là, horreur, malheur, rien n’apparaît dans Thunar. Pourtant il est bien branché non?
Un coup de dmesg | tail plus tard, toujours pas de trace du téléphone. Késako? m’interroge-je un brin désarçonné tout de même. Tout de façon, la commande précédente, c’est un truc de newbie, tout le monde le sait hein…Normale qu’elle voit rien…Commande de m***
Un tail -20 sur /var/log/messages.log plus tard, je n’ai que ça:

Sep 17 18:19:39 localhost mtp-probe: checking bus 1, device 7: "/sys/devices/pci0000:00/0000:00:1d.7/usb1/1-5"
Sep 17 18:19:39 localhost mtp-probe: bus: 1, device: 7 was not an MTP device

WTF??? Alors je réfléchis: je me souviens vaguement que sur le Samsung à mon frère chéri que j’aime (même s’il m’appelle jamais, ingrat ^^) il fallait cocher une option pour autoriser le pingouin à monter sur la nouvelle planche de surf en plastique de Samsung. Ceci dit ça n’expliquerait pas que je ne vois rien dans les logs.
Une petite recherche google plus tard, j’ai appris quelle était la raison (scélérate!!) pour laquelle je ne pouvais pas tranquillou charger ma musique: Google a décidé que les dernières versions d’Android ne passerait plus par USB mais par MTP.

Mais que fait Google? C’est quoi ce protocole? Inventé par Microsoft, mais c’est pas vrai. Je quitte Apple pour me retrouver avec un protocole Microsoft. Si ça, c’est pas allé de Charybde en Scylla…

Bon positivons, Android c’est Linux; Arch c’est Linux. Ca devrait le faire :)
En effet:

# mtp-detect
libmtp version: 1.1.4

Listing raw device(s)
Device 0 (VID=04e8 and PID=6860) is a Samsung GT P7310/P7510/N7000/I9070/I9100/I9300 Galaxy Tab 7.7/10.1/S2/S3/Nexus/Note/Y.
   Found 1 device(s):
   Samsung: GT P7310/P7510/N7000/I9070/I9100/I9300 Galaxy Tab 7.7/10.1/S2/S3/Nexus/Note/Y (04e8:6860) @ bus 1, dev 6
Attempting to connect device(s)
PTP_ERROR_IO: failed to open session, trying again after resetting USB interface
LIBMTP libusb: Attempt to reset device
LIBMTP PANIC: failed to open session on second attempt
Unable to open raw device 0
OK.

Là je me suis surpris à taper dans google « libmtp git »…Et les micro-secondes de moulinage m’ont servi à réfléchir. J’avais quitté mon iPhone pour ne plus avoir à bidouiller avec Fuse ou libmobiledevice pour contourner iTunes et là, je recherche du code pour voir ce qui va pas. J’hallucine ou quoi??? Et ma musique???

Réflexion faite je me suis dit qu’il fallait m’adapter de façon différente et je me suis souvenu d’un lien vers une app prénommée Airdroid. C’est, ou plutôt ce serait, une app’ me permettant de charger ma musique en wifi direct depuis mon navigateur. Je me dis qui ne tente rien n’a rien. Me voilà à l’installer sur mon « pebble blue », c’est gratuit. Pour le coup c’est vachement clair et intuitif. Newbie-compliant. En 5 minutes je me suis retrouvé devant ça.

Tout peut vraiment être géré via une interface qui n’est pas sans rappeler Apple. Claire, concise, précise et avec laquelle on peut tout faire, et surtout ce qui m’intéresse: charger la musique, gérer les contacts ou l’agenda etc…

Tout ça pour dire qu’à première vue le logo ne ment pas sur la marque: Android le robot froid et un peu encombré dans la démarche n’a pas la rondeur avenante d’une pomme qui roule…Cumbersome, on vous dit…