mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-06 13:18:06 -05:00
655582e970
FSFE licensing checking program lint is now happy $ reuse lint * Bad licenses: * Missing licenses: * Unused licenses: * Used licenses: AGPL-3.0-only, AGPL-3.0-or-later, Apache-2.0, CC-BY-SA-4.0, CC0-1.0, GPL-3.0-or-later, LGPL-3.0-or-later, MIT * Read errors: 0 * Files with copyright information: 6324 / 6324 * Files with license information: 6324 / 6324 Congratulations! Your project is compliant with version 3.0 of the REUSE Specification :-)
257 lines
10 KiB
Plaintext
257 lines
10 KiB
Plaintext
// SPDX-FileCopyrightText: RetroShare Team <contact@retroshare.cc>
|
|
// SPDX-License-Identifier: CC-BY-SA-4.0
|
|
|
|
Compile Retroshare for Android
|
|
==============================
|
|
|
|
Compiling an application for Android is not as easy as one would imagine,
|
|
expecially one like RetroShare that has a big codebase and is not well
|
|
documented. This document is aimed to empower the reader so she can hopefully
|
|
succed or at least have a significant help in compiling her own RetroShare APK
|
|
installable on Android.
|
|
|
|
|
|
== Preparing The Environement
|
|
|
|
First of all setup your Qt for Android development environement following the
|
|
guide on the link:http://doc.qt.io/qt-5/androidgs.html[Qt for android web site].
|
|
At this point you should have Android SDK, Android NDK, and Qt for Android
|
|
working fine, and you should be capable of executing on an Android emulator or
|
|
on your Android phone Qt for Android examples.
|
|
|
|
But RetroShare is not as simple to compile as those examples. The good news is
|
|
that Android NDK ships all the necessary to build a custom toolchain that is
|
|
suitable to build RetroShare.
|
|
In order to build the toolchain with needed libraries RetroShare provides the
|
|
+android-prepare-toolchain.sh+ script; before you execute it you should define
|
|
some variables the script cannot determine in an easy and reliable manner by
|
|
itself in your terminal.
|
|
|
|
[source,bash]
|
|
-------------------------------------------------------------------------------
|
|
## The path where Android NDK is installed in your system
|
|
export ANDROID_NDK_PATH="/opt/android-ndk/"
|
|
|
|
## The path where your fresh compiled toolchain will be installed, make sure
|
|
## the parent exists
|
|
export NATIVE_LIBS_TOOLCHAIN_PATH="${HOME}/Builds/android-toolchains/retroshare-android/"
|
|
|
|
## The CPU architecture of the Android device you want to target
|
|
export ANDROID_NDK_ARCH="arm"
|
|
|
|
## The Android API level the Android device you want to target
|
|
export ANDROID_PLATFORM_VER="16"
|
|
|
|
## The number of core that yout host CPU have (just to speed up compilation) set
|
|
## it to 1 if unsure
|
|
export HOST_NUM_CPU=1
|
|
|
|
./android-prepare-toolchain.sh
|
|
-------------------------------------------------------------------------------
|
|
|
|
|
|
== Preparing Qt Creator
|
|
|
|
Now that your environement is set up you should configure Qt Creator for Android
|
|
following the
|
|
link:http://doc.qt.io/qtcreator/creator-developing-android.html[official guide].
|
|
At the end of this step your Qt Creator should recognize the Android compiler
|
|
and the Qt for Android kit.
|
|
|
|
Your Kit is now ready to use. Now you can open RetroShare as a Qt Creator
|
|
project and in the Projects left menu add the newly created kit if not already
|
|
present, so you can select it on the build type selection button down on the
|
|
left.
|
|
|
|
Now you need to set properly a few options like `JSONAPI_GENERATOR_EXE` and
|
|
disable some of RetroShare modules like `retroshare-gui` that are not available
|
|
on Android so you will have to go to
|
|
|
|
_Qt Creator left pane -> Projects -> Build and Run -> Android SOMESTUFF kit ->
|
|
Build Steps -> qmake -> Additional arguments_ +
|
|
|
|
and add the following configurations (change `Your_Path` according to your
|
|
deployment)
|
|
|
|
[source,makefile]
|
|
-------------------------------------------------------------------------------
|
|
CONFIG+=retroshare_service CONFIG+=rs_jsonapi CONFIG+=rs_deep_search
|
|
RS_UPNP_LIB=miniupnpc
|
|
JSONAPI_GENERATOR_EXE=Your_Path/jsonapi-generator/src/jsonapi-generator
|
|
NATIVE_LIBS_TOOLCHAIN_PATH=Your_Path/retroshare-android-16-arm/
|
|
CONFIG+=no_retroshare_gui CONFIG+=no_rs_service_webui_terminal_password
|
|
CONFIG+=no_rs_service_terminal_login
|
|
-------------------------------------------------------------------------------
|
|
|
|
TIP: Some versions of QtCreator try to find the Android SDK in
|
|
`/opt/android/sdk`. A workaround to this is to make a symbolic link there
|
|
pointing to your SDK installation path, like
|
|
+mkdir -p /opt/android/sdk && ln -s /home/user/android-sdk-linux
|
|
/opt/android/sdk+
|
|
|
|
|
|
== Quircks
|
|
|
|
=== Protected Apps
|
|
|
|
On some Android devices like +Huawei ALE-L21+ background applications are
|
|
killed when screen is turned off unless they are in the _protected app_ list.
|
|
At moment seems apps developers don't have a way to have the application
|
|
_protected_ by default, unless the phone vendor decide the app is _popular_ so
|
|
the user have to enable _protection_ for RetroShare manually on those mobile
|
|
phones. +
|
|
|
|
{empty} +
|
|
To enable enable _protection_: +Android menu -> Settings -> Privacy & security
|
|
-> Protected apps -> RetroShare+ +
|
|
{empty} +
|
|
|
|
Other devices may offer similar _features_ please report them.
|
|
|
|
|
|
=== APK signature mismatch
|
|
|
|
If you try to install a RetroShare APK that comes from a different source
|
|
(eg: if you try to upgrade from F-Droid when you originally installed an APK
|
|
build by yourself) Android will prevent that from happening. In that case the
|
|
only solution is to uninstall the app and then install the new APK but if you do
|
|
it also the application data and your precious cryptographic keys, friend list
|
|
etc. will be lost forever.
|
|
To avoid that you can attempt to manually backup and then restore from the
|
|
command-line (`adb backup` seems not working either) to change the app source
|
|
without erasing the appliation data.
|
|
|
|
CAUTION: Following steps require root access on your Android device
|
|
|
|
.Backup RetroShare Android application data
|
|
[source,bash]
|
|
--------------------------------------------------------------------------------
|
|
export ORIG_DIR="/data/data/org.retroshare.android.qml_app"
|
|
export BACKUP_DIR="org.retroshare.android.qml_app.backup"
|
|
|
|
adb root
|
|
|
|
adb shell am force-stop org.retroshare.android.qml_app
|
|
sleep 1s
|
|
|
|
mkdir ${BACKUP_DIR}
|
|
|
|
# Avoid adb pull failing
|
|
adb shell rm ${ORIG_DIR}/files/.retroshare/libresapi.sock
|
|
adb pull ${ORIG_DIR}/files/ ${BACKUP_DIR}/files/
|
|
--------------------------------------------------------------------------------
|
|
|
|
After this you should be able to uninstall the old APK with your preferred
|
|
method, as example from the command-line.
|
|
|
|
.Uninstall RetroShare Android from the command-line
|
|
[source,bash]
|
|
--------------------------------------------------------------------------------
|
|
adb uninstall org.retroshare.android.qml_app
|
|
--------------------------------------------------------------------------------
|
|
|
|
Now you can install a different signature APK and then restore the application
|
|
data with the following commands.
|
|
|
|
[source,bash]
|
|
--------------------------------------------------------------------------------
|
|
export ORIG_DIR="/data/data/org.retroshare.android.qml_app"
|
|
export BACKUP_DIR="org.retroshare.android.qml_app.backup"
|
|
|
|
adb root
|
|
|
|
## Launch the app to make sure the parent directory exists and has proper owner
|
|
adb shell monkey -p org.retroshare.android.qml_app -c android.intent.category.LAUNCHER 1
|
|
sleep 1s
|
|
|
|
adb shell am force-stop org.retroshare.android.qml_app
|
|
sleep 1s
|
|
|
|
|
|
APP_OWNER="$(adb shell busybox ls -lnd ${ORIG_DIR} | awk '{print $3":"$4}')"
|
|
adb shell rm -rf ${ORIG_DIR}/files
|
|
adb push ${BACKUP_DIR}/files/ ${ORIG_DIR}/files/
|
|
adb shell busybox chown -R ${APP_OWNER} ${ORIG_DIR}/files/
|
|
--------------------------------------------------------------------------------
|
|
|
|
Opening RetroShare android app now should show your old profile.
|
|
|
|
|
|
== Debugging with GDB
|
|
|
|
QtCreator actually support debugging only for the foreground activity, so to
|
|
debug what's happening in the core extra trickery is needed.
|
|
|
|
- Run the App in Debug mode from QtCreator "Start Debugging" button
|
|
- Enable QtCreator debugger console view Menu->Window->Debugger Log
|
|
- Run +show solib-search-path+ in the QtCreator GDB console
|
|
- Take note of the output you get in the right pane of the console
|
|
- Thanks https://stackoverflow.com/a/31164313 for the idea
|
|
|
|
TIP: QtCreator GDB console seems a bit buggy and easly trigger timeout
|
|
message when a command is run, in that case attempt to run the command while the
|
|
debugging is paused or at breakpoint, or with other similar tricks.
|
|
|
|
CAUTION: Following steps require root access on your Android device
|
|
|
|
Now on your phone yuo need to authorize root access to applications, then once
|
|
you plug your sacrifical Android phone run this commands
|
|
|
|
.Run gdbserver as root on Android phone
|
|
[source,bash]
|
|
--------------------------------------------------------------------------------
|
|
## Open a shell from your workstation on the connected Android phone
|
|
adb shell
|
|
|
|
## take the note of the phone IP address
|
|
ip address show
|
|
|
|
## Gain root permissions on the shell
|
|
su
|
|
|
|
## Attach with gdbserver and listen on one TCP port
|
|
gdbserver :4567 --attach $(pgrep org.retroshare.android.qml_app:rs)
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
|
.Prepare and run Android NDK GDB on your workstation
|
|
[source,bash]
|
|
--------------------------------------------------------------------------------
|
|
## Setup some convenience variables
|
|
NDK_GDB="${ANDROID_NDK_PATH}/toolchains/arm-linux-androideabi-4.9/prebuilt/linux-x86_64/bin/arm-linux-androideabi-gdb"
|
|
RS_BUILD_PATH="${HOME}/Builds/RetroShare-Android_for_armeabi_v7a_GCC_4_9_Qt_5_9_2_android_armv7-Debug/"
|
|
|
|
## Start Android NDK GDB of your phone architecture passing the executable
|
|
$NDK_GDB $RS_BUILD_PATH/retroshare-android-service/src/libretroshare-android-service.so
|
|
|
|
## Instruct GDB how and where to find debugging symbols
|
|
(gdb) set auto-solib-add on
|
|
(gdb) set solib-search-path THE:BIG:LIST:OF:DIRECTORIES:YOU:TAKE:NOTE:BEFORE
|
|
|
|
## Connect to the gdbserver running on the phone
|
|
(gdb) target remote $PHONE_IP:4567
|
|
|
|
## Have fun debugging
|
|
(gdb)
|
|
--------------------------------------------------------------------------------
|
|
|
|
TIP: Some time WiFi power saving on Android mess with the GDB connection,
|
|
to prevent that from appening open another +adb shell+ and live +ping+ toward
|
|
your work-station running
|
|
|
|
|
|
== Furter Readings
|
|
|
|
- link:http://doc.qt.io/qt-5/android-support.html[]
|
|
- link:https://developer.android.com/ndk/guides/libs.html[]
|
|
- link:retroshare://forum?name=Compiling%20nogui%20for%20android&id=8fd22bd8f99754461e7ba1ca8a727995&msgid=4e0f92330600bba9cf978f384f4b7b2f2ca64eff[]
|
|
- link:retroshare://file?name=Android%20Native%20Development%20Kit%20Cookbook.pdf&size=29214468&hash=0123361c1b14366ce36118e82b90faf7c7b1b136[]
|
|
- link:https://groups.google.com/forum/#!topic/android-developers/srATPaL0aRU[]
|
|
- link:https://stackoverflow.com/questions/31638986/protected-apps-setting-on-huawei-phones-and-how-to-handle-it[]
|
|
- link:https://tthtlc.wordpress.com/2012/09/19/how-to-do-remote-debugging-via-gdbserver-running-inside-the-android-phone/[]
|
|
- link:https://source.android.com/devices/tech/debug/[]
|
|
- link:https://source.android.com/devices/tech/debug/gdb[]
|
|
- link:https://fw4spl-org.github.io/fw4spl-blog/2015/07/27/Native-debugging-on-Android-with-QtCreator.html[]
|
|
- link:https://fragglet.livejournal.com/19646.html[]
|
|
- link:https://github.com/android-ndk/ndk/issues/773[How to build without using standalone toolchain?]
|