In this article we will dive into system call interface implementation in arm linux(with gnu eabi).我们将从bionic中的open函数开始追溯arm linux的系统调用实现(使用gnu eabi)。
Linux的应用程序要想访问内核必须使用系统调用从而实现从usr模式转到svc模式。在arm中,这个过程是通过swi(或者和它等价的指令)来实现模式转换的。
从bionic libc中的open函数追溯系统调用实现
相关文件:
-
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
相关调用过程:
-
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_openswi #0ldmfd sp!, {r4, r7}movs r0, r0bxpl lrb __set_syscall_errno -
vector_swilinux/arch/arm/kernel/entry-common.Sadr tbl, sys_call_table @ load syscall table pointercmp scno, #NR_syscalls @ check upper syscall limitadr lr, BSYM(ret_fast_syscall) @ return addressldrcc pc, [tbl, scno, lsl #2] @ call sys_* routine -
sys_call_table系统调用跳转表,里面保存了各个系统调用实现的地址。.type sys_call_table, #objectENTRY(sys_call_table)#include "calls.S"
资源和链接
TODOS
- 找出eabi中寄存器使用和参数传递的规则
- 了解swi跳转的更多详细知识,比如如何跳转到一个固定位置的
- arm系统的中断系统
- 熟悉常用的arm指令和gnu 汇编器指令
本文探讨了ARM Linux系统调用的实现原理,重点介绍了通过bionic中的open函数追溯系统调用的过程。从应用程序访问内核的角度出发,详细解析了swi指令在ARM架构中的作用及其如何帮助实现从用户模式到内核模式的转换。
668

被折叠的 条评论
为什么被折叠?



