aboutsummaryrefslogtreecommitdiff
path: root/pkgs/development/androidndk-pkgs
diff options
context:
space:
mode:
authorSander van der Burg <svanderburg@gmail.com>2018-11-28 22:14:43 +0100
committerSander van der Burg <svanderburg@gmail.com>2018-12-18 21:14:43 +0100
commit2757ddb18221e1cad72dd4ca12930cfaf017ed6b (patch)
treeca3b6f4310cf5514084f344bc4fbb092b381fe61 /pkgs/development/androidndk-pkgs
parentde9c97c0c872d06799075f18e263b5dd101bd839 (diff)
Separate androidndkpkgs from androidenv
Diffstat (limited to 'pkgs/development/androidndk-pkgs')
-rw-r--r--pkgs/development/androidndk-pkgs/androidndk-pkgs.nix126
-rw-r--r--pkgs/development/androidndk-pkgs/default.nix36
2 files changed, 162 insertions, 0 deletions
diff --git a/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix b/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix
new file mode 100644
index 00000000000..d4189fe8455
--- /dev/null
+++ b/pkgs/development/androidndk-pkgs/androidndk-pkgs.nix
@@ -0,0 +1,126 @@
+{ lib, stdenv
+, makeWrapper
+, runCommand, wrapBintoolsWith, wrapCCWith
+, buildAndroidndk, androidndk, targetAndroidndkPkgs
+}:
+
+let
+ # Mapping from a platform to information needed to unpack NDK stuff for that
+ # platform.
+ #
+ # N.B. The Android NDK uses slightly different LLVM-style platform triples
+ # than we do. We don't just use theirs because ours are less ambiguous and
+ # some builds need that clarity.
+ ndkInfoFun = { config, ... }: {
+ "x86_64-apple-darwin" = {
+ double = "darwin-x86_64";
+ };
+ "x86_64-unknown-linux-gnu" = {
+ double = "linux-x86_64";
+ };
+ "armv5tel-unknown-linux-androideabi" = {
+ arch = "arm";
+ triple = "arm-linux-androideabi";
+ gccVer = "4.8";
+ };
+ "armv7a-unknown-linux-androideabi" = {
+ arch = "arm";
+ triple = "arm-linux-androideabi";
+ gccVer = "4.9";
+ };
+ "aarch64-unknown-linux-android" = {
+ arch = "arm64";
+ triple = "aarch64-linux-android";
+ gccVer = "4.9";
+ };
+ }.${config} or
+ (throw "Android NDK doesn't support ${config}, as far as we know");
+
+ hostInfo = ndkInfoFun stdenv.hostPlatform;
+ targetInfo = ndkInfoFun stdenv.targetPlatform;
+
+in
+
+rec {
+ # Misc tools
+ binaries = let
+ ndkBinDir =
+ "${androidndk}/libexec/${androidndk.name}/toolchains/${targetInfo.triple}-${targetInfo.gccVer}/prebuilt/${hostInfo.double}/bin";
+ in runCommand "ndk-gcc-binutils" {
+ isGNU = true; # for cc-wrapper
+ nativeBuildInputs = [ makeWrapper ];
+ propgatedBuildInputs = [ androidndk ];
+ } ''
+ mkdir -p $out/bin
+ for prog in ${ndkBinDir}/${targetInfo.triple}-*; do
+ prog_suffix=$(basename $prog | sed 's/${targetInfo.triple}-//')
+ ln -s $prog $out/bin/${stdenv.targetPlatform.config}-$prog_suffix
+ done
+ '';
+
+ binutils = wrapBintoolsWith {
+ bintools = binaries;
+ libc = targetAndroidndkPkgs.libraries;
+ extraBuildCommands = ''
+ echo "--build-id" >> $out/nix-support/libc-ldflags
+ '';
+ };
+
+ gcc = wrapCCWith {
+ cc = binaries;
+ bintools = binutils;
+ libc = targetAndroidndkPkgs.libraries;
+ extraBuildCommands = ''
+ echo "-D__ANDROID_API__=${stdenv.targetPlatform.sdkVer}" >> $out/nix-support/cc-cflags
+ ''
+ + lib.optionalString stdenv.targetPlatform.isAarch32 (let
+ p = stdenv.targetPlatform.platform.gcc or {}
+ // stdenv.targetPlatform.parsed.abi;
+ flags = lib.concatLists [
+ (lib.optional (p ? arch) "-march=${p.arch}")
+ (lib.optional (p ? cpu) "-mcpu=${p.cpu}")
+ (lib.optional (p ? abi) "-mabi=${p.abi}")
+ (lib.optional (p ? fpu) "-mfpu=${p.fpu}")
+ (lib.optional (p ? float) "-mfloat=${p.float}")
+ (lib.optional (p ? float-abi) "-mfloat-abi=${p.float-abi}")
+ (lib.optional (p ? mode) "-mmode=${p.mode}")
+ ];
+ in ''
+ sed -E -i \
+ $out/bin/${stdenv.targetPlatform.config}-cc \
+ $out/bin/${stdenv.targetPlatform.config}-c++ \
+ $out/bin/${stdenv.targetPlatform.config}-gcc \
+ $out/bin/${stdenv.targetPlatform.config}-g++ \
+ -e '130i extraBefore+=(-Wl,--fix-cortex-a8)' \
+ -e 's|^(extraBefore=)\(\)$|\1(${builtins.toString flags})|'
+ '')
+ # GCC 4.9 is the first relase with "-fstack-protector"
+ + lib.optionalString (lib.versionOlder targetInfo.gccVer "4.9") ''
+ sed -E \
+ -i $out/nix-support/add-hardening.sh \
+ -e 's|(-fstack-protector)-strong|\1|g'
+ '';
+ };
+
+ # Bionic lib C and other libraries.
+ #
+ # We use androidndk from the previous stage, else we waste time or get cycles
+ # cross-compiling packages to wrap incorrectly wrap binaries we don't include
+ # anyways.
+ libraries =
+ let
+ includePath = if buildAndroidndk.version == "10e" then
+ "${buildAndroidndk}/libexec/${buildAndroidndk.name}/platforms/android-${stdenv.hostPlatform.sdkVer}/arch-${hostInfo.arch}/usr/include/"
+ else
+ "${buildAndroidndk}/libexec/${buildAndroidndk.name}/sysroot/usr/include";
+ libPath = "${buildAndroidndk}/libexec/${buildAndroidndk.name}/platforms/android-${stdenv.hostPlatform.sdkVer}/arch-${hostInfo.arch}/usr/lib/";
+ in
+ runCommand "bionic-prebuilt" {} ''
+ mkdir -p $out
+ cp -r ${includePath} $out/include
+ chmod +w $out/include
+ ${lib.optionalString (lib.versionOlder "10e" buildAndroidndk.version)
+ "ln -s $out/include/${hostInfo.triple}/asm $out/include/asm"}
+ ln -s ${libPath} $out/lib
+ '';
+}
diff --git a/pkgs/development/androidndk-pkgs/default.nix b/pkgs/development/androidndk-pkgs/default.nix
new file mode 100644
index 00000000000..1c34b1dff7d
--- /dev/null
+++ b/pkgs/development/androidndk-pkgs/default.nix
@@ -0,0 +1,36 @@
+{ androidenv, buildPackages, pkgs, targetPackages
+, includeSources ? true, licenseAccepted ? false
+}:
+
+rec {
+
+ "17c" = import ./androidndk-pkgs.nix {
+ inherit (buildPackages)
+ makeWrapper;
+ inherit (pkgs)
+ lib stdenv
+ runCommand wrapBintoolsWith wrapCCWith;
+ # buildPackages.foo rather than buildPackages.buildPackages.foo would work,
+ # but for splicing messing up on infinite recursion for the variants we
+ # *dont't* use. Using this workaround, but also making a test to ensure
+ # these two really are the same.
+ buildAndroidndk = buildPackages.buildPackages.androidenv.androidndk_17c;
+ androidndk = androidenv.androidndk_17c;
+ targetAndroidndkPkgs = targetPackages.androidndkPkgs_17c;
+ };
+
+ "10e" = import ./androidndk-pkgs.nix {
+ inherit (buildPackages)
+ makeWrapper;
+ inherit (pkgs)
+ lib stdenv
+ runCommand wrapBintoolsWith wrapCCWith;
+ # buildPackages.foo rather than buildPackages.buildPackages.foo would work,
+ # but for splicing messing up on infinite recursion for the variants we
+ # *dont't* use. Using this workaround, but also making a test to ensure
+ # these two really are the same.
+ buildAndroidndk = buildPackages.buildPackages.androidenv.androidndk_10e;
+ androidndk = androidenv.androidndk_10e;
+ targetAndroidndkPkgs = targetPackages.androidndkPkgs_10e;
+ };
+}