新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > arm linux 系統(tǒng)調(diào)用實(shí)現(xiàn)

arm linux 系統(tǒng)調(diào)用實(shí)現(xiàn)

作者: 時(shí)間:2016-11-09 來(lái)源:網(wǎng)絡(luò) 收藏
In this article we will dive into system call interface implementation in arm linux(with gnu eabi).我們將從bionic中的open函數(shù)開(kāi)始追溯arm linux的系統(tǒng)調(diào)用實(shí)現(xiàn)(使用gnu eabi)。

Linux的應(yīng)用程序要想訪問(wèn)內(nèi)核必須使用系統(tǒng)調(diào)用從而實(shí)現(xiàn)從usr模式轉(zhuǎn)到svc模式。在arm中,這個(gè)過(guò)程是通過(guò)swi(或者和它等價(jià)的指令)來(lái)實(shí)現(xiàn)模式轉(zhuǎn)換的。

本文引用地址:http://m.butianyuan.cn/article/201611/318015.htm

從bionic libc中的open函數(shù)追溯系統(tǒng)調(diào)用實(shí)現(xiàn)

相關(guān)文件:

  • bionic/libc/unistd/open.c

  • bionic/libc/arch-arm/syscalls/__open.S

  • linux/arch/arm/kernel/entry-common.S

  • linux/arch/arm/kernel/entry-armv.S

  • linux/arch/arm/kernel/entry-header.S

相關(guān)調(diào)用過(guò)程:

  • int open(const char *pathname, int flags, ...);bionic/libc/unistd/open.c

  • __openbionic/libc/arch-arm/syscalls/__open.S

    __open:

    .save {r4, r7}

    stmfd sp!, {r4, r7}

    ldr r7, =__NR_open

    swi #0

    ldmfd sp!, {r4, r7}

    movs r0, r0

    bxpl lr

    b __set_syscall_errno

  • vector_swilinux/arch/arm/kernel/entry-common.S

    adr tbl, sys_call_table @ load syscall table pointer

    cmp scno, #NR_syscalls @ check upper syscall limit

    adr lr, BSYM(ret_fast_syscall) @ return address

    ldrcc pc, [tbl, scno, lsl #2] @ call sys_* routine

  • sys_call_table系統(tǒng)調(diào)用跳轉(zhuǎn)表,里面保存了各個(gè)系統(tǒng)調(diào)用實(shí)現(xiàn)的地址。

    .type sys_call_table, #object

    ENTRY(sys_call_table)

    #include "calls.S"

資源和鏈接

  • eabi
  • ARM linux系統(tǒng)調(diào)用的實(shí)現(xiàn)原理
  • SWI : SoftWare Interrupt

TODOS

  • 找出eabi中寄存器使用和參數(shù)傳遞的規(guī)則
  • 了解swi跳轉(zhuǎn)的更多詳細(xì)知識(shí),比如如何跳轉(zhuǎn)到一個(gè)固定位置的
  • arm系統(tǒng)的中斷系統(tǒng)
  • 熟悉常用的arm指令和gnu 匯編器指令


關(guān)鍵詞: armlinux系統(tǒng)調(diào)

評(píng)論


技術(shù)專區(qū)

關(guān)閉