Applikasiya binar interfeysi

Vikipediya, azad ensiklopediya
Naviqasiyaya keç Axtarışa keç
Kerneldaxili və kerneldən istifadəçi fəzasına API və ABI-lərin yüksək səviyyəli müqayisəsi.

Applikasiya binar interfeysi (ing. application binary interface, ABI) — kompüter proqram təminatında iki binar proqram modulu arasındakı interfeys. Çox vaxt bu modullardan biri kitabxana və ya əməliyyat sistemi obyekti, digəri isə istifadəçi tərəfindən idarə olunan proqramdır.

ABI aşağı səviyyəli, aparatdan asılı format olan maşın kodunda məlumat strukturlarına və ya hesablama prosedurlarına necə daxil olunduğunu müəyyən edir. Bunun əksinə olaraq, tətbiq proqramlaşdırma interfeysi (API) bu girişi mənbə kodunda müəyyən edir. Bu, nisbətən yüksək səviyyəli, aparatdan müstəqil, çox vaxt insan tərəfindən oxuna bilən formatdır. ABI-nin ümumi cəhəti məlumatların hesablama prosedurlarına giriş kimi təqdim edilməsini və ya çıxış kimi oxunmasını müəyyən edən çağırış konvensiyasıdır. Buna misal olaraq x86 çağırış konvensiyalarını göstərmək olar.

ABI-yə riayət etmək (rəsmi olaraq standartlaşdırıla və ya standartlaşdırılmaya bilər) adətən kompilyator, əməliyyat sistemi və ya kitabxana müəllifinin işidir. Bununla belə, tətbiqi proqramçı proqramlaşdırma dillərinin qarışığında proqram yazan zaman hətta eyni dildə yazılmış proqramı müxtəlif kompilyatorlarla tərtib edərkən birbaşa ABI ilə işləməli ola bilər.

ABI əsas aparat arxitekturası qədər vacibdir. Proqram bu ikisinin hər hansı məhdudiyyətini pozarsa, eyni dərəcədə uğursuz olacaq.

Təsviri[redaktə | mənbəni redaktə et]

ABI-nin əhatə etdiyi təfərrüatlara aşağıdakılar daxildir:

  • Reyestr faylı strukturu, yığının təşkili, yaddaşa giriş növləri və s. kimi təfərrüatları olan prosessor təlimat dəsti
  • Prosessorun birbaşa daxil ola biləcəyi əsas verilənlər tiplərinin ölçüləri, tərtibatları və düzülmələri
  • Funksiyaların arqumentlərinin necə ötürüldüyünə və geri qaytarılan dəyərlərə nəzarət edən çağırış konvensiyası; məsələn, aşağıdakılara nəzarət edir:
    • İstər bütün parametrlərin yığına ötürülməsi, istərsə də bəzilərinin reyestrlərə ötürülməsi
    • Hansı reyestrlərin hansı funksiya parametrləri üçün istifadə olunması
    • Yığına ötürülən ilk funksiya parametrinin birinci və ya sonuncu itələnməsi
    • Çağırışçının və ya çağırılananın funksiya çağırışından sonra yığının təmizlənməsinə cavabdeh olub-olmaması
  • Tətbiq əməliyyat sisteminə sistem çağırışlarını necə etməli olduğu, həmçinin, əgər ABI sistem zəngləri qaralamalarına prosedur çağırışlarını yox, birbaşa sistem çağırışlarını təyin edirsə, sistem çağırış nömrələri
  • Tam əməliyyat sistemi ABI vəziyyətində, obyekt fayllarının binar formatı, proqram kitabxanaları və s.

Tam ABI[redaktə | mənbəni redaktə et]

"Intel Binary Compatibility Standard" (iBCS) kimi tam ABI[1] onu dəstəkləyən bir əməliyyat sistemindən olan proqrama lazımi paylaşılan kitabxanaların mövcud olması və oxşar ilkin şərtlərin yerinə yetirilməsi şərti ilə hər hansı digər belə sistemdə dəyişiklik etmədən işləməyə imkan verir.

ABI-lər həmçinin C++ adının dəyişdirilməsi,[2] istisnaların yayılması[3] və eyni platformada kompilyatorlar arasında çağırış konvensiyası kimi təfərrüatları standartlaşdıra bilər. Bu, platformalar arası uyğunluq tələb etmir.

Daxili ABI[redaktə | mənbəni redaktə et]

Daxili proqram binar interfeysi (EABI) daxili əməliyyat sistemi ilə istifadə üçün fayl formatları, verilənlər növləri, reyestrdən istifadə, yığın çərçivəsinin təşkili və quraşdırılmış proqram təminatının funksiya parametrlərinin ötürülməsi üçün standart konvensiyaları müəyyən edir.

EABI-lər quraşdırılmış sistemin məhdud resursları daxilində performansı optimallaşdırmaq üçün nəzərdə tutulmuşdur. Buna görə də EABI-lər mürəkkəb əməliyyat sistemlərində nüvə və istifadəçi kodu arasında edilən əksər abstraksiyaları buraxır. Məsələn, daha kiçik icra olunanlara və daha sürətli yüklənməyə imkan vermək üçün dinamik keçiddən qaçınmaq olar, sabit reyestrdən istifadə daha yığcam yığınlara və kernel çağırışlarına imkan verir, proqramın imtiyazlı rejimdə işlədilməsi cihaz sürücüsünə zəng etmədən birbaşa giriş imkanı yaradır.[4] EABI seçimi performansa təsir edə bilər.[5][6]

Geniş istifadə olunan EABI-lərə "PowerPC",[4] "Arm" EABI[7] və "MIPS" EABI daxildir.[8] C kitabxanası kimi xüsusi proqram təminatı tətbiqləri daha konkret ABI formalaşdırmaq üçün əlavə məhdudiyyətlər tətbiq edə bilər. Məsələn, ARM EABI-nin alt çoxluqları olan ARM üçün GNU OABI və EABI-dır. [9]

Həmçinin bax[redaktə | mənbəni redaktə et]

İstinadlar[redaktə | mənbəni redaktə et]

  1. "Intel Binary Compatibility Standard (iBCS)". 2012-05-27 tarixində arxivləşdirilib. İstifadə tarixi: 2023-12-12.
  2. "Itanium C++ ABI". 2023-07-31 tarixində arxivləşdirilib. İstifadə tarixi: 2023-12-12. (compatible with multiple architectures)
  3. "Itanium C++ ABI: Exception Handling". 2023-11-27 tarixində arxivləşdirilib. İstifadə tarixi: 2023-12-12. (compatible with multiple architectures)
  4. 1 2 EABI Summary // PowerPC Embedded Application Binary Interface: 32-Bit Implementation (PDF) (Version 1.0). Freescale Semiconductor, Inc. 1 October 1995. 28–30. 31 July 2023 tarixində arxivləşdirilib (PDF). İstifadə tarixi: 12 December 2023.
  5. "Debian ARM accelerates via EABI port". Linuxdevices.com. 16 October 2016. 21 January 2007 tarixində orijinalından arxivləşdirilib. İstifadə tarixi: 11 October 2007.
  6. Andrés Calderón and Nelson Castillo. "Why ARM's EABI matters". Linuxdevices.com. 14 March 2007. 31 March 2007 tarixində orijinalından arxivləşdirilib. İstifadə tarixi: 11 October 2007.
  7. "ABI for the Arm Architecture". Developer.arm.com. 4 February 2020 tarixində arxivləşdirilib. İstifadə tarixi: 4 February 2020.
  8. Eric Christopher. "mips eabi documentation". binutils@sources.redhat.com (Poçt siyahısı). 11 June 2003. 7 May 2020 tarixində arxivləşdirilib. İstifadə tarixi: 19 June 2020.
  9. "ArmEabiPort". Debian Wiki. 2013-09-27 tarixində arxivləşdirilib. İstifadə tarixi: 2023-12-12. Strictly speaking, both the old and new ARM ABIs are subsets of the ARM EABI specification, but in everyday usage the term "EABI" is used to mean the new one described here and "OABI" or "old-ABI" to mean the old one.

Xarici keçidlər[redaktə | mənbəni redaktə et]