VNDK সংজ্ঞা সরঞ্জামটি বিক্রেতাদের তাদের উত্স গাছকে একটি Android 8.0 পরিবেশে স্থানান্তর করতে সহায়তা করে৷ এই টুলটি সিস্টেমে বাইনারি ফাইল স্ক্যান করে এবং বিক্রেতা ইমেজ তারপর নির্ভরতা সমাধান করে। মডিউল নির্ভরতা গ্রাফের উপর ভিত্তি করে, টুলটি VNDK ধারণাগুলির লঙ্ঘন সনাক্ত করতে পারে এবং পার্টিশনগুলির মধ্যে মডিউলগুলি সরানোর জন্য অন্তর্দৃষ্টি/পরামর্শ প্রদান করতে পারে। যদি একটি জেনেরিক সিস্টেম ইমেজ (GSI) নির্দিষ্ট করা হয়, VNDK সংজ্ঞা টুল GSI এর সাথে আপনার সিস্টেম ইমেজ তুলনা করতে পারে এবং বর্ধিত লাইব্রেরি নির্ধারণ করতে পারে।
এই বিভাগটি VNDK সংজ্ঞা সরঞ্জামের জন্য প্রায়শই ব্যবহৃত তিনটি কমান্ড কভার করে:
-
vndkঅ্যান্ড্রয়েড 8.0 এবং উচ্চতর সংস্করণে সিস্টেমের সমাধানের জন্য VNDK_SP_LIBRARIES, VNDK_SP_EXT_LIBRARIES এবং EXTRA_VENDOR_LIBRARIES কম্পিউট করুন৷ -
check-depভেন্ডর মডিউল থেকে অযোগ্য ফ্রেমওয়ার্ক শেয়ার্ড লাইব্রেরিতে লঙ্ঘনকারী মডিউল নির্ভরতা পরীক্ষা করুন। -
depsশেয়ার্ড লাইব্রেরি এবং এক্সিকিউটেবলের মধ্যে নির্ভরতা প্রিন্ট করুন।
উন্নত কমান্ড ব্যবহার সম্পর্কে আরও বিশদ বিবরণের জন্য, VNDK সংজ্ঞা সরঞ্জাম সংগ্রহস্থলে README.md ফাইলটি পড়ুন।
vndk
vndk সাবকমান্ড সিস্টেম পার্টিশন এবং ভেন্ডর পার্টিশন থেকে শেয়ার্ড লাইব্রেরি এবং এক্সিকিউটেবলগুলি লোড করে, তারপর /system/lib[64]/vndk-sp-${VER} এবং /vendor/lib[64] এ কপি করা আবশ্যক লাইব্রেরিগুলি নির্ধারণ করতে মডিউল নির্ভরতা সমাধান করে। vndk সাবকমান্ডের বিকল্পগুলির মধ্যে রয়েছে:
| অপশন | বর্ণনা |
|---|---|
--system | সিস্টেম পার্টিশনে থাকা ফাইল ধারণকারী একটি ডিরেক্টরিতে নির্দেশ করুন। |
--vendor | একটি বিক্রেতা পার্টিশনে থাকা ফাইলগুলি ধারণকারী একটি ডিরেক্টরিতে নির্দেশ করুন। |
--aosp-system | জেনেরিক সিস্টেম ইমেজে (GSI) থাকা ফাইলগুলি ধারণকারী একটি ডিরেক্টরির দিকে নির্দেশ করুন। |
--load-extra-deps | একটি ফাইলের দিকে নির্দেশ করুন যা অন্তর্নিহিত নির্ভরতা বর্ণনা করে, যেমন dlopen() । |
উদাহরণস্বরূপ, VNDK লাইব্রেরি সেট গণনা করতে, নিম্নলিখিত vndk সাবকমান্ড চালান:
./vndk_definition_tool.py vndk \
--system ${ANDROID_PRODUCT_OUT}/system \
--vendor ${ANDROID_PRODUCT_OUT}/vendor \
--aosp-system ${ANDROID_PRODUCT_OUT}/../generic_arm64_ab/system\
--load-extra-deps dlopen.depএকটি সাধারণ ফাইল বিন্যাসের সাথে অতিরিক্ত নির্ভরতা নির্দিষ্ট করুন। প্রতিটি লাইন একটি সম্পর্কের প্রতিনিধিত্ব করে, কোলনের আগে ফাইলের সাথে কোলনের পরে ফাইলের উপর নির্ভর করে। যেমন:
/system/lib/libart.so: /system/lib/libart-compiler.so
এই লাইনটি VNDK সংজ্ঞা সরঞ্জামটিকে জানতে দেয় যে libart.so নির্ভর করে libart-compiler.so এর উপর।
ইনস্টলেশনের গন্তব্য
VNDK সংজ্ঞা টুল নিম্নলিখিত বিভাগের জন্য লাইব্রেরি এবং সংশ্লিষ্ট ইনস্টল ডিরেক্টরি তালিকাভুক্ত করে:
| শ্রেণী | ডিরেক্টরি |
|---|---|
| vndk_sp | অবশ্যই /system/lib[64]/vndk-sp-${VER} এ ইনস্টল করতে হবে |
| vndk_sp_ext | /vendor/lib[64]/vndk-sp এ ইনস্টল করতে হবে |
| extra_vendor_libs | /vendor/lib[64] এ ইনস্টল করতে হবে |
সিস্টেম টেমপ্লেট তৈরি করুন
VNDK সংজ্ঞা সরঞ্জাম থেকে আউটপুট সংগ্রহ করার পরে, একজন বিক্রেতা একটি Android.mk তৈরি করতে পারেন এবং VNDK_SP_LIBRARIES , VNDK_SP_EXT_LIBRARIES এবং EXTRA_VENDOR_LIBRARIES পূরণ করতে পারেন যাতে লাইব্রেরিগুলিকে নির্ধারিত ইনস্টলেশন গন্তব্যে অনুলিপি করার প্রক্রিয়াটি স্বয়ংক্রিয়ভাবে করা যায়৷
ifneq ($(filter $(YOUR_DEVICE_NAME),$(TARGET_DEVICE)),) VNDK_SP_LIBRARIES := ##_VNDK_SP_## VNDK_SP_EXT_LIBRARIES := ##_VNDK_SP_EXT_## EXTRA_VENDOR_LIBRARIES := ##_EXTRA_VENDOR_LIBS_## #------------------------------------------------------------------------------- # VNDK Modules #------------------------------------------------------------------------------- LOCAL_PATH := $(call my-dir) define define-vndk-lib include $$(CLEAR_VARS) LOCAL_MODULE := $1.$2 LOCAL_MODULE_CLASS := SHARED_LIBRARIES LOCAL_PREBUILT_MODULE_FILE := $$(TARGET_OUT_INTERMEDIATE_LIBRARIES)/$1.so LOCAL_STRIP_MODULE := false LOCAL_MULTILIB := first LOCAL_MODULE_TAGS := optional LOCAL_INSTALLED_MODULE_STEM := $1.so LOCAL_MODULE_SUFFIX := .so LOCAL_MODULE_RELATIVE_PATH := $3 LOCAL_VENDOR_MODULE := $4 include $$(BUILD_PREBUILT) ifneq ($$(TARGET_2ND_ARCH),) ifneq ($$(TARGET_TRANSLATE_2ND_ARCH),true) include $$(CLEAR_VARS) LOCAL_MODULE := $1.$2 LOCAL_MODULE_CLASS := SHARED_LIBRARIES LOCAL_PREBUILT_MODULE_FILE := $$($$(TARGET_2ND_ARCH_VAR_PREFIX)TARGET_OUT_INTERMEDIATE_LIBRARIES)/$1.so LOCAL_STRIP_MODULE := false LOCAL_MULTILIB := 32 LOCAL_MODULE_TAGS := optional LOCAL_INSTALLED_MODULE_STEM := $1.so LOCAL_MODULE_SUFFIX := .so LOCAL_MODULE_RELATIVE_PATH := $3 LOCAL_VENDOR_MODULE := $4 include $$(BUILD_PREBUILT) endif # TARGET_TRANSLATE_2ND_ARCH is not true endif # TARGET_2ND_ARCH is not empty endef $(foreach lib,$(VNDK_SP_LIBRARIES),\ $(eval $(call define-vndk-lib,$(lib),vndk-sp-gen,vndk-sp,))) $(foreach lib,$(VNDK_SP_EXT_LIBRARIES),\ $(eval $(call define-vndk-lib,$(lib),vndk-sp-ext-gen,vndk-sp,true))) $(foreach lib,$(EXTRA_VENDOR_LIBRARIES),\ $(eval $(call define-vndk-lib,$(lib),vndk-ext-gen,,true))) #------------------------------------------------------------------------------- # Phony Package #------------------------------------------------------------------------------- include $(CLEAR_VARS) LOCAL_MODULE := $(YOUR_DEVICE_NAME)-vndk LOCAL_MODULE_TAGS := optional LOCAL_REQUIRED_MODULES := \ $(addsuffix .vndk-sp-gen,$(VNDK_SP_LIBRARIES)) \ $(addsuffix .vndk-sp-ext-gen,$(VNDK_SP_EXT_LIBRARIES)) \ $(addsuffix .vndk-ext-gen,$(EXTRA_VENDOR_LIBRARIES)) include $(BUILD_PHONY_PACKAGE) endif # ifneq ($(filter $(YOUR_DEVICE_NAME),$(TARGET_DEVICE)),)
চেক-ডেপ
check-dep সাবকমান্ড বিক্রেতা মডিউল স্ক্যান করে এবং তাদের নির্ভরতা পরীক্ষা করে। যদি এটি লঙ্ঘন সনাক্ত করে, এটি লঙ্ঘন নির্ভর লাইব্রেরি এবং প্রতীক ব্যবহারগুলি মুদ্রণ করে:
./vndk_definition_tool.py check-dep \
--system ${ANDROID_PRODUCT_OUT}/system \
--vendor ${ANDROID_PRODUCT_OUT}/vendor \
--tag-file eligible-list.csv \
--module-info ${ANDROID_PRODUCT_OUT}/module-info.json \
1> check_dep.txt \
2> check_dep_err.txt উদাহরণস্বরূপ, নিম্নলিখিত নমুনা আউটপুট libRS_internal.so থেকে libmediandk.so তে একটি লঙ্ঘন নির্ভরতা দেখায়:
/system/lib/libRS_internal.so
MODULE_PATH: frameworks/rs
/system/lib/libmediandk.so
AImageReader_acquireNextImage
AImageReader_delete
AImageReader_getWindow
AImageReader_new
AImageReader_setImageListener check-dep সাবকমান্ডের বিকল্পগুলির মধ্যে রয়েছে:
| অপশন | বর্ণনা |
|---|---|
--tag-file | একটি যোগ্য লাইব্রেরি ট্যাগ ফাইল (নীচে বর্ণিত) উল্লেখ করতে হবে, যা একটি Google-প্রদত্ত স্প্রেডশীট যা ফ্রেমওয়ার্ক ভাগ করা লাইব্রেরির বিভাগগুলি বর্ণনা করে৷ |
--module-info | অ্যান্ড্রয়েড বিল্ড সিস্টেম দ্বারা উত্পন্ন module-info.json দিকে পয়েন্ট করে৷ এটি VNDK সংজ্ঞা টুলকে সোর্স কোডের সাথে বাইনারি মডিউল সংযুক্ত করতে সাহায্য করে। |
যোগ্য লাইব্রেরি ট্যাগ ফাইল
Google একটি যোগ্য VNDK স্প্রেডশীট প্রদান করে (যেমন eligible-list.csv ) যা ফ্রেমওয়ার্ক ভাগ করা লাইব্রেরিগুলিকে ট্যাগ করে যা বিক্রেতা মডিউল দ্বারা ব্যবহার করা যেতে পারে:
| ট্যাগ | বর্ণনা |
|---|---|
| এলএল-এনডিকে | স্থিতিশীল ABIs/API সহ ভাগ করা লাইব্রেরি যা ফ্রেমওয়ার্ক এবং বিক্রেতা মডিউল উভয়ই ব্যবহার করতে পারে। |
| এলএল-এনডিকে-প্রাইভেট | LL-NDK লাইব্রেরির ব্যক্তিগত নির্ভরতা। বিক্রেতা মডিউল সরাসরি এই লাইব্রেরি অ্যাক্সেস করা উচিত নয়. |
| ভিএনডিকে-এসপি | SP-HAL ফ্রেমওয়ার্ক শেয়ার করা লাইব্রেরি নির্ভরতা। |
| VNDK-SP-প্রাইভেট | VNDK-SP নির্ভরতা যা সমস্ত বিক্রেতা মডিউলগুলিতে সরাসরি অ্যাক্সেসযোগ্য নয়। |
| ভিএনডিকে | ফ্রেমওয়ার্ক শেয়ার করা লাইব্রেরি যা বিক্রেতা মডিউলের জন্য উপলব্ধ (SP-HAL এবং SP-HAL-Dep ছাড়া)। |
| ভিএনডিকে-প্রাইভেট | VNDK নির্ভরতা যা সমস্ত বিক্রেতা মডিউলগুলিতে সরাসরি অ্যাক্সেসযোগ্য নয়। |
| FWK-শুধুমাত্র | ফ্রেমওয়ার্ক-কেবল শেয়ার করা লাইব্রেরি যা অবশ্যই বিক্রেতা মডিউল দ্বারা অ্যাক্সেস করা উচিত নয় (প্রত্যক্ষ বা পরোক্ষভাবে নয়)। |
| FWK-শুধু-RS | ফ্রেমওয়ার্ক-কেবল শেয়ার করা লাইব্রেরি যা অবশ্যই ভেন্ডর মডিউল দ্বারা অ্যাক্সেস করা যাবে না (RS ব্যবহার ব্যতীত)। |
নিম্নলিখিত সারণীটি বিক্রেতার ভাগ করা লাইব্রেরির জন্য ব্যবহৃত ট্যাগগুলি বর্ণনা করে:
| ট্যাগ | বর্ণনা |
|---|---|
| এসপি-এইচএএল | একই-প্রক্রিয়া HAL বাস্তবায়ন শেয়ার্ড লাইব্রেরি। |
| SP-HAL-Dep | SP-HAL বিক্রেতা লাইব্রেরি নির্ভরতা শেয়ার করেছেন (এলএল-এনডিকে এবং ভিএনডিকে-এসপি ব্যতীত এসপি-এইচএএল নির্ভরতাও বলা হয়)। |
| VND-শুধুমাত্র | ফ্রেমওয়ার্ক-অদৃশ্য শেয়ার করা লাইব্রেরি যা ফ্রেমওয়ার্ক মডিউল দ্বারা অ্যাক্সেস করা উচিত নয়। অনুলিপি করা বর্ধিত VNDK লাইব্রেরিগুলিকে VND-ONLY হিসাবে ট্যাগ করা হয়েছে৷ |
ট্যাগের মধ্যে সম্পর্ক:

চিত্র 1. ট্যাগের মধ্যে সম্পর্ক।
deps
লাইব্রেরি নির্ভরতা ডিবাগ করতে, deps সাবকমান্ড মডিউল নির্ভরতা প্রিন্ট করে:
./vndk_definition_tool.py deps \
--system ${ANDROID_PRODUCT_OUT}/system \
--vendor ${ANDROID_PRODUCT_OUT}/vendorআউটপুট একাধিক লাইন নিয়ে গঠিত। ট্যাব অক্ষর ছাড়া লাইন একটি নতুন বিভাগ শুরু করে। একটি ট্যাব অক্ষর সহ লাইন পূর্ববর্তী বিভাগের উপর নির্ভর করে। যেমন:
/system/lib/ld-android.so
/system/lib/libc.so
/system/lib/libdl.soএই আউটপুটটি দেখায় যে ld-android.so কোনো নির্ভরতা নেই এবং libc.so নির্ভর করে libdl.so এর উপর।
--revert বিকল্প নির্দিষ্ট করার সময়, deps সাবকমান্ড লাইব্রেরির ব্যবহার প্রিন্ট করে (বিপরীত নির্ভরতা):
./vndk_definition_tool.py deps \
--revert \
--system ${ANDROID_PRODUCT_OUT}/system \
--vendor ${ANDROID_PRODUCT_OUT}/vendorযেমন:
/system/lib/ld-android.so
/system/lib/libdl.so
এই আউটপুটটি দেখায় যে ld-android.so libdl.so দ্বারা ব্যবহৃত হয়, বা অন্য কথায়, libdl.so ld-android.so এর উপর নির্ভর করে। উপরন্তু, এই আউটপুটটি দেখায় যে libdl.so হল ld-android.so এর একমাত্র ব্যবহারকারী।
--symbol বিকল্পটি নির্দিষ্ট করার সময়, deps সাবকমান্ড ব্যবহৃত চিহ্নগুলি প্রিন্ট করে:
./vndk_definition_tool.py deps \
--symbol \
--system ${ANDROID_PRODUCT_OUT}/system \
--vendor ${ANDROID_PRODUCT_OUT}/vendor
যেমন:
/system/lib/libc.so
/system/lib/libdl.so
android_get_application_target_sdk_version
dl_unwind_find_exidx
dlclose
dlerror
dlopen
dlsymএই আউটপুটটি দেখায় যে libc.so libdl.so থেকে রপ্তানি করা ছয়টি ফাংশনের উপর নির্ভর করে। যদি --symbol বিকল্প এবং --revert বিকল্প উভয়ই নির্দিষ্ট করা থাকে, ব্যবহারকারীর দ্বারা ব্যবহৃত প্রতীকগুলি মুদ্রিত হয়।