Ja, schmutzig ist praktisch – zumindest wenn es um Updates geht. Obwohl die meisten Entwickler empfehlen möglichst bei jedem Update mit einem frischen System zu beginnen versuche ich meine Daten so lange wie möglich mitzuschleifen („Dirty Flash“) – leider gibt es noch immer unzählige Apps, welche keine brauchbare Backup-Funktion bieten und auch systembasierte Lösungen wie Titanium Backup sind leider nicht unfehlbar.
Zuletzt war ich etwas nachlässig – mein Handy war noch auf Version 2, aktuell Version 9 meiner aktuellen ROM. Zeit zum Aktalisieren, vor allem da Dirty Cow gerade bekannt wurde.
Also, Sideload drüber und – narf. „Telefon reagiert nicht mehr“. Gemeint ist hierbei die Telefon-App, also jene, welche Sprachtelefonie ermöglicht. Brauch ich zwar normal nicht, aber die Popups nerven doch etwas.
Über ADB ließ sich folgendes im Log erspähen:
12-06 16:43:32.820 3708 3708 E AndroidRuntime: FATAL EXCEPTION: main 12-06 16:43:32.820 3708 3708 E AndroidRuntime: Process: com.android.phone, PID: 3708 12-06 16:43:32.820 3708 3708 E AndroidRuntime: java.lang.IllegalArgumentException: column 'user_network_mode' does not exist 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at android.database.AbstractCursor.getColumnIndexOrThrow(AbstractCursor.java:333) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at android.database.CursorWrapper.getColumnIndexOrThrow(CursorWrapper.java:87) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.telephony.SubscriptionController.getSubInfoRecord(SubscriptionController.java:293) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.telephony.SubscriptionController.getSubInfoUsingSlotIdWithCheck(SubscriptionController.java:1631) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.telephony.SubscriptionInfoUpdater.updateSubscriptionInfoByIccId(SubscriptionInfoUpdater.java:593) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.telephony.SubscriptionInfoUpdater.handleSimLoaded(SubscriptionInfoUpdater.java:421) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.telephony.SubscriptionInfoUpdater.handleMessage(SubscriptionInfoUpdater.java:338) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at android.os.Looper.loop(Looper.java:154) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at android.app.ActivityThread.main(ActivityThread.java:6140) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at java.lang.reflect.Method.invoke(Native Method) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:888) 12-06 16:43:32.820 3708 3708 E AndroidRuntime: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:778)
Dankenswerterweise gibt es einen passenden Post von Daan, welcher die Ursache genau beschreibt und einen passenden Befehl zum zurücksetzen der defekten Datenbank anbietet. Hierbei gehen ggf. Einstellungen verloren, diese muss man ggf. später von seiner Datensicherung wieder einspielen.
adb shell su - rm -rf /data/user_de/0/com.android.providers.telephony/databases/telephony.*
Nach dem Befehl war dann Ruhe und sogar das telefonieren funktioniert wieder. Fein.