| 
									
										
										
										
											2021-02-02 01:57:40 +08:00
										 |  |  | Notes for Android platforms | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  | =========================== | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  Requirement details | 
					
						
							|  |  |  |  ------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-22 19:27:27 +08:00
										 |  |  |  Beside basic tools like perl and make, you'll need to download the Android | 
					
						
							| 
									
										
										
										
											2020-06-30 03:13:07 +08:00
										 |  |  |  NDK. It's available for Linux, macOS and Windows, but only Linux | 
					
						
							|  |  |  |  version was actually tested. There is no reason to believe that macOS | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  |  wouldn't work. And as for Windows, it's unclear which "shell" would be | 
					
						
							|  |  |  |  suitable, MSYS2 might have best chances. NDK version should play lesser | 
					
						
							|  |  |  |  role, the goal is to support a range of most recent versions. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Configuration | 
					
						
							|  |  |  |  ------------- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  Android is a cross-compiled target and you can't rely on `./Configure` | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  |  to find out the configuration target for you.  You have to name your | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  target explicitly; there are `android-arm`, `android-arm64`, `android-mips`, | 
					
						
							| 
									
										
										
										
											2024-01-30 05:20:54 +08:00
										 |  |  |  `android-mip64`, `android-x86`, `android-x86_64` and `android-riscv64` | 
					
						
							|  |  |  |  (`*MIPS` targets are no longer supported with NDK R20+). | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |  Do not pass --cross-compile-prefix (as you might be tempted), as it | 
					
						
							|  |  |  |  will be "calculated" automatically based on chosen platform. However, | 
					
						
							|  |  |  |  you still need to know the prefix to extend your PATH, in order to | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  invoke `$(CROSS_COMPILE)clang` [`*gcc` on NDK 19 and lower] and company. | 
					
						
							|  |  |  |  (`./Configure` will fail and give you a hint if you get it wrong.) | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-22 19:27:27 +08:00
										 |  |  |  Apart from `PATH` adjustment, you need to set `ANDROID_NDK_ROOT` environment | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  to point at the `NDK` directory. If you're using a side-by-side NDK the path | 
					
						
							|  |  |  |  will look something like `/some/where/android-sdk/ndk/<ver>`, and for a | 
					
						
							|  |  |  |  standalone NDK the path will be something like `/some/where/android-ndk-<ver>`. | 
					
						
							| 
									
										
										
										
											2019-12-03 17:50:52 +08:00
										 |  |  |  Both variables are significant at both configuration and compilation times. | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  The NDK customarily supports multiple Android API levels, e.g. `android-14`, | 
					
						
							| 
									
										
										
										
											2022-09-22 19:27:27 +08:00
										 |  |  |  `android-21`, etc. By default, latest API level is chosen. If you need to target | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  an older platform pass the argument `-D__ANDROID_API__=N` to `Configure`, | 
					
						
							|  |  |  |  with `N` being the numerical value of the target platform version. For example, | 
					
						
							| 
									
										
										
										
											2019-12-03 17:50:52 +08:00
										 |  |  |  to compile for Android 10 arm64 with a side-by-side NDK r20.0.5594570 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  |     export ANDROID_NDK_ROOT=/home/whoever/Android/android-sdk/ndk/20.0.5594570 | 
					
						
							|  |  |  |     PATH=$ANDROID_NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/bin:$ANDROID_NDK_ROOT/toolchains/arm-linux-androideabi-4.9/prebuilt/linux-x86_64/bin:$PATH | 
					
						
							|  |  |  |     ./Configure android-arm64 -D__ANDROID_API__=29 | 
					
						
							|  |  |  |     make | 
					
						
							| 
									
										
										
										
											2019-12-03 17:56:41 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 00:20:07 +08:00
										 |  |  |  Older versions of the NDK have GCC under their common prebuilt tools | 
					
						
							|  |  |  |  directory, so the bin path will be slightly different. EG: to compile | 
					
						
							|  |  |  |  for ICS on ARM with NDK 10d: | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-29 13:43:26 +08:00
										 |  |  |     export ANDROID_NDK_ROOT=/some/where/android-ndk-10d | 
					
						
							|  |  |  |     PATH=$ANDROID_NDK_ROOT/toolchains/arm-linux-androideabi-4.8/prebuilt/linux-x86_64/bin:$PATH | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  |     ./Configure android-arm -D__ANDROID_API__=14 | 
					
						
							| 
									
										
										
										
											2018-10-14 21:19:41 +08:00
										 |  |  |     make | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  Caveat lector! Earlier OpenSSL versions relied on additional `CROSS_SYSROOT` | 
					
						
							|  |  |  |  variable set to `$ANDROID_NDK_ROOT/platforms/android-<api>/arch-<arch>` to | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  |  appoint headers-n-libraries' location. It's still recognized in order | 
					
						
							|  |  |  |  to facilitate migration from older projects. However, since API level | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  appears in `CROSS_SYSROOT` value, passing `-D__ANDROID_API__=N` can be in | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  |  conflict, and mixing the two is therefore not supported. Migration to | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  `CROSS_SYSROOT`-less setup is recommended. | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-22 19:27:27 +08:00
										 |  |  |  One can engage clang by adjusting PATH to cover the same NDK's clang. Just | 
					
						
							| 
									
										
										
										
											2018-10-14 21:19:41 +08:00
										 |  |  |  keep in mind that if you miss it, Configure will try to use gcc... | 
					
						
							|  |  |  |  Also, PATH would need even further adjustment to cover unprefixed, yet | 
					
						
							| 
									
										
										
										
											2018-08-06 15:43:39 +08:00
										 |  |  |  target-specific, ar and ranlib. It's possible that you don't need to | 
					
						
							|  |  |  |  bother, if binutils-multiarch is installed on your Linux system. | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-14 21:19:41 +08:00
										 |  |  |  Another option is to create so called "standalone toolchain" tailored | 
					
						
							|  |  |  |  for single specific platform including Android API level, and assign its | 
					
						
							| 
									
										
										
										
											2022-09-22 19:27:27 +08:00
										 |  |  |  location to `ANDROID_NDK_ROOT`. In such case, you have to pass matching | 
					
						
							| 
									
										
										
										
											2020-06-10 23:49:25 +08:00
										 |  |  |  target name to Configure and shouldn't use `-D__ANDROID_API__=N`. `PATH` | 
					
						
							|  |  |  |  adjustment becomes simpler, `$ANDROID_NDK_ROOT/bin:$PATH` suffices. | 
					
						
							| 
									
										
										
										
											2018-10-14 21:19:41 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-16 19:14:28 +08:00
										 |  |  |  Running tests (on Linux) | 
					
						
							|  |  |  |  ------------------------ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  This is not actually supported. Notes are meant rather as inspiration. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Even though build output targets alien system, it's possible to execute | 
					
						
							|  |  |  |  test suite on Linux system by employing qemu-user. The trick is static | 
					
						
							|  |  |  |  linking. Pass -static to Configure, then edit generated Makefile and | 
					
						
							|  |  |  |  remove occurrences of -ldl and -pie flags. You would also need to pick | 
					
						
							|  |  |  |  API version that comes with usable static libraries, 42/2=21 used to | 
					
						
							|  |  |  |  work. Once built, you should be able to | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     env EXE_SHELL=qemu-<arch> make test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  If you need to pass additional flag to qemu, quotes are your friend, e.g. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     env EXE_SHELL="qemu-mips64el -cpu MIPS64R6-generic" make test |