32 bit ve 64 bit mimariler için derleme

Derleme sistemi, aynı derlemede 32 bit ve 64 bit olmak üzere iki hedef CPU mimarisi için ikili dosyalar oluşturmayı destekler. Bu iki hedefli derleme, çoklu kitaplık derlemesi olarak bilinir.

Derleme sistemi, yerleşik statik kitaplıklar ve paylaşılan kitaplıklar için her iki mimari için de ikili program oluşturma kuralları oluşturur. Ürün yapılandırması (PRODUCT_PACKAGES), bağımlılık grafiğiyle birlikte hangi ikililerin derlenip sistem görüntüsüne yükleneceğini belirler.

Derleme sistemi, yürütülebilir dosyalar ve uygulamalar için varsayılan olarak yalnızca 64 bit sürümü oluşturur ancak bu ayarı global bir BoardConfig.mk değişkeni veya modül kapsamlı bir değişkenle geçersiz kılabilirsiniz.

İkinci bir CPU mimarisini ve ABI'yi tanımlama

BoardConfig.mk, ikinci CPU mimarisini ve uygulama ikili arayüzünü (ABI) yapılandırmak için aşağıdaki değişkenleri içerir:

  • TARGET_2ND_ARCH
  • TARGET_2ND_ARCH_VARIANT
  • TARGET_2ND_CPU_VARIANT
  • TARGET_2ND_CPU_ABI
  • TARGET_2ND_CPU_ABI2

Bu değişkenleri kullanan örnek bir makefile için build/make/target/board/generic_arm64/BoardConfig.mk bölümüne bakın.

Çok kitaplıklı bir derlemede, PRODUCT_PACKAGES içindeki modül adları, derleme sistemi tarafından tanımlandıkları sürece hem 32 bit hem de 64 bit ikili dosyaları kapsar. Bağımlılık nedeniyle dahil edilen kitaplıklarda, 32 bit veya 64 bit kitaplık yalnızca başka bir 32 bit veya 64 bit kitaplık ya da yürütülebilir dosya tarafından gerekiyorsa yüklenir.

Ancak make komut satırındaki modül adları yalnızca 64 bit sürümü kapsar. Örneğin, lunch aosp_arm64-eng çalıştırıldıktan sonra make libc yalnızca 64 bit libc'yi oluşturur. 32 bit libc'yi derlemek için make libc_32 dosyasını çalıştırmanız gerekir.

Android.mk dosyasında modül mimarisini tanımlama

Derlemenizi 32 bit ve 64 bit için yapılandırmak ve global TARGET_PREFER_32_BIT değişkenini geçersiz kılmak üzere LOCAL_MULTILIB değişkenini kullanabilirsiniz.

TARGET_PREFER_32_BIT değerini geçersiz kılmak için LOCAL_MULTILIB değerini aşağıdakilerden birine ayarlayın:

  • both hem 32 bit hem de 64 bit derlemeler oluşturur.
  • 32 yalnızca 32 bit derlemeler oluşturur.
  • 64 yalnızca 64 bit derlemeler oluşturur.
  • first yalnızca ilk mimari için derlenir (32 bit cihazlarda 32 bit, 64 bit cihazlarda 64 bit).

LOCAL_MULTILIB varsayılan olarak ayarlanmamıştır ve derleme sistemi, modül sınıfına ve LOCAL_MODULE_TARGET_ARCH ile LOCAL_32_BIT_ONLY gibi diğer LOCAL_* değişkenlerine göre hangi mimarinin oluşturulacağına karar verir.

Modülünüzü belirli mimariler için derlemek istiyorsanız aşağıdaki değişkenleri kullanın:

  • LOCAL_MODULE_TARGET_ARCH: Bu değişkeni arm x86 arm64 gibi bir mimari listesi olarak ayarlayın. Derlenen mimari bu listedeyse derleme sistemi mevcut modülü ekler.

  • LOCAL_MODULE_UNSUPPORTED_TARGET_ARCH: Bu değişken, LOCAL_MODULE_TARGET_ARCH değişkeninin tam tersidir. Oluşturulan mimari bu listede not varsa geçerli modül derleme sistemi tarafından dahil edilir.

Bu iki değişkenin küçük varyantları vardır:

  • LOCAL_MODULE_TARGET_ARCH_WARN
  • LOCAL_MODULE_UNSUPPORTED_TARGET_ARCH_WARN

Derleme sistemi, listelenen mimariler nedeniyle mevcut modülün atlanması durumunda uyarı verir.

Belirli bir mimari için derleme işaretleri ayarlamak üzere, mimariye özel LOCAL_* değişkenlerini kullanın. Burada *, mimariye özel bir son ektir. Örneğin:

  • LOCAL_SRC_FILES_arm, LOCAL_SRC_FILES_x86,
  • LOCAL_CFLAGS_arm, LOCAL_CFLAGS_arm64,
  • LOCAL_LDFLAGS_arm, LOCAL_LDFLAGS_arm64,

Bu değişkenler yalnızca ilgili mimari için bir ikili oluşturuluyorsa uygulanır.

Bazen, ikili dosyanın 32 bit mi yoksa 64 bit mi oluşturulacağına bağlı olarak işaretleri ayarlamak daha kolaydır. LOCAL_* değişkenini _32 veya _64 son ekiyle kullanın. Örneğin:

  • LOCAL_SRC_FILES_32, LOCAL_SRC_FILES_64,
  • LOCAL_CFLAGS_32, LOCAL_CFLAGS_64,
  • LOCAL_LDFLAGS_32, LOCAL_LDFLAGS_64,

Kitaplık yükleme yolunu ayarlama

Multilib olmayan bir derleme için bir kitaplığı varsayılan konumdan başka bir konuma yüklemek üzere LOCAL_MODULE_PATH'ü kullanabilirsiniz. Örneğin, LOCAL_MODULE_PATH := $(TARGET_OUT_SHARED_LIBRARIES)/hw.

Ancak çok kitaplık derlemesinde bunun yerine LOCAL_MODULE_RELATIVE_PATH kullanın:

LOCAL_MODULE_RELATIVE_PATH := hw

Bu biçimle hem 64 bit hem de 32 bit kitaplıklar doğru konuma yüklenir.

Bir yürütülebilir dosyayı hem 32 bit hem de 64 bit olarak derlerseniz yükleme yolunu ayırt etmek için aşağıdaki değişkenlerden birini kullanın:

  • LOCAL_MODULE_STEM_32, LOCAL_MODULE_STEM_64: Yüklenen dosya adını belirtir.
  • LOCAL_MODULE_PATH_32, LOCAL_MODULE_PATH_64: Yükleme yolunu belirtir.

Kaynak dosyalar için ara dizin alma

Çok kitaplıklı bir derlemede, $(local-intermediates-dir) (veya açık değişkenlerle $(intermediates-dir-for)) için kaynak dosyaları oluşturursanız bu güvenilir bir şekilde çalışmaz. Bunun nedeni, oluşturulan ara kaynakların hem 32 bit hem de 64 bit derlemeler tarafından gerekli olması ancak $(local-intermediates-dir)'ün iki ara dizinden yalnızca birine işaret etmesidir.

Derleme sistemi, kaynak oluşturmak için özel, çok kitaplık uyumlu bir ara dizin sağlar. Ara dizin yolunu almak için $(local-generated-sources-dir) veya $(generated-sources-dir-for) makrosunu kullanın. Bu makroların kullanım alanları $(local-intermediates-dir) ve $(intermediates-dir-for)'e benzer.

Bu özel dizine oluşturulan ve LOCAL_GENERATED_SOURCES tarafından alınan bir kaynak dosya, çok kitaplıklı bir derlemede hem 32 bit hem de 64 bit için derlenir.

Önceden oluşturulmuş ikili hedeflerin sistem mimarisini belirtme

Çoklu kitaplık derlemesinde, önceden derlenmiş ikili hedeflerin sistem mimarisini belirtmek için TARGET_ARCH veya TARGET_ARCH ile birlikte TARGET_2ND_ARCH kullanamazsınız. Bunun yerine LOCAL_* değişkenlerini LOCAL_MODULE_TARGET_ARCH veya LOCAL_MODULE_UNSUPPORTED_TARGET_ARCH kullanın.

Derleme sistemi, bu değişkenlerle 64 bit çok kitaplıklı derleme üzerinde çalışıyor olsa bile ilgili 32 bit önceden derlenmiş ikili dosyayı seçebilir.

Önceden derlenmiş ikili programın kaynak yolunu hesaplamak için seçilen mimariyi kullanmak istiyorsanız $(get-prebuilt-src-arch) işlevini çağırın.

32 bit ve 64 bit ODEX dosyası oluşturulduğundan emin olun

Google, 64 bit cihazlar için varsayılan olarak önyükleme resmi ve tüm Java kitaplıkları için hem 32 bit hem de 64 bit ODEX dosyaları oluşturur. Google, APK'ler için varsayılan olarak yalnızca birincil 64 bit mimari için ODEX oluşturur. Bir uygulama hem 32 bit hem de 64 bit işlemlerde başlatılıyorsa hem 32 bit hem de 64 bit ODEX dosyalarının oluşturulduğundan emin olmak için LOCAL_MULTILIB := both seçeneğini kullanın. Uygulamada 32 bit veya 64 bit JNI kitaplıkları varsa bu işaret, derleme sistemine bunları da dahil etmesini söyler.