Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[BUG] Cromite v120.0.6099.199 crashes after unmodified recompilation with apktool 2.9.2 #3489

Open
frama99 opened this issue Jan 9, 2024 · 7 comments

Comments

@frama99
Copy link

frama99 commented Jan 9, 2024

Information

  1. Apktool Version (apktool -version) - 2.9.2
  2. Operating System (Mac, Linux, Windows) - Linux openSUSE Tumbleweed 20231226
  3. APK From? (Playstore, ROM, Other) - https://github.com/uazo/cromite/releases => v120.0.6099.199-672a5061d34744482fcdd58ee4c9a5cf24acbd4b => arm64_ChromePublic.apk
  4. Java Version (java --version) - openjdk version "21.0.1" 2023-10-17
  5. Device, OS and Version - Pixel 6a (bluejay), GrapheneOS, 2024010400

No modifications were made to the APK file. The re-compiled APK crashes while clicking through the initialization wizard questions, right before the app home screen is displayed. Most likely the app does not have any protection. So the app works fine without any crash when zipaliging and signing the original APK directly.

All tests were done with Wi-Fi offline.

Thank you so much for the huge effort you put into this project. Apktool is an amazing development tool.

Stacktrace/Logcat

01-09 12:25:46.383  6022  6022 W System.err: java.lang.NullPointerException: Attempt to invoke virtual method 'int android.content.res.ColorStateList.getDefaultColor()' on a null object reference
01-09 12:25:46.383  6022  6022 W System.err:    at org.chromium.chrome.browser.toolbar.top.ToolbarPhone.n(chromium-ChromePublic.apk-stable-609919904:217)
01-09 12:25:46.383  6022  6022 W System.err:    at yG1.h(chromium-ChromePublic.apk-stable-609919904:160)
01-09 12:25:46.383  6022  6022 W System.err:    at AS1.a(chromium-ChromePublic.apk-stable-609919904:8)
01-09 12:25:46.383  6022  6022 W System.err:    at yT.a(chromium-ChromePublic.apk-stable-609919904:13)
01-09 12:25:46.383  6022  6022 W System.err:    at org.chromium.ui.resources.ResourceManager.resourceRequested(chromium-ChromePublic.apk-stable-609919904:10)
01-09 12:25:46.383  6022  6022 W System.err:    at J.N.MHqlwRYg(Native Method) 
01-09 12:25:46.383  6022  6022 W System.err:    at wI1.f(chromium-ChromePublic.apk-stable-609919904:113)
01-09 12:25:46.383  6022  6022 W System.err:    at Yz.onResult(chromium-ChromePublic.apk-stable-609919904:12)
01-09 12:25:46.383  6022  6022 W System.err:    at XG0.n(chromium-ChromePublic.apk-stable-609919904:34) 
01-09 12:25:46.383  6022  6022 W System.err:    at org.chromium.chrome.browser.compositor.CompositorView.onCompositorLayout(chromium-ChromePublic.apk-stable-609919904:40)
01-09 12:25:46.383  6022  6022 W System.err:    at android.os.MessageQueue.nativePollOnce(Native Method)
01-09 12:25:46.383  6022  6022 W System.err:    at android.os.MessageQueue.next(MessageQueue.java:335)
01-09 12:25:46.383  6022  6022 W System.err:    at android.os.Looper.loopOnce(Looper.java:162)
01-09 12:25:46.383  6022  6022 W System.err:    at android.os.Looper.loop(Looper.java:294)
01-09 12:25:46.383  6022  6022 W System.err:    at android.app.ActivityThread.main(ActivityThread.java:8279)
01-09 12:25:46.383  6022  6022 W System.err:    at java.lang.reflect.Method.invoke(Native Method)
01-09 12:25:46.383  6022  6022 W System.err:    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:552)
01-09 12:25:46.383  6022  6022 W System.err:    at com.android.internal.os.ExecInit.main(ExecInit.java:49)
01-09 12:25:46.383  6022  6022 W System.err:    at com.android.internal.os.RuntimeInit.nativeFinishInit(Native Method)
01-09 12:25:46.383  6022  6022 W System.err:    at com.android.internal.os.RuntimeInit.main(RuntimeInit.java:359)
01-09 12:25:46.384  6022  6022 F chromium: [FATAL:jni_android.cc(290)] Please include Java exception stack in crash report
01-09 12:25:46.418  6257  6257 W libchrome_crash: type=1400 audit(0.0:41757): avc:  denied  { search } for  name="tests" dev="dm-47" ino=105 scontext=u:r:untrusted_app:s0:c181,c256,c512,c768 tcontext=u:object_r:shell_test_data_file:s0 tclass=dir permissive=0 app=org.cromite.cromite
01-09 12:25:46.422  6257  6257 W libchrome_crash: type=1400 audit(0.0:41758): avc:  denied  { search } for  name="tests" dev="dm-47" ino=105 scontext=u:r:untrusted_app:s0:c181,c256,c512,c768 tcontext=u:object_r:shell_test_data_file:s0 tclass=dir permissive=0 app=org.cromite.cromite
01-09 12:25:46.422  6257  6257 W libchrome_crash: type=1400 audit(0.0:41759): avc:  denied  { search } for  name="tests" dev="dm-47" ino=105 scontext=u:r:untrusted_app:s0:c181,c256,c512,c768 tcontext=u:object_r:shell_test_data_file:s0 tclass=dir permissive=0 app=org.cromite.cromite
01-09 12:25:46.422  6257  6257 W libchrome_crash: type=1400 audit(0.0:41760): avc:  denied  { search } for  name="tests" dev="dm-47" ino=105 scontext=u:r:untrusted_app:s0:c181,c256,c512,c768 tcontext=u:object_r:shell_test_data_file:s0 tclass=dir permissive=0 app=org.cromite.cromite

Steps to Reproduce

  1. apktool d # with --no-src the app still crashes, but with --no-src --no-res or only with --no-res the app works well
  2. apktool b
  3. zipalign 4
  4. apksigner ... sign with some key.

After installing and starting the app, two setup wizard steps are displayed:

  1. Welcome to Cromite: -> Continue
  2. Typically the app crashes here. If not then go a step further: -> Continue -> Allow notifications => Homescreen.

When performing only zipalign 4 and apksigner ... with the original APK and installing that, the app does not crash.

After decompiling the APK with `-no-src' and re-compiling that, the app still crashes (same position, same stack trace).

After decompiling the APK with --no-src --no-res or only with --no-res and re-compiling that, the app doe not crash anymore. But in this case one has no access to AndroidManifest.xml anymore, unfortunately.

APK

https://github.com/uazo/cromite/releases
=> v120.0.6099.199-672a5061d34744482fcdd58ee4c9a5cf24acbd4b
=> arm64_ChromePublic.apk

Questions to ask before submission

  1. Have you tried apktool d, apktool b without changing anything? yes
  2. If you are trying to install a modified apk, did you resign it? yes
  3. Are you using the latest apktool version? yes
@iBotPeaches
Copy link
Owner

Sounds like you've done what I was going to ask and isolated the disassembly to the resources. Skipping disassembly of resources and launching resulted in no issue.

Odd however the error isn't a common one that references a missing resource. Its almost like the sources are trying to reference a resource that is no longer available.

@frama99
Copy link
Author

frama99 commented Jan 9, 2024

I read previous tickets and thought it would be a good idea to do these tests immediately :-) Besides that I had some hope that --no-src would solve the problem and still allow access to AndroidManifest.xml. But unfortunately it is just the other way around. De/re-compiling the sources seems to work fine, but the resources cause the trouble. Maybe you have a chance and time to look deeper into this problem. Many thanks. - Please let me know if I can help in any way.

@iBotPeaches
Copy link
Owner

Screenshot from 2024-01-14 11-32-42

I disassembled, rebuilt, disassembled and then compared. Source changes are the lost of default values, but I'm guessing the jvm/something knows default values of unset scalars.

The resources difference appear to be ordering of attributes.

So honestly not sure at the moment.

@frama99
Copy link
Author

frama99 commented Jan 22, 2024

I repeated your steps (disassemble, rebuild, disassemble) and can confirm your findings. The smail-files are identical, except some default values. The missing default assignments seem to be no problem since the missing values are the defaults anyway, so nothing changes there.

I carefully compared all resources xml files as well and again can confirm that only the ordering changes between disassemble-1 and disassemble-2 versions, with one exception: In case of "res/layout/otp_verification_dialog.xml" there is an additional backslash escape sequence "\ ", thus n2:digits="\ 0123456789" vs. n2:digits=" 0123456789". But again this is not a problem since backslash something in XML should be just the character escaped by the backslash. Anyway this resource has nothing to do with the problem.

Hence I assume that the problem is introduced already by the first disassemble step and can not be detected with this method.

Just to make sure that it is not a version specific problem I tried the same procedure (disassemble, rebuild, install) with the latest Cromite version v120.0.6099.230-068d09a1ed328898da892e800eec492d8dfcbb3e, with same result (crash with similar stack trace):

01-22 09:27:37.387 10747 10747 W System.err: java.lang.NullPointerException: Attempt to invoke virtual method 'int android.content.res.ColorStateList.getDefaultColor()' on a null object reference
01-22 09:27:37.387 10747 10747 W System.err:    at org.chromium.chrome.browser.toolbar.top.ToolbarPhone.n(chromium-ChromePublic.apk-stable-609923004:217)
01-22 09:27:37.387 10747 10747 W System.err:    at BG1.h(chromium-ChromePublic.apk-stable-609923004:160)
01-22 09:27:37.387 10747 10747 W System.err:    at DS1.a(chromium-ChromePublic.apk-stable-609923004:8)
01-22 09:27:37.387 10747 10747 W System.err:    at AT.a(chromium-ChromePublic.apk-stable-609923004:13)
01-22 09:27:37.387 10747 10747 W System.err:    at org.chromium.ui.resources.ResourceManager.resourceRequested(chromium-ChromePublic.apk-stable-609923004:10)
01-22 09:27:37.387 10747 10747 W System.err:    at J.N.MHqlwRYg(Native Method)
01-22 09:27:37.387 10747 10747 W System.err:    at zI1.f(chromium-ChromePublic.apk-stable-609923004:113)
01-22 09:27:37.387 10747 10747 W System.err:    at Zz.onResult(chromium-ChromePublic.apk-stable-609923004:12)
01-22 09:27:37.387 10747 10747 W System.err:    at ZG0.n(chromium-ChromePublic.apk-stable-609923004:34)
01-22 09:27:37.387 10747 10747 W System.err:    at org.chromium.chrome.browser.compositor.CompositorView.onCompositorLayout(chromium-ChromePublic.apk-stable-609923004:335)
01-22 09:27:37.387 10747 10747 W System.err:    at android.os.MessageQueue.nativePollOnce(Native Method)
01-22 09:27:37.387 10747 10747 W System.err:    at android.os.MessageQueue.next(MessageQueue.java:335)
01-22 09:27:37.387 10747 10747 W System.err:    at android.os.Looper.loopOnce(Looper.java:162)
01-22 09:27:37.387 10747 10747 W System.err:    at android.os.Looper.loop(Looper.java:294)
01-22 09:27:37.387 10747 10747 W System.err:    at android.app.ActivityThread.main(ActivityThread.java:8279)
01-22 09:27:37.387 10747 10747 W System.err:    at java.lang.reflect.Method.invoke(Native Method)
01-22 09:27:37.387 10747 10747 W System.err:    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:552)
01-22 09:27:37.387 10747 10747 W System.err:    at com.android.internal.os.ExecInit.main(ExecInit.java:49)
01-22 09:27:37.387 10747 10747 W System.err:    at com.android.internal.os.RuntimeInit.nativeFinishInit(Native Method)
01-22 09:27:37.387 10747 10747 W System.err:    at com.android.internal.os.RuntimeInit.main(RuntimeInit.java:359)
01-22 09:27:37.388 10747 10747 F chromium: [FATAL:jni_android.cc(290)] Please include Java exception stack in crash report

One possible next step is probably to build Cromite and then immediately compare the involved resources, thus the primary and the first disassembled one. I did download the sources from Cromite web page, but unfortunately it's not that simple. Those contain only patches/diffs to Chromium. Chromium is really huge and the build instructions of Cromite are still a TODO ... so difficult.

Finally I downloaded Chromium sources and did compare some content of xml resource files (with focus on toolbar and color) - as far as this is possible without compiling the code. Up to now I did not find any good clue what resource might causes the null pointer exception.

@frama99 frama99 closed this as completed Jan 22, 2024
@frama99 frama99 reopened this Jan 22, 2024
@frama99
Copy link
Author

frama99 commented Jan 22, 2024

Sorry. Click accident.

@aminought
Copy link

Got the same problem for Vivaldi Snapshot. Any progress?

@iBotPeaches
Copy link
Owner

I have not. If you preform the same test I did in this comment you can see if its just as confusing or provides additional context.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants
@iBotPeaches @aminought @frama99 and others