تتميز Vulkan بسرعتها المنخفضة، واجهة برمجة تطبيقات من عدّة أنظمة أساسية لعرض ثلاثي الأبعاد عالي الأداء والرسومات. مثل OpenGL ES (GLES)، توفر Vulkan أدوات لإنشاء رسومات في الوقت الفعلي في التطبيقات. تشمل مزايا استخدام Vulkan خفض معدّل استخدام وحدة المعالجة المركزية (CPU). النقل والدعم للغة SPIR-V Binary Intermediate.
لتنفيذ Vulkan بنجاح، يجب أن يشتمل الجهاز على ما يلي:
- أداة تحميل Vulkan المقدَّمة من Android
- يشير ذلك المصطلح إلى برنامج تشغيل Vulkan يتم توفيره من خلال منظومة على الرقاقة (SoC) مثل وحدات معالجة الرسومات الداخلية (GPU) التي توفّر وحدات معالجة الرسومات (GPU). لتنفيذ Vulkan API: لدعم وظائف Vulkan، يحتاج الجهاز إلى أجهزة وحدة معالجة رسومات متوافقة مع Vulkan وبرامج التشغيل المرتبطة بها. وحدة معالجة الرسومات أن يتوافق مع الإصدار 3.1 من GLES والإصدارات الأحدث استشِر مورّد المنظومة على الرقاقة (SoC) لطلب دعم السائق.
إذا كان الجهاز يتضمن برنامج تشغيل Vulkan، يجب على الجهاز توضيح
FEATURE_VULKAN_HARDWARE_LEVEL
و
FEATURE_VULKAN_HARDWARE_VERSION
من ميزات النظام، مع إصدارات
تعكس إمكانات الجهاز بدقة. يساعد هذا في ضمان
يتوافق جهازك مع
مستند تعريف التوافق (CDD).
أداة تحميل Vulkan
أداة تحميل Vulkan platform/frameworks/native/vulkan
هي
واجهة أساسية بين تطبيقات Vulkan وبرنامج تشغيل Vulkan للجهاز. ذا فولكان
القيمة المُثبَّتة لأداة التحميل في /system/lib[64]/libvulkan.so
. عامل التحميل
نقاط دخول واجهة برمجة تطبيقات Vulkan الأساسية ونقاط دخول الإضافات
المطلوبة بواسطة Android CDD، والعديد من الإضافات الاختيارية الإضافية. نافذة
يتم تصدير إضافات تكامل النظام (WSI) بواسطة أداة التحميل وبشكل أساسي
تنفيذها في برنامج التحميل بدلاً من تنفيذها في برنامج التشغيل. كما يدعم برنامج التحميل
مع تعداد الطبقات وتحميلها التي يمكن أن تكشف عن المزيد من الإضافات وتتقاطع مع
الأساسية في طريقها إلى برنامج التشغيل.
يتضمن NDK مكتبة بديلة libvulkan.so
المرتبطة. تصدر المكتبة نفس الرموز مثل برنامج التحميل. تطلب التطبيقات الوظائف
تم تصديره من مكتبة libvulkan.so
الحقيقية إلى
دخول وظائف الترامبولين في الحمولة، والذي يتم نقله إلى
طبقة أو برنامج التشغيل بناءً على الوسيطة الأولى. vkGet*ProcAddr()
يقوم بإرجاع مؤشرات الدالة التي تنقل منصات الترامبولين إليها (أي
فإنها تستدعي مباشرة رمز واجهة برمجة التطبيقات الأساسية). يشير استدعاء الدالة من خلال الدالة
أكثر كفاءة، بدلاً من الرموز التي يتم تصديرها، حيث
ويتخطى الترامبولين ويرسلها.
تعداد برامج التشغيل والتحميل
عند إنشاء صورة النظام، يتوقع Android أن يعرف النظام وحدات معالجة الرسومات (GPU).
المتوفرة. تستخدم طريقة التحميل آلية HAL الحالية في
hardware.h
لاكتشاف برنامج التشغيل وتحميله. المسارات المفضلة لبرامج تشغيل Vulkan 32 بت و64 بت هي:
/vendor/lib/hw/vulkan.<ro.hardware.vulkan>.so /vendor/lib/hw/vulkan.<ro.product.platform>.so /vendor/lib64/hw/vulkan.<ro.hardware.vulkan>.so /vendor/lib64/hw/vulkan.<ro.product.platform>.so
وفي نظام التشغيل Android 7.0 والإصدارات الأحدث، تم استخدام مشتق Vulkan hw_module_t
تتضمن هذه العلامة بنية hw_module_t
واحدة، يتم دعم برنامج تشغيل واحد فقط والسلسلة الثابتة
تم تمرير HWVULKAN_DEVICE_0
إلى open()
.
يتجاوب مشتق Vulkan hw_device_t
مع قيمة واحدة
لبرنامج التشغيل الذي يمكن أن يدعم أجهزة مادية متعددة. تشير رسالة الأشكال البيانية
يمكن توسيع بنية hw_device_t
لتصديرها
vkGetGlobalExtensionProperties()
وvkCreateInstance()
و
vkGetInstanceProcAddr()
. ويمكن للقائم بالتحميل العثور على جميع
VkInstance()
وVkPhysicalDevice()
و
دوال vkGetDeviceProcAddr()
عن طريق استدعاء
بنية hw_device_t
vkGetInstanceProcAddr()
.
اكتشاف الطبقات وتحميلها
يدعم برنامج تحميل Vulkan تعداد الطبقات وتحميلها التي يمكن أن تعرض الإضافات الإضافية واعتراض طلبات البيانات من واجهة برمجة التطبيقات الأساسية في طريقها إلى السائق. لا يشتمل Android على طبقات على صورة النظام. وَلَكِنْ قد تتضمن التطبيقات طبقات في حزمة APK
عند استخدام الطبقات، يجب تذكُّر أنّ نموذج أمان Android وسياساته اختلافًا كبيرًا عن المنصات الأخرى. على وجه الخصوص، لا يسمح Android تحميل رمز خارجي في عملية لا يمكن تصحيح الأخطاء بها على قناة الإصدار العلني (غير مزوّد بحق الوصول إلى الجذر) الأجهزة، ولا يسمح للرمز البرمجي الخارجي بفحص عمليات والذاكرة والحالة وما إلى ذلك. ويشمل ذلك حظر حفظ النفايات الأساسية وواجهة برمجة التطبيقات. وآثارها وما إلى ذلك على القرص لفحصها لاحقًا. فقط الطبقات التي يتم تقديمها كجزء من يتم تفعيل التطبيقات التي لا يمكن تصحيح الأخطاء بها على أجهزة الإنتاج، ويجب ألا توفِّر برامج التشغيل الوظائف التي تنتهك هذه السياسات.
تشمل حالات استخدام الطبقات ما يلي:
- طبقات وقت التطوير: التحقُّق من الصحة يجب عدم تثبيت الطبقات والرقائق الخاصة بأدوات التتبع/الملف التعريفي/تصحيح الأخطاء على صورة النظام لأجهزة الإنتاج. طبقات وعمليات التحقق من صحة يجب أن تكون أدوات التتبع/التتبّع/تصحيح الأخطاء قابلة للتحديث بدون وجود نظام . المطوِّرون الذين يريدون استخدام أحد هذه التطبيقات من هذه الطبقات أثناء التطوير يمكن أن تعدل حزمة التطبيق، على سبيل المثال، عن طريق إضافة ملف إلى دليل المكتبات الأصلية. مهندسو IHV والمصنّعين الأصليين للأجهزة الذين تريد تشخيص الأعطال في شحن التطبيقات غير القابلة للتعديل الوصول إلى الإصدارات غير الإنتاجية (المزوّدة بحق الوصول إلى الجذر) لصورة النظام، ما لم تكن تلك التطبيقات قابلة للتصحيح. لمزيد من المعلومات، يمكنك الاطّلاع على طبقات التحقق من Vulkan على Android.
- طبقات الأداة: تكشف هذه الطبقات عن الإضافات، مثل الطبقة التي تعمل على تنفيذ أداة إدارة الذاكرة لذاكرة الجهاز. يختار المطورون الطبقات وإصدارات هذه الطبقات لاستخدامها في تطبيق، إلا أن التطبيقات المختلفة التي تستخدم الطبقة نفسها قد تظل تستخدم على إصدارات مختلفة. يختار المطورون أي من هذه الطبقات لشحنها حزمة التطبيق.
- الطبقات (الضمنية) التي تم إدخالها: تتضمن الطبقات مثل عدد اللقطات في الثانية والشبكة الاجتماعية وتراكبات مشغّل الألعاب التي يوفّرها المستخدم بعض التطبيقات الأخرى بدون علم التطبيق أو موافقته. هذه تنتهك سياسات أمان Android وغير مدعومة.
وبالنسبة إلى التطبيقات التي لا يمكن تصحيح الأخطاء بها، يبحث برنامج التحميل عن الطبقات فقط في
دليل المكتبة الأصلي للتطبيق ويحاول تحميل أي مكتبة باسم
تتطابق مع نمط معيّن (على سبيل المثال، libVKLayer_foo.so
).
وبالنسبة إلى التطبيقات التي يمكن تصحيح الأخطاء بها، يبحث برنامج التحميل عن طبقات في
/data/local/debug/vulkan
ويحاول تحميل أي مكتبة مطابقة
نمط معين.
يتيح Android نقل الطبقات مع تغييرات بيئة الإنشاء بين Android والأنظمة الأساسية الأخرى. للحصول على تفاصيل حول الواجهة بين الطبقات عامل تحميل، راجع بنية واجهات Vulkan Loader. حضارة الخرونوس تتم استضافة طبقات التحقق من الصحة في طبقات التحقق من صحة Vulkan.
إصدارات وإمكانات Vulkan API
يسرد الجدول التالي إصدارات Vulkan API لعدة إصدارات من Android.إصدار Android | إصدار Vulkan |
---|---|
Android 13 | Vulkan 1.3 |
الإصدار 9 من نظام التشغيل Android | Vulkan 1.1 |
الإصدار 7 من نظام التشغيل Android | Vulkan 1.0 |
نظرة عامة على وظائف Vulkan 1.3
يعتمد Vulkan 1.3 على عدد من الإضافات الاختيارية سابقًا في وظائف Vulkan الأساسية. ويتم تضمين الكثير من هذه الوظائف بغرض زيادة التحكم والدقة في واجهة برمجة Vulkan. لم تعُد مثيلات بطاقات العرض ذات بطاقة واحدة مطلوبة لعرض كائنات التمرير أو المخزن المؤقت للإطارات. ويمكن تقليل العدد الإجمالي لكائنات حالة المسار، إصلاح المزامنة داخل واجهة برمجة التطبيقات. Vulkan 1.3 له نفس متطلبات الأجهزة مثل Vulkan 1.2 و1.1 و1.0 مع معظم عمليات التنفيذ في برنامج تشغيل الرسومات الخاص بمنظومة SoC، وليس في إطار العمل.
في ما يلي أهم ميزات Vulkan 1.3 لنظام التشغيل Android:
- إتاحة مثيلات بطاقات العرض بمرّة واحدة
- الدعم للإنهاء الفوري لاستدعاء أداة التظليل
- دقّة أكبر في إنشاء المسارات ومشاركتها والتحكّم فيها
يشتمل Vulkan 1.3 أيضًا على العديد من الميزات الأصغر وتحسينات قابلية استخدام واجهة برمجة التطبيقات. كافة التغييرات إلى واجهة برمجة تطبيقات Vulkan الأساسية مع إصدار 1.3 من المراجعة الثانوية على النُسخ الأساسية (Vulkan 1.3)
نظرة عامة على وظائف Vulkan 1.2
يضيف Vulkan 1.2 عددًا من الميزات والإضافات التي تبسِّط عرض واجهة برمجة التطبيقات. وتشمل هذه المعلومات ما يلي: طراز ذاكرة موحد ومعلومات إضافية يمكن الاستعلام عنها من برنامج تشغيل الجهاز. Vulkan 1.2 له نفس متطلبات الأجهزة مثل Vulkan 1.0 و1.1؛ جميع تطبيقها في برنامج تشغيل الرسومات الخاص بمنظومة المنظومة على الرقاقة (SoC)، وليس في إطار العمل.
أهم ميزة في الإصدار 1.2 من Vulkan لنظام التشغيل Android هي توفير مساحة تخزين على 8 بت.
يشتمل Vulkan 1.2 أيضًا على العديد من الميزات الأصغر وتحسينات قابلية استخدام واجهة برمجة التطبيقات. كافة التغييرات إلى واجهة برمجة تطبيقات Vulkan الأساسية مع إصدار 1.2 من المراجعة الثانوية على النُسخ الأساسية (Vulkan 1.2)
نظرة عامة على وظائف Vulkan 1.1
يشتمل Vulkan 1.1 على إمكانية التشغيل التفاعلي للذاكرة/المزامنة، والذي لتمكين المصنّعين الأصليين للأجهزة من دعم Vulkan 1.1 على الأجهزة. بالإضافة إلى ذلك، يتيح التشغيل المتداخل للذاكرة/المزامنة للمطوّرين لتحديد ما إذا كان الإصدار 1.1 من Vulkan متوافقًا مع أحد الأجهزة واستخدامه بفعالية عندما يكون كذلك. يمتلك Vulkan 1.1 متطلبات الأجهزة نفسها مثل Vulkan 1.0، ولكن معظم يمكن تطبيقها في برنامج تشغيل الرسومات الخاص بـ SOC، وليس في إطار العمل.
في ما يلي أهم ميزات Vulkan 1.1 لنظام التشغيل Android:
- دعم استيراد وتصدير المخازن المؤقتة للذاكرة والمزامنة عناصر من خارج Vulkan (لإمكانية التشغيل التفاعلي مع الكاميرا وبرامج الترميز وGLES)
- دعم تنسيقات YCbCr
يشتمل Vulkan 1.1 أيضًا على العديد من الميزات الأصغر وتحسينات قابلية استخدام واجهة برمجة التطبيقات. كافة التغييرات إلى واجهة برمجة تطبيقات Vulkan الأساسية مع إصدار 1.1 من المراجعة الثانوية على النُسخ الأساسية (Vulkan 1.1)
اختيار دعم Vulkan
يجب أن تتوافق أجهزة Android مع مجموعة ميزات Vulkan الأكثر تطورًا المتاحة، بشرط أن تتوافق مع واجهة التطبيق الثنائية (ABI) 64 بت ولا تكون ذاكرة منخفضة.
ويجب أن تتوافق الأجهزة التي تعمل بنظام التشغيل Android 13 والإصدارات الأحدث مع الإصدار 1.3 من Vulkan.
يجب أن تتوافق الأجهزة التي تعمل بنظام التشغيل Android 10 مع الإصدار 1.1 من Vulkan.
ويمكن أن تتوافق الأجهزة الأخرى اختياريًا مع Vulkan 1.3 و1.2 و1.1.
دعم إصدار Vulkan
يتوافق جهاز Android مع إصدار Vulkan في حال استيفاء الشروط التالية:
- إضافة برنامج تشغيل Vulkan يتوافق مع إصدار Vulkan محلّ الاهتمام (يجب أن يكون هذا الإصدار من إصدار Vulkan) 1.3 أو 1.1 أو 1.0) إلى جانب المتطلبات الإضافية لقرص الحِزمة إصدار Android. بدلاً من ذلك، يمكنك تحديث برنامج تشغيل Vulkan الحالي برقم إصدار Vulkan أقل.
- بالنسبة إلى Vulkan 1.3 أو 1.1، تأكَّد من إرجاع ميزة النظام التي يعرضها مدير الحِزم
true
لإصدار vulkan الصحيح.- بالنسبة إلى Vulkan 1.3، تعد هذه الميزة
PackageManager#hasSystemFeature(PackageManager.FEATURE_VULKAN_HARDWARE_VERSION, 0x403000)
- بالنسبة إلى Vulkan 1.1، تعد هذه الميزة
PackageManager#hasSystemFeature(PackageManager.FEATURE_VULKAN_HARDWARE_VERSION, 0x401000)
true
لبرنامج Vulkan 1.3 وVulkan 1.1 بإضافة قاعدة. كما هو موضح على النحو التالي، إلى ملفdevice.mk
مناسب.- أضف ما يلي إلى Vulkan 1.3:
PRODUCT_COPY_FILES += frameworks/native/data/etc/android.hardware.vulkan.version-1_3.xml: $(TARGET_COPY_OUT_VENDOR)/etc/permissions/android.hardware.vulkan.version.xml
- بالنسبة إلى Vulkan 1.3، تعد هذه الميزة
- أضف ما يلي إلى Vulkan 1.1:
PRODUCT_COPY_FILES += frameworks/native/data/etc/android.hardware.vulkan.version-1_1.xml: $(TARGET_COPY_OUT_VENDOR)/etc/permissions/android.hardware.vulkan.version.xml
الملف الشخصي الأساسي على Android (ABP)
ننصح جميع أجهزة Android بالتوافق مع أحدث ملف شخصي للإصدار Android Baseline 2022 وفقًا للمواصفات التالية: الموضحة في دليل الملف الشخصي في Android Baseline
على أي جهاز يعمل بنظام التشغيل Android 14 أو الإصدارات الأحدث وواجهة Vulkan API، يجب:
تلبية جميع الوظائف المحددة في
الملف الشخصي لإصدار Android Baseline 2021 القائمة الكاملة بالوظائف المطلوبة هي
في ملف Vulkan الشخصي json
، إلا أنّ هناك مجموعة فرعية رئيسية من القيم
تشمل الوظائف ما يلي:
- الزخارف المضغوطة من خلال ASTC وETC.
- مساحات ألوان متغيرة من خلال
VK_EXT_swapchain_colorspace
- تظليل العينة واستكمال النماذج المتعددة من خلال
sampleRateShading
دمج نظام النوافذ (WSI)
في libvulkan.so
، ينفِّذ برنامج التشغيل ما يلي:
إضافات دمج نظام النوافذ (WSI):
VK_KHR_surface
VK_KHR_android_surface
VK_KHR_swapchain
VK_KHR_driver_properties
، تم تنفيذه على Vulkan 1.1 بوصة Android 10 فقط- تم تنفيذ "
VK_GOOGLE_display_timing
" على أي إصدار من إصدارات Vulkan. في Android 10
العنصران VkSurfaceKHR
وVkSwapchainKHR
وجميع العناصر
تعالج المنصة التفاعلات مع ANativeWindow
، ولا تتم
يتعرض للسائقين. يعتمد تنفيذ WSI على
الإضافة VK_ANDROID_native_buffer
التي يجب أن تكون
عن طريق السائق لا يتم استخدام هذه الإضافة إلا من خلال تنفيذ WSI
ولا تظهر للتطبيقات
علامات استخدام Gralloc
قد تحتاج عمليات تنفيذ Vulkan إلى مخازن مؤقتة لسلسلة التبادل لاستخدامها مع علامات استخدام Gralloc الخاصة التي حددتها التنفيذ. عند إنشاء سلسلة تبديل يطلب Android من برنامج التشغيل ترجمة التنسيق المطلوب واستخدام الصورة. العلامات إلى علامات استخدام Gralloc من خلال استدعاء:
typedef enum VkSwapchainImageUsageFlagBitsANDROID { VK_SWAPCHAIN_IMAGE_USAGE_SHARED_BIT_ANDROID = 0x00000001, VK_SWAPCHAIN_IMAGE_USAGE_FLAG_BITS_MAX_ENUM = 0x7FFFFFFF } VkSwapchainImageUsageFlagBitsANDROID; typedef VkFlags VkSwapchainImageUsageFlagsANDROID; VkResult VKAPI vkGetSwapchainGrallocUsage2ANDROID( VkDevice device, VkFormat format, VkImageUsageFlags imageUsage, VkSwapchainImageUsageFlagsANDROID swapchainUsage, uint64_t* grallocConsumerUsage, uint64_t* grallocProducerUsage );
المعلمتان format
وimageUsage
مأخوذتان من
هيكل VkSwapchainCreateInfoKHR
. يجب أن يملأ السائق
*grallocConsumerUsage
و*grallocProducerUsage
مع
علامات الاستخدام Gralloc المطلوبة للتنسيق
واستخدامها. يتم دمج علامات الاستخدام التي يعرضها برنامج التشغيل مع معدّل الاستخدام.
علامات طلبها مستهلك نظام التبديل عند تخصيص الموارد الاحتياطية.
يطلب الإصدار 7.x من نظام التشغيل Android إصدارًا سابقًا من "VkSwapchainImageUsageFlagsANDROID()
".
باسم vkGetSwapchainGrallocUsageANDROID()
. إيقاف الإصدار 8.0 والإصدارات الأحدث من نظام التشغيل Android
vkGetSwapchainGrallocUsageANDROID()
ولكن لا تزال المكالمات
vkGetSwapchainGrallocUsageANDROID()
إذا
لا يوفّر السائق القيمة vkGetSwapchainGrallocUsage2ANDROID()
:
VkResult VKAPI vkGetSwapchainGrallocUsageANDROID( VkDevice device, VkFormat format, VkImageUsageFlags imageUsage, int* grallocUsage );
لا يتوافق vkGetSwapchainGrallocUsageANDROID()
مع استخدام نظام التبديل في سلسلة.
أو علامات استخدام إضافية لـ Gralloc
صور مستنِدة إلى Gralloc
VkNativeBufferANDROID
هو إضافة vkCreateImage
لإنشاء صورة يدعمها المخزن المؤقت Gralloc. VkNativeBufferANDROID
هو
تم توفيرها إلى vkCreateImage()
في VkImageCreateInfo
هيكلية سلسلة. يتم إجراء مكالمات إلى vkCreateImage()
مع VkNativeBufferANDROID
.
أثناء الاتصال بـ vkCreateSwapchainKHR
. يخصص تنفيذ WSI
عدد المخازن الأصلية المطلوبة لسلسلة التبديل، ثم تنشئ
VkImage
لكل نوع:
typedef struct { VkStructureType sType; // must be VK_STRUCTURE_TYPE_NATIVE_BUFFER_ANDROID const void* pNext; // Buffer handle and stride returned from gralloc alloc() buffer_handle_t handle; int stride; // Gralloc format and usage requested when the buffer was allocated. int format; int usage; // Beginning in Android 8.0, the usage field above is deprecated and the // usage2 struct below was added. The usage field is still filled in for // compatibility with Android 7.0 drivers. Drivers for Android 8.0 // should prefer the usage2 struct, especially if the // android.hardware.graphics.allocator HAL uses the extended usage bits. struct { uint64_t consumer; uint64_t producer; } usage2; } VkNativeBufferANDROID;
عند إنشاء صورة مدعومة من Gralloc، تكون لدى VkImageCreateInfo
البيانات التالية:
.sType = VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO .pNext = the above VkNativeBufferANDROID structure .imageType = VK_IMAGE_TYPE_2D .format = a VkFormat matching the format requested for the gralloc buffer .extent = the 2D dimensions requested for the gralloc buffer .mipLevels = 1 .arraySize = 1 .samples = 1 .tiling = VK_IMAGE_TILING_OPTIMAL .usage = VkSwapchainCreateInfoKHR::imageUsage .flags = 0 .sharingMode = VkSwapchainCreateInfoKHR::imageSharingMode .queueFamilyCount = VkSwapchainCreateInfoKHR::queueFamilyIndexCount .pQueueFamilyIndices = VkSwapchainCreateInfoKHR::pQueueFamilyIndices
وفي Android 8.0 والإصدارات الأحدث، يوفر النظام الأساسي
بنية الإضافة "VkSwapchainImageCreateInfoKHR
" في
تم توفير سلسلة VkImageCreateInfo
لـ "vkCreateImage
"
عندما تكون هناك حاجة إلى علامات استخدام صورة سلسلة التبديل لسلسلة التبديل.
تحتوي بنية الإضافة على علامات استخدام صورة سلسلة التبديل:
typedef struct { VkStructureType sType; // must be VK_STRUCTURE_TYPE_SWAPCHAIN_IMAGE_CREATE_INFO_ANDROID const void* pNext; VkSwapchainImageUsageFlagsANDROID usage; } VkSwapchainImageCreateInfoANDROID;
في نظام التشغيل Android 10 والإصدارات الأحدث، يدعم النظام الأساسي
VK_KHR_swapchain
الإصدار 70، لذلك يستطيع تطبيق Vulkan إنشاء
تم الاحتفاظ بنسخة احتياطية من VkImage
من خلال ذاكرة التبديل. يطلب التطبيق أولاً
vkCreateImage
باستخدام VkImageSwapchainCreateInfoKHR
بنية مرتبطة بالبنية VkImageCreateInfo
. ثم
يطلب التطبيق الاتصال بـ vkBindImageMemory2(KHR)
باستخدام
بنية VkBindImageMemorySwapchainInfoKHR
مرتبطة بالسلسلة
بنية VkBindImageMemoryInfo
imageIndex
المحددة في بنية VkBindImageMemorySwapchainInfoKHR
يجب
كفهرس صور صالح لسلسلة التبديل. في الوقت نفسه، توفّر المنصة
بنية الإضافة VkNativeBufferANDROID
مع البنية المقابلة
معلومات المخزن المؤقت Gralloc في سلسلة VkBindImageMemoryInfo
، لذلك
يعرف برنامج التشغيل أي المخزن المؤقت Gralloc الذي يربط VkImage
بها.
الحصول على صور
يحصل vkAcquireImageANDROID
على ملكية صورة لسلسلة التبديل.
وتستورد سياجًا أصليًا يتم إرسال إشارة إليه خارجيًا إلى كلٍ من
كائن VkSemaphore
وكائن VkFence
حالي:
VkResult VKAPI vkAcquireImageANDROID( VkDevice device, VkImage image, int nativeFenceFd, VkSemaphore semaphore, VkFence fence );
يتم استدعاء vkAcquireImageANDROID()
أثناء
vkAcquireNextImageKHR
لاستيراد
سياج أصلي بين الكائنات VkSemaphore
وVkFence
التي يوفرها التطبيق (ومع ذلك، فإن كلاً من عناصر الإشارة وكائنات السياج
اختيارية في هذه المكالمة). ويمكن للسائق أيضًا استغلال هذه الفرصة للتعرُّف على
ومعالجة أي تغييرات خارجية على حالة المخزن المؤقت Gralloc إلا أن العديد من السائقين لن
أحتاج إلى اتخاذ أي إجراء هنا. تضع هذه المكالمة VkSemaphore
و
VkFence
في حالة الانتظار نفسها كما لو تمت الإشارة إليها من خلال vkQueueSubmit
.
لذلك يمكن أن تنتظر قوائم الانتظار على الإشارة ويمكن للتطبيق الانتظار.
وتتم الإشارة إلى كِلا العنصرَين عند وجود إشارات سياجية أصلية. إذا
قد تمت الإشارة من السياج الأصلي، فإن الإشارة ضمن الإشارات
عند إرجاع هذه الدالة. يحصل السائق على ملكية ملف السياج.
ويغلق واصف ملف السياج إذا لم يعد هناك حاجة إليه. السائق
يجب فعل ذلك حتى في حال عدم توفير أي عنصر منسي أو عنصر، أو حتى
تعذّر vkAcquireImageANDROID
وعرض خطأ. في حال حذف
fenceFd
- 1، ويبدو كما لو كان السياج المحلي
مُشار إليها.
إصدار الصور
يتم إعداد صورة سلسلة التبديل لـ vkQueueSignalReleaseImageANDROID
.
واستخدام خارجي، وإنشاء سور أصلي، وجدولة السياج الأصلي ليتم الإشارة إليه بعد
أشارت رموز الإدخال إلى:
VkResult VKAPI vkQueueSignalReleaseImageANDROID( VkQueue queue, uint32_t waitSemaphoreCount, const VkSemaphore* pWaitSemaphores, VkImage image, int* pNativeFenceFd );
يتصل vkQueuePresentKHR()
بـ vkQueueSignalReleaseImageANDROID()
.
في قائمة الانتظار المقدّمة. يجب أن يضع السائق سياجًا أصليًا لا يُظهر إشارة
حتى علامات waitSemaphoreCount
إشارة pWaitSemaphores
وأي عمل إضافي مطلوب
إعداد image
ليكتمل العرض التقديمي.
إذا كانت علامات الانتظار (إن وُجدت) قد تمت الإشارة إليها، وكانت قيمة queue
هي
في وضع الخمول بالفعل، يمكن للسائق ضبط *pNativeFenceFd
إلى -1
بدلاً من واصف ملف سياج أصلي، مما يشير إلى أن
فلا داعي للانتظار. يمتلك المتصل واصف الملف ويغلقه.
تم إرجاعها في *pNativeFenceFd
.
يمكن للعديد من برامج التشغيل تجاهل مَعلمة الصورة، ولكن قد يحتاج البعض الآخر إلى الاستعداد
هياكل البيانات من جانب وحدة المعالجة المركزية (CPU) المرتبطة بمخازن Gralloc المؤقت للاستخدام من قِبل جهات خارجية
المستهلكون للصور. يجب أن يعد تحضير محتويات المورد الاحتياطي للاستخدام من قبل المستهلكين الخارجيين
أن يتم بشكل غير متزامن كجزء من نقل الصورة إلى
VK_IMAGE_LAYOUT_PRESENT_SRC_KHR
إذا تم إنشاء الصورة باستخدام
VK_SWAPCHAIN_IMAGE_USAGE_SHARED_BIT_ANDROID
، ثم يجب أن يكون السائق
السماح بالاتصال بـ vkQueueSignalReleaseImageANDROID()
بشكل متكرر
بدون تدخل مكالمات إلى vkAcquireImageANDROID()
.
إتاحة إمكانية مشاركة الصور التي تتيح مشاركة العرض
يمكن أن تشترك بعض الأجهزة في ملكية صورة واحدة بين
مسار العرض وتنفيذ Vulkan لتقليل وقت الاستجابة.
وفي الإصدار 9 من نظام التشغيل Android والإصدارات الأحدث، تعلن أداة التحميل بشكل مشروط عن
إضافة واحدة (VK_KHR_shared_presentable_image
) استنادًا إلى معلومات السائق
ردًا على مكالمة إلى vkGetPhysicalDeviceProperties2
.
إذا لم يكن السائق متوافقًا مع Vulkan 1.1 أو
VK_KHR_physical_device_properties2
، إلا أن أداة التحميل لا
الإعلان عن الدعم للصور التي يمكن مشاركتها مع الآخرين بخلاف ذلك، تطلب أداة التحميل
إمكانات السائق من خلال الاتصال بـ vkGetPhysicalDeviceProperties2()
وتضمين الهيكل التالي في
سلسلة VkPhysicalDeviceProperties2::pNext
:
typedef struct { VkStructureType sType; // must be VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_PRESENTATION_PROPERTIES_ANDROID const void* pNext; VkBool32 sharedImage; } VkPhysicalDevicePresentationPropertiesANDROID;
إذا كان بإمكان السائق مشاركة ملكية صورة مع الشاشة
يضبط العضو sharedImage
على VK_TRUE
.
التحقُّق
يمكن للمصنّعين الأصليين للأجهزة اختبار تنفيذ Vulkan باستخدام CTS، الذي يتضمن ما يلي:
- اختبارات التوافق مع Khronos Vulkan
في وحدة
CtsDeqpTestCases
، والتي تتضمن اختبارات واجهة برمجة التطبيقات الوظيفية لإصدارات Vulkan 1.0 و1.1 و1.2 و1.3. - وحدة
CtsGraphicsTestCases
التي تختبر أداء الجهاز بشكل صحيح لإمكانيات Vulkan التي تتوافق معها.
علامة ميزة Vulkan
جهاز متوافق مع Android 11 أو الإصدارات الأحدث ويتوافق مع Vulkan API
مطلوبة لعرض علامة الميزة،
android.software.vulkan.deqp.level
قيمة علامة هذه الميزة
يمثل تاريخًا، مُشفرًا كقيمة عددية. يحدد التاريخ المرتبط
اختبارات Vulkan dEQP التي يدّعي الجهاز اجتيازها.
وقد تم ترميز التاريخ بالتنسيق YYYY-MM-DD كعدد صحيح 32 بت على النحو التالي:
- البت 0-15 تخزن العام
- البت 16-23 تخزن الشهر
- البت 24-31 مخزنة في اليوم
إنّ أدنى قيمة مسموح بها لعلامة الميزة هي 0x07E30301
،
الذي يتوافق مع التاريخ 2019-03-01، وهو التاريخ المرتبط
اختبارات dEQP من Vulkan لنظام التشغيل Android 10 إذا كانت علامة الميزة بهذه القيمة على الأقل،
يدّعي الجهاز اجتياز جميع اختبارات Vulkan dEQP على نظام Android 10.
تتوافق القيمة 0x07E40301
مع التاريخ 2020-03-01، وهو
التاريخ المرتبط باختبارات Vulkan dEQP لنظام Android 11. إذا كانت الميزة
هذه القيمة على الأقل، يدعي الجهاز أنه يجتاز كل معايير
اختبارات dEQP من Vulkan.
تتوافق القيمة 0x07E60301
مع التاريخ 01-03-2022، وهو
التاريخ المرتبط باختبارات Vulkan dEQP
الإصدار 13 من نظام التشغيل Android إذا كانت علامة الميزة بهذه القيمة على الأقل،
يدّعي الجهاز أنّه يحيل جميع بيانات Vulkan Android 13
اختبارات dEQP.
هو جهاز يكشف عن علامة ميزة معيّنة (أي
0x07E30301
و0x07E40301
و0x07E60301
)
يدعي أنه يجتاز جميع اختبارات dEQP من Android Vulkan لعلامة الميزة هذه (نظام التشغيل Android 10،
Android 11 وAndroid 13 على التوالي). هذا الجهاز
قد تجتاز اختبارات Vulkan dEQP من إصدار Android لاحق.
ويشكّل Vulkan dEQP جزءًا من مجموعة أدوات Android CTS. من نظام Android 11، يُعد معدّو اختبار dEQP
أحد مكوّنات CTS على دراية بـ android.software.vulkan.deqp.level
وتتخطى أي اختبارات Vulkan dEQP وفقًا لذلك
علامة الميزة - لا يدّعي الجهاز توافقه. مثل هذه الاختبارات
تم الإبلاغ عنه على أنه يمر تافهًا.