واجهة التطبيق الثنائية
واجهة التطبيق الثنائية (بالإنجليزية: Application binary interface اختصارها (ABI)) في برمجيات الحاسب هي واجهة بين وحدتي برنامج ثنائيين، وفي الغالب تكون واحدة من هذه الوحدات عبارة عن مكتبة برمجية أو بيئة نظام التشغيل، والأخرى هي البرنامج الذي يتم تشغيله من قبل المستخدم. تقوم هذه الواجهة بتعريف آليات الوصول إلى هياكل البيانات أو الإجراءات الحسابية في لغة الآلة، وهي عبارة عن أدنى مستوى من تفاصيل البرمجة المرئية للمبرمج والتي تعتمد على الأجهزة بشكل أساس. في المقابل، واجهة برمجة التطبيقات ويشار إليها اختصارا (بالإنجليزية: API) تعرّف هذا الوصول في الشيفرة المصدرية وهي في مستوى أعلى نسبيا. تعتبر واجهة برمجة التطبيقات تنسيقا مستقلا عن الأجهزة، وغالباً ما تكون قابلة للقراءة من قبل الإنسان. أحد الجوانب الشائعة لـواجهة برمجة التطبيقات هو اصطلاح الاستدعاء، الذي يحدد كيفية توفير البيانات كمدخلات أو قراءة مخرجات من إجرائية حسابية. على سبيل المثال اصطلاحات استدعاء إكس 86.
عادة مايكون الالتزام بواجهة التطبيق الثنائية (التي قد تكون أو لا تكون موحدة بشكل رسمي) وظيفة المحول البرمجي أو نظام التشغيل أو مؤلف المكتبة البرمجية. ومع ذلك، قد يضطر مبرمجو التطبيقات إلى التعامل مع واجهة التطبيق الثنائية بشكل مباشر عند كتابة برامجهم باستخدام مزيج من لغات البرمجة (أو حتى المحولات البرمجية المختلفة لنفس لغة البرمجة).
الوصف
تغطي واجهة التطبيق الثنائية عدة تفاصيل مثل:
- مجموعة تعليمات المعالج (مع تفاصيل مثل تسجيل بنية الملف، ومؤسسة المكدس، وأنواع الوصول إلى الذاكرة).
- الأحجام والتخطيطات والمحاذاة لأنواع البيانات الأساسية التي يمكن للمعالج الوصول إليها مباشرة.
- اصطلاح الاستدعاء، الذي يتحكم في كيفية تمرير وسيطات الدالات واسترداد قيم الإرجاع، على سبيل المثال، ما إذا كانت كافة المعلمات يتم تمريرها على المكدس أو يتم تمرير بعضها في السجلات، أية سجلات استخدمت لمعلمات الدالة، وما إذا كان يتم دفع معلمة الدالة الأولى التي تم تمريرها إلى المكدس أولاً أو آخراً.
- كيف يجب أن يقوم التطبيق بإجراء استدعاءات نظام التشغيل، وما وإذا كانت واجهة التطبيق الثنائية تحدد أرقام استدعاءات النظام لاستدعاءات النظام المباشرة عوضاً عن الاستدعاءات الإجرائية لأنوية استدعاء النظام.
- وحالة وجود واجهة تطبيق ثنائية لنظام تشغيل كامل، التنسيق الثنائي لملفات الكائنات ومكتبات البرنامج وهَلُمَّ جَرّاً.
واجهات التطبيق الثنائية الكاملة
واجهة التطبيق الثنائية الكاملة مثل مثل معيار انتل للتوافق الثنائي (بالإنجليزية: Intel Binary Compatibility Standard) ويشار إليها اختصارا (بالإنجليزية: (iBCS))،[1] تسمح لبرنامج من نظام تشغيل واحد يدعم واجهة التطبيق الثنائية بالعمل دون الحاجة إلى أي تعديلات في هذا النظام. شريطة أن تكون المكتبات المشتركة اللازمة موجودة، وأن يتم استيفاء الشروط المسبقة المماثلة.
واجهات تطبيق ثنائية أخرى توحد التفاصيل وعلى سبيل المثال تغييرات الاسم في لغة سي++، ونشر تدابير الحالات الاستثنائية واصطلاح الاستدعاء بين المحولات البرمجية على نفس النظام الأساسي، والتي لا تتطلب توافقية متعددة المنصات.
واجهات التطبيق الثنائية المضمنة
تحدد الواجهة الثنائية المضمنة (أو المدمجة) للتطبيق الاصطلاحات القياسية لصيغة الملفات وأنواع البيانات واستخدام السجل وتنظيم إطار المكدس ومعلمة الدالة التي تمر عبر برنامج مضمن للاستخدام مع نظام تشغيل مضمن.
المحولات البرمجية التي تدعم واجهة التطبيق الثنائية المضمنة تنشئ رمز كائن متوافق مع التعليمات البرمجية التي تم إنشاؤها بواسطة المحولات البرمجية الأخرى، مما يسمح للمطورين بالربط بين المكتبات التي تم إنشاؤها باستخدام محول برمجي مع رمز الكائن الذي تم إنشاؤه في محول برمجي آخر. المطورين اللذين يكتبون رمز لغة التجميع الخاص بهم قد يتفاعلون أيضا مع تجميعة تم إنشاؤها باستخدام محول برمجي متوافق.
تم تصميم واجهة التطبيق الثنائية المضمنة لتحسين الأداء ضمن الموارد المحدودة للأنظمة المضمنة. تقوم واجهة التطبيق الثنائية بحذف معظم التجريدات التي يتم إجراؤها بين النواة ورمز المستخدم في أنظمة التشغيل المعقدة. على سبيل المثال، يتم تجنب الربط الديناميكي للسماح بعمليات تنفيذية أصغر وتحميل أسرع، كما أن استخدام سجل ثابت يسمح بتكدسات أكثر إحكاما وباتصال النواة. ويسمح تشغيل التطبيقات في وضع الامتيازات بالوصول المباشر إلى تشغيل الأجهزة المخصصة دون توجيه استدعاء برنامج تشغيل جهاز. اختيار واجهة التطبيق الثنائية المضمنة يمكن أن يؤثر على الأداء.
واجهات التطبيق الثنائية المضمنة المستخدمة على نطاق واسع تشمل:
باور بي سي، واجهة التطبيق الثنائية المضمنة بنية إيه آر إم، وواجهة التطبيق الثنائية المضمنة لمجموعة تعليمات ميبس
المراجع
- "iBCS - Everything2.com"، www.everything2.com، مؤرشف من الأصل في 30 نوفمبر 2019، اطلع عليه بتاريخ 25 فبراير 2020.
روابط خارجية
- Policies/Binary Compatibility Issues With C++ – خلاصة وافية لقواعد التطوير الأساسية لعدم كسر التوافق الثنائي بين إصدارات المكتبة
- – دليل استدعاء وظيفة OS X ABI
- Debian ARM EABI port
- μClib: Motorola 8/16-bit embedded ABI
- AMD64 (x86-64) Application Binary Interface
- Application Binary Interface (ABI) for the ARM Architecture
- MIPS EABI documentation
- Sun Studio 10 Compilers and the AMD64 ABI – ملخص ومقارنة لبعض واجهات التطبيق الثنائية المشهورة.
- بوابة علم الحاسوب
- بوابة تقنية المعلومات
- بوابة برمجة الحاسوب