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

[Android] aarch64 client requests aarch32 app version even when CPU and project don't support it #5833

Open
brevilo opened this issue Oct 4, 2024 · 4 comments

Comments

@brevilo
Copy link
Contributor

brevilo commented Oct 4, 2024

Describe the bug
This seems to indicate that BOINC falls back to arm-android-linux-gnu (aarch32) if a project doesn't support aarch64-android-linux-gnu. Is that correct and always the case? If so, it shouldn't be since as of ARMv9-A aarch32 support is optional and not implemented on the Cortex-A520, for instance.

Steps To Reproduce

  1. Use a device with a Cortex-A520
  2. Attach BOINC to Einstein@Home (supporting arm-android-linux-gnu only)
  3. Receive an aarch32 app
  4. Run into an exec format error (8)

Expected behavior
BOINC should not fall back to aarch32 on Cortex-A520

System Information

  • OS: Android 14 (Samsung)
  • BOINC Version: 8.0.2

Additional context

  • This was observed on a volunteer's Samsung S24+
  • Problem: the CPU identifies as [Impl 0x41 Arch8 Variant 0x0 Paart 0xd80 Rev 1] (also notice the unrelated 'Paart' typo) which doesn't indicate that it's in fact architecture 9. Use a static list of part IDs that don't support aarch32 anymore also seems error prone. Maybe simply drop the fallback?
@brevilo brevilo changed the title [Android] aarch64 client requests aarch32 app version even when CPU doesn't support it [Android] aarch64 client requests aarch32 app version even when CPU and project don't support it Oct 4, 2024
@AenBleidd AenBleidd added this to the Client/Manager 8.2.0 milestone Oct 4, 2024
@brevilo
Copy link
Contributor Author

brevilo commented Oct 16, 2024

FYI: the CPU architecture reported by /proc/cpuinfo does not indicate the actual architecture, according to this LKML thread. IOW, the 8 above does not refer to ARMv8 and should thus rather be ignored.

@brevilo
Copy link
Contributor Author

brevilo commented Oct 16, 2024

To make things even worse, we're seeing S24 devices which clearly have ARMv9.2-A cores in them, yet do not support their full instruction set. Looking at the CPU features reveals that they are effectively crippled down to armv8.6-a in case of the S24 Ultra. Interestingly enough BOINC reports ABI: arm64-v8a in host.product_name, which is closer to the truth but not that helpful (there).

@brevilo
Copy link
Contributor Author

brevilo commented Oct 17, 2024

Another related observation: I rebuilt the binary for ARMv8-A since this is the first ISA with AArch64 support and should thus be the lowest common denominator to fix (well, work around) the mess from my previous comment. However, while I could execute the binary on my ARMv8 test device (BOINC 8.0.3, Android 11, AArch64 kernel) directly in an adb shell, it immediately errored out under BOINC's anonymous platform (GitHub wiki entry is broken) with an execv: Exec format error. Back to square one. This doesn't make sense. Even if BOINC would run a AArch32 client for some reason, it should still be able to execv a AArch64 app, no? 🤷‍♂

Can someone confirm that anonymous platform is fully supported by BOINC on Android? Just to exclude the error above being a red herring...

@ahorek
Copy link
Contributor

ahorek commented Dec 26, 2024

getprop ro.product.cpu.abilist64
=> arm64-v8a
getprop ro.product.cpu.abilist32
=>

only 64bit apps are supported
boinc_platform="aarch64-android-linux-gnu"

getprop ro.product.cpu.abilist64
=> arm64-v8a
getprop ro.product.cpu.abilist32
=> armeabi-v7a,armeabi

both 64 & 32bit apps are supported
boinc_platform="aarch64-android-linux-gnu"
boinc_alt_platform="arm-android-linux-gnu"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Backlog
Development

No branches or pull requests

3 participants