ARM架构下添加系统调用(与32位x86区别)

  在这两种架构下添加系统调用的步骤是类似的,简要地比较一下,以2.6.28.6内核为例。

  1.在内核源码相应位置(如sys.c或其他与这个函数联系紧密的文件)添加新的内核函数作为系统调用,形如

asmlinkage long sys_foo(void) {
}

  2.加入系统调用表。ARM架构存放于/arch/arm/kernel/call.S中,形如CALL(sys_foo);x86架构放于/arch/x86/kernel/syscall_table_32.S中,形如.long sys_foo。

  3.定义系统调用号。ARM架构存放于/arch/arm/include/asm/unistd.h中,形如

  

#define __NR_foo (__NR_SYSCALL_BASE+361);

  x86架构放于/arch/x86/include/asm/unistd_32.h中,形如

#define __NR_foo 333

  4.使用方法:编译修改后的内核,在用户空间中使用syscall()调用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值